[FFmpeg-devel] [PATCH] lavfi/drawbox: extend syntax, accept named options
Stefano Sabatini
stefasab at gmail.com
Tue Oct 30 19:46:25 CET 2012
TODO: bump micro
---
doc/filters.texi | 15 ++++++++++-----
libavfilter/vf_drawbox.c | 40 +++++++++++++++++++++++++++++++++-------
2 files changed, 43 insertions(+), 12 deletions(-)
diff --git a/doc/filters.texi b/doc/filters.texi
index 2dd2526..46245d5 100644
--- a/doc/filters.texi
+++ b/doc/filters.texi
@@ -1726,13 +1726,12 @@ specified file.
Draw a colored box on the input image.
-It accepts the syntax:
- at example
-drawbox=@var{x}:@var{y}:@var{width}:@var{height}:@var{color}
- at end example
+The filter accepts parameters as a list of @var{key}=@var{value} pairs,
+separated by ":".
- at table @option
+The description of the accepted parameters follows.
+ at table @option
@item x, y
Specify the top left corner coordinates of the box. Default to 0.
@@ -1745,6 +1744,12 @@ Specify the color of the box to write, it can be the name of a color
(case insensitive match) or a 0xRRGGBB[AA] sequence.
@end table
+If the key of the first options is omitted, the arguments are
+interpreted accorinding to the following syntax:
+ at example
+drawbox=@var{x}:@var{y}:@var{width}:@var{height}:@var{color}
+ at end example
+
Follow some examples:
@example
# draw a black box around the edge of the input image
diff --git a/libavfilter/vf_drawbox.c b/libavfilter/vf_drawbox.c
index 8e2b48e..be55d54 100644
--- a/libavfilter/vf_drawbox.c
+++ b/libavfilter/vf_drawbox.c
@@ -26,6 +26,7 @@
#include "libavutil/colorspace.h"
#include "libavutil/common.h"
+#include "libavutil/opt.h"
#include "libavutil/pixdesc.h"
#include "libavutil/parseutils.h"
#include "avfilter.h"
@@ -36,24 +37,41 @@
enum { Y, U, V, A };
typedef struct {
+ const AVClass *class;
int x, y, w, h;
+ char *color_str;
unsigned char yuv_color[4];
int vsub, hsub; ///< chroma subsampling
} DrawBoxContext;
+#define OFFSET(x) offsetof(DrawBoxContext, x)
+#define FLAGS AV_OPT_FLAG_VIDEO_PARAM|AV_OPT_FLAG_FILTERING_PARAM
+
+static const AVOption drawbox_options[] = {
+ { "x", "set the box top-left corner x position", OFFSET(x), AV_OPT_TYPE_INT, {.i64=0}, INT_MIN, INT_MAX, FLAGS },
+ { "y", "set the box top-left corner y position", OFFSET(y), AV_OPT_TYPE_INT, {.i64=0}, INT_MIN, INT_MAX, FLAGS },
+ { "w", "set the box width", OFFSET(w), AV_OPT_TYPE_INT, {.i64=0}, 0, INT_MAX, FLAGS },
+ { "h", "set the box heigth", OFFSET(h), AV_OPT_TYPE_INT, {.i64=0}, 0, INT_MAX, FLAGS },
+ { "color", "set the box edge color", OFFSET(color_str), AV_OPT_TYPE_STRING, {.str = "black" }, CHAR_MIN, CHAR_MAX, FLAGS },
+ {NULL},
+};
+
+AVFILTER_DEFINE_CLASS(drawbox);
+
static av_cold int init(AVFilterContext *ctx, const char *args)
{
- DrawBoxContext *drawbox= ctx->priv;
- char color_str[1024] = "black";
+ DrawBoxContext *drawbox = ctx->priv;
uint8_t rgba_color[4];
+ static const char *shorthand[] = { "x", "y", "w", "h", "color", NULL };
+ int ret;
- drawbox->x = drawbox->y = drawbox->w = drawbox->h = 0;
+ drawbox->class = &drawbox_class;
+ av_opt_set_defaults(drawbox);
- if (args)
- sscanf(args, "%d:%d:%d:%d:%s",
- &drawbox->x, &drawbox->y, &drawbox->w, &drawbox->h, color_str);
+ if ((ret = av_opt_set_from_string(drawbox, args, shorthand, "=", ":")) < 0)
+ return ret;
- if (av_parse_color(rgba_color, color_str, -1, ctx) < 0)
+ 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]);
@@ -64,6 +82,12 @@ static av_cold int init(AVFilterContext *ctx, const char *args)
return 0;
}
+static av_cold void uninit(AVFilterContext *ctx)
+{
+ DrawBoxContext *drawbox = ctx->priv;
+ av_opt_free(drawbox);
+}
+
static int query_formats(AVFilterContext *ctx)
{
enum AVPixelFormat pix_fmts[] = {
@@ -152,8 +176,10 @@ AVFilter avfilter_vf_drawbox = {
.description = NULL_IF_CONFIG_SMALL("Draw a colored box on the input video."),
.priv_size = sizeof(DrawBoxContext),
.init = init,
+ .uninit = uninit,
.query_formats = query_formats,
.inputs = avfilter_vf_drawbox_inputs,
.outputs = avfilter_vf_drawbox_outputs,
+ .priv_class = &drawbox_class,
};
--
1.7.5.4
More information about the ffmpeg-devel
mailing list