Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
qq_25606643
ijkplayer
提交
21186801
I
ijkplayer
项目概览
qq_25606643
/
ijkplayer
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
I
ijkplayer
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
21186801
编写于
9月 25, 2013
作者:
Z
Zhang Rui
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
ff_ffplay: optimize buffering water mark
上级
7aa47630
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
24 addition
and
13 deletion
+24
-13
ijkmedia/ijkplayer/ff_ffplay.c
ijkmedia/ijkplayer/ff_ffplay.c
+24
-13
未找到文件。
ijkmedia/ijkplayer/ff_ffplay.c
浏览文件 @
21186801
...
...
@@ -2210,15 +2210,14 @@ static int read_thread(void *arg)
}
do
{
int
buf_percent
=
INT_MAX
;
int
buf_size_percent
=
INT_MAX
;
int
buf_time_percent
=
INT_MAX
;
int
buf_size_percent
=
-
1
;
int
buf_time_percent
=
-
1
;
int
hwm_in_bytes
=
ffp
->
high_water_mark_in_bytes
;
int
hwm_in_ms
=
ffp
->
high_water_mark_in_ms
;
if
(
hwm_in_ms
>
0
)
{
int
cached_duration_in_ms
=
INT_MAX
;
int64_t
audio_cached_duration
=
INT_MAX
;
int64_t
video_cached_duration
=
INT_MAX
;
int
cached_duration_in_ms
=
-
1
;
int64_t
audio_cached_duration
=
-
1
;
int64_t
video_cached_duration
=
-
1
;
if
(
is
->
audio_st
&&
is
->
audio_st
->
time_base
.
den
>
0
&&
is
->
audio_st
->
time_base
.
num
>
0
)
audio_cached_duration
=
is
->
audioq
.
duration
*
av_q2d
(
is
->
audio_st
->
time_base
)
*
1000
;
...
...
@@ -2226,11 +2225,18 @@ static int read_thread(void *arg)
if
(
is
->
video_st
&&
is
->
video_st
->
time_base
.
den
>
0
&&
is
->
video_st
->
time_base
.
num
>
0
)
video_cached_duration
=
is
->
videoq
.
duration
*
av_q2d
(
is
->
video_st
->
time_base
)
*
1000
;
cached_duration_in_ms
=
IJKMIN
(
video_cached_duration
,
audio_cached_duration
);
if
(
cached_duration_in_ms
<
INT_MAX
)
{
if
(
video_cached_duration
>=
0
&&
audio_cached_duration
>=
0
)
{
cached_duration_in_ms
=
IJKMAX
(
video_cached_duration
,
audio_cached_duration
);
}
else
if
(
video_cached_duration
>=
0
)
{
cached_duration_in_ms
=
video_cached_duration
;
}
else
if
(
audio_cached_duration
>=
0
)
{
cached_duration_in_ms
=
audio_cached_duration
;
}
if
(
cached_duration_in_ms
>=
0
)
{
buf_time_percent
=
av_rescale
(
cached_duration_in_ms
,
1005
,
hwm_in_ms
*
10
);
if
(
last_buffered_time_percentage
!=
buf_time_percent
)
{
//
ALOGE("time cache=%%%d (%d/%d)\n", buf_time_percent, cached_duration_in_ms, hwm_in_ms);
ALOGE
(
"time cache=%%%d (%d/%d)
\n
"
,
buf_time_percent
,
cached_duration_in_ms
,
hwm_in_ms
);
last_buffered_time_percentage
=
buf_time_percent
;
ffp_notify_msg3
(
ffp
,
FFP_MSG_BUFFERING_TIME_UPDATE
,
cached_duration_in_ms
,
hwm_in_ms
);
}
...
...
@@ -2241,15 +2247,20 @@ static int read_thread(void *arg)
if
(
hwm_in_bytes
>
0
)
{
buf_size_percent
=
av_rescale
(
cached_size
,
1005
,
hwm_in_bytes
*
10
);
if
(
last_buffered_size_percentage
!=
buf_size_percent
)
{
// ALOGE("size cache=%%%d (%d/%d)\n",
buf_size_percent, cached_size, hwm_in_bytes);
ALOGE
(
"size cache=%%%d (%d/%d)
\n
"
,
buf_size_percent
,
cached_size
,
hwm_in_bytes
);
last_buffered_size_percentage
=
buf_size_percent
;
ffp_notify_msg3
(
ffp
,
FFP_MSG_BUFFERING_TIME_UPDATE
,
cached_size
,
hwm_in_bytes
);
}
}
buf_percent
=
IJKMIN
(
buf_size_percent
,
buf_time_percent
);
if
(
buf_percent
>=
100
)
ffp_toggle_buffering
(
ffp
,
0
);
if
(
buf_time_percent
>=
0
)
{
// alwas depend on cache duration if valid
if
(
buf_time_percent
>=
100
)
ffp_toggle_buffering
(
ffp
,
0
);
}
else
{
if
(
buf_size_percent
>=
100
)
ffp_toggle_buffering
(
ffp
,
0
);
}
}
while
(
0
);
// FIXME: 0 notify progress
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录