[FFmpeg-devel] [PATCH] lavfi/drawbox: implement color=invert mode
Stefano Sabatini
stefasab at gmail.com
Wed Oct 31 12:17:38 CET 2012
On date Tuesday 2012-10-30 21:25:47 +0100, Clément Bœsch encoded:
> On Tue, Oct 30, 2012 at 08:14:46PM +0100, Stefano Sabatini wrote:
> > Based on libmpcodecs/vf_rectangle.c feature.
> > ---
> > doc/filters.texi | 4 +++-
> > libavfilter/vf_drawbox.c | 12 +++++++++++-
> > 2 files changed, 14 insertions(+), 2 deletions(-)
> >
> > diff --git a/doc/filters.texi b/doc/filters.texi
> > index 73d007a..29548ae 100644
> > --- a/doc/filters.texi
> > +++ b/doc/filters.texi
> > @@ -1741,7 +1741,9 @@ the input width and height. Default to 0.
> >
> > @item color
> > Specify the color of the box to write, it can be the name of a color
> > -(case insensitive match) or a 0xRRGGBB[AA] sequence.
> > +(case insensitive match) or a 0xRRGGBB[AA] sequence. If the special
> > +value @code{invert} is used, the box edge color is the same as the
> > +video with inverted luma.
>
> Any reason to just set this mode by default (since it helps visibility
> most of the time) unless the user explicits a color?
To not break backward compatibility.
>
> > @end table
> >
> > If the key of the first options is omitted, the arguments are
> > diff --git a/libavfilter/vf_drawbox.c b/libavfilter/vf_drawbox.c
> > index be55d54..f3dd141 100644
> > --- a/libavfilter/vf_drawbox.c
> > +++ b/libavfilter/vf_drawbox.c
> > @@ -41,6 +41,7 @@ typedef struct {
> > int x, y, w, h;
> > char *color_str;
> > unsigned char yuv_color[4];
> > + int invert_color; ///< invert luma color
> > int vsub, hsub; ///< chroma subsampling
> > } DrawBoxContext;
> >
> > @@ -71,7 +72,9 @@ static av_cold int init(AVFilterContext *ctx, const char *args)
> > if ((ret = av_opt_set_from_string(drawbox, args, shorthand, "=", ":")) < 0)
> > return ret;
> >
> > - if (av_parse_color(rgba_color, drawbox->color_str, -1, ctx) < 0)
> > + if (!strcmp(drawbox->color_str, "invert"))
> > + drawbox->invert_color = 1;
> > + else if (av_parse_color(rgba_color, drawbox->color_str, -1, ctx) < 0)
> > return AVERROR(EINVAL);
> >
> > drawbox->yuv_color[Y] = RGB_TO_Y_CCIR(rgba_color[0], rgba_color[1], rgba_color[2]);
> > @@ -134,6 +137,12 @@ static int draw_slice(AVFilterLink *inlink, int y0, int h, int slice_dir)
> > row[plane] = picref->data[plane] +
> > picref->linesize[plane] * (y >> drawbox->vsub);
> >
> > + if (drawbox->invert_color) {
> > + for (x = FFMAX(xb, 0); x < (xb + drawbox->w) && x < picref->video->w; x++)
>
> () look pointless
Will fix in a later commit.
> > + if ((y - yb < 3) || (yb + drawbox->h - y < 4) ||
> > + (x - xb < 3) || (xb + drawbox->w - x < 4))
> > + row[0][x] = 0xff - row[0][x];
> > + } else {
> > for (x = FFMAX(xb, 0); x < (xb + drawbox->w) && x < picref->video->w; x++) {
> > double alpha = (double)drawbox->yuv_color[A] / 255;
> >
> > @@ -144,6 +153,7 @@ static int draw_slice(AVFilterLink *inlink, int y0, int h, int slice_dir)
> > row[2][x >> drawbox->hsub] = (1 - alpha) * row[2][x >> drawbox->hsub] + alpha * drawbox->yuv_color[V];
> > }
> > }
> > + }
> > }
> >
> > return ff_draw_slice(inlink->dst->outputs[0], y0, h, 1);
>
> LGTM otherwise
Applied.
--
FFmpeg = Furious and Frenzy Mega Puritan Exxagerate Gargoyle
More information about the ffmpeg-devel
mailing list