avfilter/af_dynaudnorm: process also short durations
This commit is contained in:
@@ -824,19 +824,13 @@ static int flush(AVFilterLink *outlink)
|
|||||||
AVFilterContext *ctx = outlink->src;
|
AVFilterContext *ctx = outlink->src;
|
||||||
AVFilterLink *inlink = ctx->inputs[0];
|
AVFilterLink *inlink = ctx->inputs[0];
|
||||||
DynamicAudioNormalizerContext *s = ctx->priv;
|
DynamicAudioNormalizerContext *s = ctx->priv;
|
||||||
int ret = 0;
|
|
||||||
|
|
||||||
if (!cqueue_empty(s->gain_history_smoothed[0])) {
|
while (s->eof && cqueue_empty(s->gain_history_smoothed[0])) {
|
||||||
ret = flush_buffer(s, inlink, outlink);
|
for (int c = 0; c < s->channels; c++)
|
||||||
} else if (s->queue.available) {
|
update_gain_history(s, c, (local_gain){ cqueue_peek(s->gain_history_original[c], 0), 1.0});
|
||||||
AVFrame *out = ff_bufqueue_get(&s->queue);
|
|
||||||
|
|
||||||
s->pts = out->pts + av_rescale_q(out->nb_samples, av_make_q(1, outlink->sample_rate),
|
|
||||||
outlink->time_base);
|
|
||||||
ret = ff_filter_frame(outlink, out);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return ret;
|
return flush_buffer(s, inlink, outlink);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int activate(AVFilterContext *ctx)
|
static int activate(AVFilterContext *ctx)
|
||||||
|
|||||||
Reference in New Issue
Block a user