Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
小白菜888
Ffmpeg
提交
a5b2d85f
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,发现更多精彩内容 >>
提交
a5b2d85f
编写于
4月 29, 2018
作者:
P
Paul B Mahol
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
avfilter/vf_fieldmatch: switch to activate
Unbreaks ppsrc filtering. Signed-off-by:
N
Paul B Mahol
<
onemda@gmail.com
>
上级
889d8584
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
46 addition
and
27 deletion
+46
-27
libavfilter/vf_fieldmatch.c
libavfilter/vf_fieldmatch.c
+46
-27
未找到文件。
libavfilter/vf_fieldmatch.c
浏览文件 @
a5b2d85f
...
...
@@ -37,6 +37,7 @@
#include "libavutil/opt.h"
#include "libavutil/timestamp.h"
#include "avfilter.h"
#include "filters.h"
#include "internal.h"
#define INPUT_MAIN 0
...
...
@@ -697,9 +698,11 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
av_assert0(prv && src && nxt); \
} while (0)
if
(
FF_INLINK_IDX
(
inlink
)
==
INPUT_MAIN
)
{
av_assert0
(
fm
->
got_frame
[
INPUT_MAIN
]
==
0
);
SLIDING_FRAME_WINDOW
(
fm
->
prv
,
fm
->
src
,
fm
->
nxt
);
fm
->
got_frame
[
INPUT_MAIN
]
=
1
;
}
else
{
av_assert0
(
fm
->
got_frame
[
INPUT_CLEANSRC
]
==
0
);
SLIDING_FRAME_WINDOW
(
fm
->
prv2
,
fm
->
src2
,
fm
->
nxt2
);
fm
->
got_frame
[
INPUT_CLEANSRC
]
=
1
;
}
...
...
@@ -818,36 +821,53 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
return
ff_filter_frame
(
outlink
,
dst
);
}
static
int
request_inlink
(
AVFilterContext
*
ctx
,
int
lid
)
static
int
activate
(
AVFilterContext
*
ctx
)
{
int
ret
=
0
;
FieldMatchContext
*
fm
=
ctx
->
priv
;
if
(
!
fm
->
got_frame
[
lid
])
{
AVFilterLink
*
inlink
=
ctx
->
inputs
[
lid
];
ret
=
ff_request_frame
(
inlink
);
if
(
ret
==
AVERROR_EOF
)
{
// flushing
fm
->
eof
|=
1
<<
lid
;
ret
=
filter_frame
(
inlink
,
NULL
);
}
AVFrame
*
frame
=
NULL
;
int
ret
=
0
,
status
;
int64_t
pts
;
if
((
fm
->
got_frame
[
INPUT_MAIN
]
==
0
)
&&
(
ret
=
ff_inlink_consume_frame
(
ctx
->
inputs
[
INPUT_MAIN
],
&
frame
))
>
0
)
{
ret
=
filter_frame
(
ctx
->
inputs
[
INPUT_MAIN
],
frame
);
if
(
ret
<
0
)
return
ret
;
}
return
ret
;
}
static
int
request_frame
(
AVFilterLink
*
outlink
)
{
int
ret
;
AVFilterContext
*
ctx
=
outlink
->
src
;
FieldMatchContext
*
fm
=
ctx
->
priv
;
const
uint32_t
eof_mask
=
1
<<
INPUT_MAIN
|
fm
->
ppsrc
<<
INPUT_CLEANSRC
;
if
((
fm
->
eof
&
eof_mask
)
==
eof_mask
)
// flush done?
return
AVERROR_EOF
;
if
((
ret
=
request_inlink
(
ctx
,
INPUT_MAIN
))
<
0
)
if
(
ret
<
0
)
return
ret
;
if
(
fm
->
ppsrc
&&
(
ret
=
request_inlink
(
ctx
,
INPUT_CLEANSRC
))
<
0
)
if
(
fm
->
ppsrc
&&
(
fm
->
got_frame
[
INPUT_CLEANSRC
]
==
0
)
&&
(
ret
=
ff_inlink_consume_frame
(
ctx
->
inputs
[
INPUT_CLEANSRC
],
&
frame
))
>
0
)
{
ret
=
filter_frame
(
ctx
->
inputs
[
INPUT_CLEANSRC
],
frame
);
if
(
ret
<
0
)
return
ret
;
}
if
(
ret
<
0
)
{
return
ret
;
return
0
;
}
else
if
(
ff_inlink_acknowledge_status
(
ctx
->
inputs
[
INPUT_MAIN
],
&
status
,
&
pts
))
{
if
(
status
==
AVERROR_EOF
)
{
// flushing
fm
->
eof
|=
1
<<
INPUT_MAIN
;
ret
=
filter_frame
(
ctx
->
inputs
[
INPUT_MAIN
],
NULL
);
}
ff_outlink_set_status
(
ctx
->
outputs
[
0
],
status
,
pts
);
return
ret
;
}
else
if
(
fm
->
ppsrc
&&
ff_inlink_acknowledge_status
(
ctx
->
inputs
[
INPUT_CLEANSRC
],
&
status
,
&
pts
))
{
if
(
status
==
AVERROR_EOF
)
{
// flushing
fm
->
eof
|=
1
<<
INPUT_CLEANSRC
;
ret
=
filter_frame
(
ctx
->
inputs
[
INPUT_CLEANSRC
],
NULL
);
}
ff_outlink_set_status
(
ctx
->
outputs
[
0
],
status
,
pts
);
return
ret
;
}
else
{
if
(
ff_outlink_frame_wanted
(
ctx
->
outputs
[
0
]))
{
if
(
fm
->
got_frame
[
INPUT_MAIN
]
==
0
)
ff_inlink_request_frame
(
ctx
->
inputs
[
INPUT_MAIN
]);
if
(
fm
->
ppsrc
&&
(
fm
->
got_frame
[
INPUT_CLEANSRC
]
==
0
))
ff_inlink_request_frame
(
ctx
->
inputs
[
INPUT_CLEANSRC
]);
}
return
0
;
}
}
static
int
query_formats
(
AVFilterContext
*
ctx
)
...
...
@@ -901,7 +921,6 @@ static av_cold int fieldmatch_init(AVFilterContext *ctx)
AVFilterPad
pad
=
{
.
name
=
av_strdup
(
"main"
),
.
type
=
AVMEDIA_TYPE_VIDEO
,
.
filter_frame
=
filter_frame
,
.
config_props
=
config_input
,
};
int
ret
;
...
...
@@ -975,7 +994,6 @@ static const AVFilterPad fieldmatch_outputs[] = {
{
.
name
=
"default"
,
.
type
=
AVMEDIA_TYPE_VIDEO
,
.
request_frame
=
request_frame
,
.
config_props
=
config_output
,
},
{
NULL
}
...
...
@@ -987,6 +1005,7 @@ AVFilter ff_vf_fieldmatch = {
.
query_formats
=
query_formats
,
.
priv_size
=
sizeof
(
FieldMatchContext
),
.
init
=
fieldmatch_init
,
.
activate
=
activate
,
.
uninit
=
fieldmatch_uninit
,
.
inputs
=
NULL
,
.
outputs
=
fieldmatch_outputs
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录