[FFmpeg-devel] [PATCH] lavfi/drawtext: add support to expansion of generic expressions

Nicolas George nicolas.george at normalesup.org
Tue Nov 27 11:43:43 CET 2012


Le septidi 7 frimaire, an CCXXI, Stefano Sabatini a écrit :
> TODO: bump micro
> ---
>  doc/filters.texi          |    8 ++++++++
>  libavfilter/vf_drawtext.c |   24 ++++++++++++++++++++++++
>  2 files changed, 32 insertions(+)
> 
> diff --git a/doc/filters.texi b/doc/filters.texi
> index 99654eb..5c8bc6f 100644
> --- a/doc/filters.texi
> +++ b/doc/filters.texi
> @@ -2075,6 +2075,14 @@ The following functions are available:
>  
>  @table @command
>  
> + at item expr, e
> +The expression evaluation result.
> +It must take one argument specifying the expression to be evaluated,
> +which accepts the same constants and functions as the @var{x} and
> + at var{y} values. Note that not all constants should be used, for
> +example the text size is not known at this point, so the constants
> + at var{text_w} and @var{text_h} will have an undefined value.
> +
>  @item gmtime
>  The time at which the filter is running, expressed in UTC.
>  It can accept an argument: a strftime() format string.
> diff --git a/libavfilter/vf_drawtext.c b/libavfilter/vf_drawtext.c
> index 96512ab..cb23555 100644
> --- a/libavfilter/vf_drawtext.c
> +++ b/libavfilter/vf_drawtext.c
> @@ -167,6 +167,7 @@ typedef struct {
>      AVTimecode  tc;                 ///< timecode context
>      int tc24hmax;                   ///< 1 if timecode is wrapped to 24 hours, 0 otherwise
>      int frame_id;
> +    int expr_func_warning_done;
>  } DrawTextContext;
>  
>  #define OFFSET(x) offsetof(DrawTextContext, x)
> @@ -643,12 +644,35 @@ static int func_strftime(AVFilterContext *ctx, AVBPrint *bp,
>      return 0;
>  }
>  
> +static int func_eval_expr(AVFilterContext *ctx, AVBPrint *bp,
> +                          char *fct, unsigned argc, char **argv, int tag)
> +{
> +    DrawTextContext *dtext = ctx->priv;
> +    double res;
> +    int ret;
> +
> +    ret = av_expr_parse_and_eval(&res, argv[0], var_names, dtext->var_values,
> +                                 NULL, NULL, fun2_names, fun2,
> +                                 &dtext->prng, 0, ctx);
> +    if (ret < 0 && !dtext->expr_func_warning_done) {
> +        av_log(ctx, AV_LOG_WARNING,
> +               "Expression '%s' for the expr text expansion function is not valid\n",
> +               argv[0]);
> +        dtext->expr_func_warning_done = 1;

Any reason not just return an error? Most of the time, I rather dislike
programs that continue running when the user made a stupid typo that will
make their output useless.

> +    } else {
> +        av_bprintf(bp, "%f", res);
> +    }
> +    return ret;
> +}
> +
>  static const struct drawtext_function {
>      const char *name;
>      unsigned argc_min, argc_max;
>      int tag; /** opaque argument to func */
>      int (*func)(AVFilterContext *, AVBPrint *, char *, unsigned, char **, int);
>  } functions[] = {
> +    { "expr",      1, 1, 0,   func_eval_expr },
> +    { "e",         1, 1, 0,   func_eval_expr },
>      { "pts",       0, 0, 0,   func_pts      },
>      { "gmtime",    0, 1, 'G', func_strftime },
>      { "localtime", 0, 1, 'L', func_strftime },

Apart from the remark above, looks good, and a very good idea too, thanks.

Regards,

-- 
  Nicolas George
-------------- next part --------------
A non-text attachment was scrubbed...
Name: not available
Type: application/pgp-signature
Size: 198 bytes
Desc: Digital signature
URL: <http://ffmpeg.org/pipermail/ffmpeg-devel/attachments/20121127/3799874d/attachment.asc>


More information about the ffmpeg-devel mailing list