[FFmpeg-devel] [PATCH] avfilter/avf_showcqt: add bar_t option

Muhammad Faiz mfcc64 at gmail.com
Sat Oct 29 18:33:01 EEST 2016


On 10/28/16, Muhammad Faiz <mfcc64 at gmail.com> wrote:
> custom bargraph transparency
>
> Signed-off-by: Muhammad Faiz <mfcc64 at gmail.com>
> ---
>  doc/filters.texi          |  4 ++++
>  libavfilter/avf_showcqt.c | 14 +++++++++-----
>  libavfilter/avf_showcqt.h |  3 ++-
>  3 files changed, 15 insertions(+), 6 deletions(-)
>
> diff --git a/doc/filters.texi b/doc/filters.texi
> index c37fa29..fb04a56 100644
> --- a/doc/filters.texi
> +++ b/doc/filters.texi
> @@ -16835,6 +16835,10 @@ Acceptable range is @code{[1, 7]}.
>  Specify the bargraph gamma. Default value is @code{1}. Acceptable range is
>  @code{[1, 7]}.
>
> + at item bar_t
> +Specify the bargraph transparency level. Lower value makes the bargraph
> sharper.
> +Default value is @code{1}. Acceptable range is @code{[0, 1]}.
> +
>  @item timeclamp, tc
>  Specify the transform timeclamp. At low frequency, there is trade-off
> between
>  accuracy in time domain and frequency domain. If timeclamp is lower,
> diff --git a/libavfilter/avf_showcqt.c b/libavfilter/avf_showcqt.c
> index 49b950c..a25176d 100644
> --- a/libavfilter/avf_showcqt.c
> +++ b/libavfilter/avf_showcqt.c
> @@ -75,6 +75,7 @@ static const AVOption showcqt_options[] = {
>      { "gamma",    "set sonogram gamma", OFFSET(sono_g),
> AV_OPT_TYPE_FLOAT, { .dbl = 3.0 },            1.0, 7.0,      FLAGS },
>      { "bar_g",    "set bargraph gamma", OFFSET(bar_g),
> AV_OPT_TYPE_FLOAT, { .dbl = 1.0 },            1.0, 7.0,      FLAGS },
>      { "gamma2",   "set bargraph gamma", OFFSET(bar_g),
> AV_OPT_TYPE_FLOAT, { .dbl = 1.0 },            1.0, 7.0,      FLAGS },
> +    { "bar_t",  "set bar transparency", OFFSET(bar_t),
> AV_OPT_TYPE_FLOAT, { .dbl = 1.0 },            0.0, 1.0,      FLAGS },
>      { "timeclamp",     "set timeclamp", OFFSET(timeclamp),
> AV_OPT_TYPE_DOUBLE, { .dbl = 0.17 },           0.1, 1.0,      FLAGS },
>      { "tc",            "set timeclamp", OFFSET(timeclamp),
> AV_OPT_TYPE_DOUBLE, { .dbl = 0.17 },           0.1, 1.0,      FLAGS },
>      { "basefreq", "set base frequency", OFFSET(basefreq),
> AV_OPT_TYPE_DOUBLE, { .dbl = BASEFREQ },      10.0, 100000.0, FLAGS },
> @@ -752,10 +753,10 @@ static void yuv_from_cqt(ColorFloat *c, const
> FFTComplex *v, float gamma, int le
>  }
>
>  static void draw_bar_rgb(AVFrame *out, const float *h, const float *rcp_h,
> -                         const ColorFloat *c, int bar_h)
> +                         const ColorFloat *c, int bar_h, float bar_t)
>  {
>      int x, y, w = out->width;
> -    float mul, ht, rcp_bar_h = 1.0f / bar_h;
> +    float mul, ht, rcp_bar_h = 1.0f / bar_h, rcp_bar_t = 1.0f / bar_t;
>      uint8_t *v = out->data[0], *lp;
>      int ls = out->linesize[0];
>
> @@ -769,6 +770,7 @@ static void draw_bar_rgb(AVFrame *out, const float *h,
> const float *rcp_h,
>                  *lp++ = 0;
>              } else {
>                  mul = (h[x] - ht) * rcp_h[x];
> +                mul = (mul < bar_t) ? (mul * rcp_bar_t) : 1.0f;
>                  *lp++ = lrintf(mul * c[x].rgb.r);
>                  *lp++ = lrintf(mul * c[x].rgb.g);
>                  *lp++ = lrintf(mul * c[x].rgb.b);
> @@ -785,6 +787,7 @@ do { \
>          *lpv++ = 128; \
>      } else { \
>          mul = (h[x] - ht) * rcp_h[x]; \
> +        mul = (mul < bar_t) ? (mul * rcp_bar_t) : 1.0f; \
>          *lpy++ = lrintf(mul * c[x].yuv.y + 16.0f); \
>          *lpu++ = lrintf(mul * c[x].yuv.u + 128.0f); \
>          *lpv++ = lrintf(mul * c[x].yuv.v + 128.0f); \
> @@ -797,15 +800,16 @@ do { \
>          *lpy++ = 16; \
>      } else { \
>          mul = (h[x] - ht) * rcp_h[x]; \
> +        mul = (mul < bar_t) ? (mul * rcp_bar_t) : 1.0f; \
>          *lpy++ = lrintf(mul * c[x].yuv.y + 16.0f); \
>      } \
>  } while (0)
>
>  static void draw_bar_yuv(AVFrame *out, const float *h, const float *rcp_h,
> -                         const ColorFloat *c, int bar_h)
> +                         const ColorFloat *c, int bar_h, float bar_t)
>  {
>      int x, y, yh, w = out->width;
> -    float mul, ht, rcp_bar_h = 1.0f / bar_h;
> +    float mul, ht, rcp_bar_h = 1.0f / bar_h, rcp_bar_t = 1.0f / bar_t;
>      uint8_t *vy = out->data[0], *vu = out->data[1], *vv = out->data[2];
>      uint8_t *lpy, *lpu, *lpv;
>      int lsy = out->linesize[0], lsu = out->linesize[1], lsv =
> out->linesize[2];
> @@ -1160,7 +1164,7 @@ static int plot_cqt(AVFilterContext *ctx, AVFrame
> **frameout)
>          UPDATE_TIME(s->alloc_time);
>
>          if (s->bar_h) {
> -            s->draw_bar(out, s->h_buf, s->rcp_h_buf, s->c_buf, s->bar_h);
> +            s->draw_bar(out, s->h_buf, s->rcp_h_buf, s->c_buf, s->bar_h,
> s->bar_t);
>              UPDATE_TIME(s->bar_time);
>          }
>
> diff --git a/libavfilter/avf_showcqt.h b/libavfilter/avf_showcqt.h
> index 165d36e..3fa36f8 100644
> --- a/libavfilter/avf_showcqt.h
> +++ b/libavfilter/avf_showcqt.h
> @@ -78,7 +78,7 @@ typedef struct {
>                                      int len, int fft_len);
>      void                (*permute_coeffs)(float *v, int len);
>      void                (*draw_bar)(AVFrame *out, const float *h, const
> float *rcp_h,
> -                                    const ColorFloat *c, int bar_h);
> +                                    const ColorFloat *c, int bar_h, float
> bar_t);
>      void                (*draw_axis)(AVFrame *out, AVFrame *axis, const
> ColorFloat *c, int off);
>      void                (*draw_sono)(AVFrame *out, AVFrame *sono, int off,
> int idx);
>      void                (*update_sono)(AVFrame *sono, const ColorFloat *c,
> int idx);
> @@ -102,6 +102,7 @@ typedef struct {
>      char                *bar_v;
>      float               sono_g;
>      float               bar_g;
> +    float               bar_t;
>      double              timeclamp;
>      double              basefreq;
>      double              endfreq;
> --
> 2.5.0
>
>

applied

thanks


More information about the ffmpeg-devel mailing list