mirror of
				https://github.com/nyanmisaka/ffmpeg-rockchip.git
				synced 2025-10-22 16:40:18 +08:00 
			
		
		
		
	avfilter/af_stereotools: add support for commands
This commit is contained in:
		| @@ -5554,6 +5554,10 @@ Equal power distribution, from -6dB to +6dB range. | |||||||
| @end table | @end table | ||||||
| @end table | @end table | ||||||
|  |  | ||||||
|  | @subsection Commands | ||||||
|  |  | ||||||
|  | This filter supports the all above options as @ref{commands}. | ||||||
|  |  | ||||||
| @subsection Examples | @subsection Examples | ||||||
|  |  | ||||||
| @itemize | @itemize | ||||||
|   | |||||||
| @@ -57,7 +57,7 @@ typedef struct StereoToolsContext { | |||||||
| } StereoToolsContext; | } StereoToolsContext; | ||||||
|  |  | ||||||
| #define OFFSET(x) offsetof(StereoToolsContext, x) | #define OFFSET(x) offsetof(StereoToolsContext, x) | ||||||
| #define A AV_OPT_FLAG_AUDIO_PARAM|AV_OPT_FLAG_FILTERING_PARAM | #define A AV_OPT_FLAG_AUDIO_PARAM|AV_OPT_FLAG_FILTERING_PARAM|AV_OPT_FLAG_RUNTIME_PARAM | ||||||
|  |  | ||||||
| static const AVOption stereotools_options[] = { | static const AVOption stereotools_options[] = { | ||||||
|     { "level_in",    "set level in",     OFFSET(level_in),    AV_OPT_TYPE_DOUBLE, {.dbl=1},   0.015625,  64, A }, |     { "level_in",    "set level in",     OFFSET(level_in),    AV_OPT_TYPE_DOUBLE, {.dbl=1},   0.015625,  64, A }, | ||||||
| @@ -120,11 +120,8 @@ static int config_input(AVFilterLink *inlink) | |||||||
|     AVFilterContext *ctx = inlink->dst; |     AVFilterContext *ctx = inlink->dst; | ||||||
|     StereoToolsContext *s = ctx->priv; |     StereoToolsContext *s = ctx->priv; | ||||||
|  |  | ||||||
|     s->length = 2 * inlink->sample_rate * 0.05; |     s->length = FFALIGN(inlink->sample_rate / 10, 2); | ||||||
|     if (s->length <= 1 || s->length & 1) { |     if (!s->buffer) | ||||||
|         av_log(ctx, AV_LOG_ERROR, "sample rate is too small\n"); |  | ||||||
|         return AVERROR(EINVAL); |  | ||||||
|     } |  | ||||||
|         s->buffer = av_calloc(s->length, sizeof(*s->buffer)); |         s->buffer = av_calloc(s->length, sizeof(*s->buffer)); | ||||||
|     if (!s->buffer) |     if (!s->buffer) | ||||||
|         return AVERROR(ENOMEM); |         return AVERROR(ENOMEM); | ||||||
| @@ -341,6 +338,18 @@ static int filter_frame(AVFilterLink *inlink, AVFrame *in) | |||||||
|     return ff_filter_frame(outlink, out); |     return ff_filter_frame(outlink, out); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | static int process_command(AVFilterContext *ctx, const char *cmd, const char *args, | ||||||
|  |                            char *res, int res_len, int flags) | ||||||
|  | { | ||||||
|  |     int ret; | ||||||
|  |  | ||||||
|  |     ret = ff_filter_process_command(ctx, cmd, args, res, res_len, flags); | ||||||
|  |     if (ret < 0) | ||||||
|  |         return ret; | ||||||
|  |  | ||||||
|  |     return config_input(ctx->inputs[0]); | ||||||
|  | } | ||||||
|  |  | ||||||
| static av_cold void uninit(AVFilterContext *ctx) | static av_cold void uninit(AVFilterContext *ctx) | ||||||
| { | { | ||||||
|     StereoToolsContext *s = ctx->priv; |     StereoToolsContext *s = ctx->priv; | ||||||
| @@ -375,5 +384,6 @@ AVFilter ff_af_stereotools = { | |||||||
|     .uninit         = uninit, |     .uninit         = uninit, | ||||||
|     .inputs         = inputs, |     .inputs         = inputs, | ||||||
|     .outputs        = outputs, |     .outputs        = outputs, | ||||||
|  |     .process_command = process_command, | ||||||
|     .flags          = AVFILTER_FLAG_SUPPORT_TIMELINE_INTERNAL, |     .flags          = AVFILTER_FLAG_SUPPORT_TIMELINE_INTERNAL, | ||||||
| }; | }; | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user
	 Paul B Mahol
					Paul B Mahol