[FFmpeg-cvslog] lavfi/drawbox: extend syntax, accept named options
Stefano Sabatini
git at videolan.org
Tue Oct 30 23:42:12 CET 2012
ffmpeg | branch: master | Stefano Sabatini <stefasab at gmail.com> | Tue Oct 30 19:42:40 2012 +0100| [2ed7e6cce56e1c2df2648095879bd7de3cff7dc9] | committer: Stefano Sabatini
lavfi/drawbox: extend syntax, accept named options
> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=2ed7e6cce56e1c2df2648095879bd7de3cff7dc9
---
doc/filters.texi | 17 +++++++++++------
libavfilter/version.h | 2 +-
libavfilter/vf_drawbox.c | 41 ++++++++++++++++++++++++++++++++++-------
3 files changed, 46 insertions(+), 14 deletions(-)
diff --git a/doc/filters.texi b/doc/filters.texi
index 968c24b..07ae1c9 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.
@@ -1740,11 +1739,17 @@ Specify the top left corner coordinates of the box. Default to 0.
Specify the width and height of the box, if 0 they are interpreted as
the input width and height. Default to 0.
- at item color
+ at item color, c
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/version.h b/libavfilter/version.h
index 849674d..199c9bb 100644
--- a/libavfilter/version.h
+++ b/libavfilter/version.h
@@ -30,7 +30,7 @@
#define LIBAVFILTER_VERSION_MAJOR 3
#define LIBAVFILTER_VERSION_MINOR 20
-#define LIBAVFILTER_VERSION_MICRO 112
+#define LIBAVFILTER_VERSION_MICRO 113
#define LIBAVFILTER_VERSION_INT AV_VERSION_INT(LIBAVFILTER_VERSION_MAJOR, \
LIBAVFILTER_VERSION_MINOR, \
diff --git a/libavfilter/vf_drawbox.c b/libavfilter/vf_drawbox.c
index 8e2b48e..a93620f 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,42 @@
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 },
+ { "c", "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 +83,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 +177,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,
};
More information about the ffmpeg-cvslog
mailing list