aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2019-10-06 15:44:20 +0200
committerPaul B Mahol <onemda@gmail.com>2019-10-06 15:46:06 +0200
commit66d45af13c043d2bb555cef462d73906761ea1ba (patch)
treeaef641d8fde2ea96e253dc22bd1aec1b0dbbb0d7
parentda9337c911c9cd68b1580e569138b9c79472db1f (diff)
downloadffmpeg-66d45af13c043d2bb555cef462d73906761ea1ba.tar.gz
avfilter/vf_avgblur: add support for commands
-rw-r--r--doc/filters.texi7
-rw-r--r--libavfilter/vf_avgblur.c17
2 files changed, 24 insertions, 0 deletions
diff --git a/doc/filters.texi b/doc/filters.texi
index 59bac58166..777dc3014c 100644
--- a/doc/filters.texi
+++ b/doc/filters.texi
@@ -6211,6 +6211,13 @@ Set vertical radius size, if zero it will be same as @code{sizeX}.
Default is @code{0}.
@end table
+@subsection Commands
+This filter supports same commands as options.
+The command accepts the same syntax of the corresponding option.
+
+If the specified expression is not valid, it is kept at its current
+value.
+
@section bbox
Compute the bounding box for the non-black pixels in the input frame
diff --git a/libavfilter/vf_avgblur.c b/libavfilter/vf_avgblur.c
index fdc9d39ce1..a1f6c9b80e 100644
--- a/libavfilter/vf_avgblur.c
+++ b/libavfilter/vf_avgblur.c
@@ -287,6 +287,22 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in)
return ff_filter_frame(outlink, out);
}
+static int process_command(AVFilterContext *ctx, const char *cmd, const char *args,
+ char *res, int res_len, int flags)
+{
+ AverageBlurContext *s = ctx->priv;
+ int ret = 0;
+
+ if ( !strcmp(cmd, "sizeX") || !strcmp(cmd, "sizeY")
+ || !strcmp(cmd, "planes")) {
+ av_opt_set(s, cmd, args, 0);
+ } else {
+ ret = AVERROR(ENOSYS);
+ }
+
+ return ret;
+}
+
static av_cold void uninit(AVFilterContext *ctx)
{
AverageBlurContext *s = ctx->priv;
@@ -322,4 +338,5 @@ AVFilter ff_vf_avgblur = {
.inputs = avgblur_inputs,
.outputs = avgblur_outputs,
.flags = AVFILTER_FLAG_SUPPORT_TIMELINE_GENERIC | AVFILTER_FLAG_SLICE_THREADS,
+ .process_command = process_command,
};