Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
7fb262b5
F
Ffmpeg
项目概览
小白菜888
/
Ffmpeg
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
F
Ffmpeg
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
7fb262b5
编写于
8月 20, 2008
作者:
M
Michael Niedermayer
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Simplify timestamp reordering by using the new API.
Originally committed as revision 14872 to
svn://svn.ffmpeg.org/ffmpeg/trunk
上级
79de84f2
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
3 addition
and
21 deletion
+3
-21
ffplay.c
ffplay.c
+3
-21
未找到文件。
ffplay.c
浏览文件 @
7fb262b5
...
...
@@ -1330,21 +1330,6 @@ static int output_picture2(VideoState *is, AVFrame *src_frame, double pts1)
return
queue_picture
(
is
,
src_frame
,
pts
);
}
static
uint64_t
global_video_pkt_pts
=
AV_NOPTS_VALUE
;
static
int
my_get_buffer
(
struct
AVCodecContext
*
c
,
AVFrame
*
pic
){
int
ret
=
avcodec_default_get_buffer
(
c
,
pic
);
uint64_t
*
pts
=
av_malloc
(
sizeof
(
uint64_t
));
*
pts
=
global_video_pkt_pts
;
pic
->
opaque
=
pts
;
return
ret
;
}
static
void
my_release_buffer
(
struct
AVCodecContext
*
c
,
AVFrame
*
pic
){
if
(
pic
)
av_freep
(
&
pic
->
opaque
);
avcodec_default_release_buffer
(
c
,
pic
);
}
static
int
video_thread
(
void
*
arg
)
{
VideoState
*
is
=
arg
;
...
...
@@ -1367,14 +1352,14 @@ static int video_thread(void *arg)
/* NOTE: ipts is the PTS of the _first_ picture beginning in
this packet, if any */
global_video_pkt_pts
=
pkt
->
pts
;
is
->
video_st
->
codec
->
reordered_opaque
=
pkt
->
pts
;
len1
=
avcodec_decode_video
(
is
->
video_st
->
codec
,
frame
,
&
got_picture
,
pkt
->
data
,
pkt
->
size
);
if
(
(
decoder_reorder_pts
||
pkt
->
dts
==
AV_NOPTS_VALUE
)
&&
frame
->
opaque
&&
*
(
uint64_t
*
)
frame
->
opaque
!=
AV_NOPTS_VALUE
)
pts
=
*
(
uint64_t
*
)
frame
->
opaque
;
&&
frame
->
reordered_
opaque
!=
AV_NOPTS_VALUE
)
pts
=
frame
->
reordered_
opaque
;
else
if
(
pkt
->
dts
!=
AV_NOPTS_VALUE
)
pts
=
pkt
->
dts
;
else
...
...
@@ -1802,9 +1787,6 @@ static int stream_component_open(VideoState *is, int stream_index)
packet_queue_init
(
&
is
->
videoq
);
is
->
video_tid
=
SDL_CreateThread
(
video_thread
,
is
);
enc
->
get_buffer
=
my_get_buffer
;
enc
->
release_buffer
=
my_release_buffer
;
break
;
case
CODEC_TYPE_SUBTITLE
:
is
->
subtitle_stream
=
stream_index
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录