Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
尘离序散
obs-studio
提交
0f272de0
O
obs-studio
项目概览
尘离序散
/
obs-studio
与 Fork 源项目一致
从无法访问的项目Fork
通知
30
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
O
obs-studio
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
0f272de0
编写于
2月 10, 2020
作者:
J
Jim
提交者:
GitHub
2月 10, 2020
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #2393 from cg2121/simplify-media-code
deps/media-playback: Simplify seek/time code
上级
94d4bfdb
9730b270
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
15 addition
and
30 deletion
+15
-30
deps/media-playback/media-playback/media.c
deps/media-playback/media-playback/media.c
+15
-30
未找到文件。
deps/media-playback/media-playback/media.c
浏览文件 @
0f272de0
...
...
@@ -436,19 +436,17 @@ static void mp_media_calc_next_ns(mp_media_t *m)
m
->
next_pts_ns
=
min_next_ns
;
}
static
bool
mp_media_reset
(
mp_media_t
*
m
)
static
void
seek_to
(
mp_media_t
*
m
,
int64_t
pos
,
bool
reset
)
{
AVStream
*
stream
=
m
->
fmt
->
streams
[
0
];
int64_t
seek_pos
;
int64_t
seek_pos
=
pos
;
int
seek_flags
;
bool
stopping
;
bool
active
;
if
(
m
->
fmt
->
duration
==
AV_NOPTS_VALUE
)
{
seek_pos
=
0
;
seek_flags
=
AVSEEK_FLAG_FRAME
;
}
else
{
seek_pos
=
m
->
fmt
->
start_time
;
if
(
reset
)
seek_pos
=
m
->
fmt
->
start_time
;
seek_flags
=
AVSEEK_FLAG_BACKWARD
;
}
...
...
@@ -469,6 +467,14 @@ static bool mp_media_reset(mp_media_t *m)
mp_decode_flush
(
&
m
->
v
);
if
(
m
->
has_audio
&&
m
->
is_local_file
)
mp_decode_flush
(
&
m
->
a
);
}
static
bool
mp_media_reset
(
mp_media_t
*
m
)
{
bool
stopping
;
bool
active
;
seek_to
(
m
,
0
,
true
);
int64_t
next_ts
=
mp_media_get_base_pts
(
m
);
int64_t
offset
=
next_ts
-
m
->
next_pts_ns
;
...
...
@@ -829,8 +835,8 @@ void mp_media_stop(mp_media_t *m)
int64_t
mp_get_current_time
(
mp_media_t
*
m
)
{
return
(
int64_t
)(((
float
)
m
->
next_pts_ns
/
1000000
.
0
f
)
*
((
float
)
m
->
speed
/
100
.
0
f
))
;
int
speed
=
(
int
)((
float
)
m
->
speed
/
100
.
0
f
);
return
(
mp_media_get_base_pts
(
m
)
/
1000000
)
*
speed
;
}
void
mp_media_seek_to
(
mp_media_t
*
m
,
int64_t
pos
)
...
...
@@ -838,26 +844,5 @@ void mp_media_seek_to(mp_media_t *m, int64_t pos)
if
(
!
m
->
active
)
return
;
int64_t
seek_to
=
pos
*
1000
;
AVStream
*
stream
=
m
->
fmt
->
streams
[
0
];
int64_t
seek_target
=
AVSEEK_FLAG_BACKWARD
==
AVSEEK_FLAG_BACKWARD
?
av_rescale_q
(
seek_to
,
AV_TIME_BASE_Q
,
stream
->
time_base
)
:
seek_to
;
if
(
m
->
is_local_file
)
{
int
ret
=
av_seek_frame
(
m
->
fmt
,
0
,
seek_target
,
AVSEEK_FLAG_BACKWARD
);
if
(
ret
<
0
)
{
blog
(
LOG_WARNING
,
"MP: Failed to seek: %s"
,
av_err2str
(
ret
));
}
}
if
(
m
->
has_video
&&
m
->
is_local_file
)
mp_decode_flush
(
&
m
->
v
);
if
(
m
->
has_audio
&&
m
->
is_local_file
)
mp_decode_flush
(
&
m
->
a
);
seek_to
(
m
,
pos
*
1000
,
false
);
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录