[FFmpeg-devel] [PATCH] lavfi/drawbox: implement color=invert mode
Clément Bœsch
ubitux at gmail.com
Tue Oct 30 21:25:47 CET 2012
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?
> @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
> + 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
--
Clément B.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 490 bytes
Desc: not available
URL: <http://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20121030/eaf35bf8/attachment.asc>
More information about the ffmpeg-devel
mailing list