diff options
author | Michael Niedermayer <michaelni@gmx.at> | 2013-04-10 20:48:46 +0200 |
---|---|---|
committer | Michael Niedermayer <michaelni@gmx.at> | 2013-04-10 21:09:06 +0200 |
commit | 1ee9eacaa492a0f38ae426439516574f4bfae4d9 (patch) | |
tree | 4e47716bd0c35e7c455516727cc3c76b9256a917 | |
parent | 85f115b5d8d7d8f39d9a2934242b108f5b7c891e (diff) | |
parent | 7ed833d78ea661d619124fd898547a900f6480bc (diff) | |
download | ffmpeg-1ee9eacaa492a0f38ae426439516574f4bfae4d9.tar.gz |
Merge commit '7ed833d78ea661d619124fd898547a900f6480bc'
* commit '7ed833d78ea661d619124fd898547a900f6480bc':
vf_gradfun: switch to an AVOptions-based system.
Conflicts:
doc/filters.texi
libavfilter/gradfun.h
libavfilter/vf_gradfun.c
Merged-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r-- | doc/filters.texi | 19 | ||||
-rw-r--r-- | libavfilter/avfilter.c | 1 | ||||
-rw-r--r-- | libavfilter/gradfun.h | 2 | ||||
-rw-r--r-- | libavfilter/vf_gradfun.c | 32 |
4 files changed, 26 insertions, 28 deletions
diff --git a/doc/filters.texi b/doc/filters.texi index 0ac643681a..4e8fed5120 100644 --- a/doc/filters.texi +++ b/doc/filters.texi @@ -3412,22 +3412,21 @@ This filter is designed for playback only. Do not use it prior to lossy compression, because compression tends to lose the dither and bring back the bands. -The filter accepts a list of options in the form of @var{key}=@var{value} pairs -separated by ":". A description of the accepted options follows. +This filter accepts the following options: @table @option @item strength -The maximum amount by which the filter will change -any one pixel. Also the threshold for detecting nearly flat -regions. Acceptable values range from @code{0.51} to @code{64}, default value -is @code{1.2}. +The maximum amount by which the filter will change any one pixel. Also the +threshold for detecting nearly flat regions. Acceptable values range from .51 to +64, default value is 1.2, out-of-range values will be clipped to the valid +range. @item radius -The neighborhood to fit the gradient to. A larger -radius makes for smoother gradients, but also prevents the filter from -modifying the pixels near detailed regions. Acceptable values are -@code{8-32}, default value is @code{16}. +The neighborhood to fit the gradient to. A larger radius makes for smoother +gradients, but also prevents the filter from modifying the pixels near detailed +regions. Acceptable values are 8-32, default value is 16, out-of-range values +will be clipped to the valid range. @end table diff --git a/libavfilter/avfilter.c b/libavfilter/avfilter.c index 36d8a27e7b..5190ed7588 100644 --- a/libavfilter/avfilter.c +++ b/libavfilter/avfilter.c @@ -669,6 +669,7 @@ int avfilter_init_filter(AVFilterContext *filter, const char *args, void *opaque !strcmp(filter->filter->name, "fps" ) || !strcmp(filter->filter->name, "frei0r" ) || !strcmp(filter->filter->name, "frei0r_src") || + !strcmp(filter->filter->name, "gradfun" ) || !strcmp(filter->filter->name, "format") || !strcmp(filter->filter->name, "noformat") || !strcmp(filter->filter->name, "resample") || diff --git a/libavfilter/gradfun.h b/libavfilter/gradfun.h index 801ddddb96..7b1140fabf 100644 --- a/libavfilter/gradfun.h +++ b/libavfilter/gradfun.h @@ -27,7 +27,7 @@ /// Holds instance-specific information for gradfun. typedef struct GradFunContext { const AVClass *class; - double strength; ///< user specified strength, used to define thresh + float strength; int thresh; ///< threshold for gradient algorithm int radius; ///< blur radius int chroma_w; ///< width of the chroma planes diff --git a/libavfilter/vf_gradfun.c b/libavfilter/vf_gradfun.c index 9295365eae..b174673e2b 100644 --- a/libavfilter/vf_gradfun.c +++ b/libavfilter/vf_gradfun.c @@ -35,6 +35,7 @@ #include "libavutil/imgutils.h" #include "libavutil/common.h" #include "libavutil/cpu.h" +#include "libavutil/opt.h" #include "libavutil/pixdesc.h" #include "libavutil/opt.h" #include "avfilter.h" @@ -43,17 +44,6 @@ #include "internal.h" #include "video.h" -#define OFFSET(x) offsetof(GradFunContext, x) -#define F AV_OPT_FLAG_VIDEO_PARAM|AV_OPT_FLAG_FILTERING_PARAM - -static const AVOption gradfun_options[] = { - { "strength", "set the maximum amount by which the filter will change any one pixel", OFFSET(strength), AV_OPT_TYPE_DOUBLE, {.dbl = 1.2}, 0.51, 64, F }, - { "radius", "set the neighborhood to fit the gradient to", OFFSET(radius), AV_OPT_TYPE_INT, {.i64 = 16}, 4, 32, F }, - { NULL } -}; - -AVFILTER_DEFINE_CLASS(gradfun); - DECLARE_ALIGNED(16, static const uint16_t, dither)[8][8] = { {0x00,0x60,0x18,0x78,0x06,0x66,0x1E,0x7E}, {0x40,0x20,0x58,0x38,0x46,0x26,0x5E,0x3E}, @@ -135,8 +125,8 @@ static av_cold int init(AVFilterContext *ctx, const char *args) { GradFunContext *gf = ctx->priv; - gf->thresh = (1 << 15) / gf->strength; - gf->radius = av_clip((gf->radius + 1) & ~1, 4, 32); + gf->thresh = (1 << 15) / gf->strength; + gf->radius = av_clip((gf->radius + 1) & ~1, 4, 32); gf->blur_line = ff_gradfun_blur_line_c; gf->filter_line = ff_gradfun_filter_line_c; @@ -231,6 +221,17 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in) return ff_filter_frame(outlink, out); } +#define OFFSET(x) offsetof(GradFunContext, x) +#define FLAGS AV_OPT_FLAG_VIDEO_PARAM|AV_OPT_FLAG_FILTERING_PARAM + +static const AVOption gradfun_options[] = { + { "strength", "The maximum amount by which the filter will change any one pixel.", OFFSET(strength), AV_OPT_TYPE_FLOAT, { .dbl = 1.2 }, 0.51, 64, FLAGS }, + { "radius", "The neighborhood to fit the gradient to.", OFFSET(radius), AV_OPT_TYPE_INT, { .i64 = 16 }, 4, 32, FLAGS }, + { NULL }, +}; + +AVFILTER_DEFINE_CLASS(gradfun); + static const AVFilterPad avfilter_vf_gradfun_inputs[] = { { .name = "default", @@ -249,17 +250,14 @@ static const AVFilterPad avfilter_vf_gradfun_outputs[] = { { NULL } }; -static const char *const shorthand[] = { "strength", "radius", NULL }; - AVFilter avfilter_vf_gradfun = { .name = "gradfun", .description = NULL_IF_CONFIG_SMALL("Debands video quickly using gradients."), .priv_size = sizeof(GradFunContext), + .priv_class = &gradfun_class, .init = init, .uninit = uninit, .query_formats = query_formats, .inputs = avfilter_vf_gradfun_inputs, .outputs = avfilter_vf_gradfun_outputs, - .priv_class = &gradfun_class, - .shorthand = shorthand, }; |