aboutsummaryrefslogtreecommitdiffstats
path: root/libavfilter/avf_showwaves.c
diff options
context:
space:
mode:
authorPaul B Mahol <onemda@gmail.com>2019-04-21 21:06:25 +0200
committerPaul B Mahol <onemda@gmail.com>2019-04-21 21:12:03 +0200
commitdafcdeb258235b65b212f52f63cf23d19bd8af0f (patch)
tree2eba27e749f19e4ff7a65e6a9ec6a53ca9ac6bc6 /libavfilter/avf_showwaves.c
parent833ae5f4bfdc73f7b3a4852469b6a62979e3d203 (diff)
downloadffmpeg-dafcdeb258235b65b212f52f63cf23d19bd8af0f.tar.gz
lavfi/avf_showwaves: fix extra gaps at end of waveform
Fixes #5931.
Diffstat (limited to 'libavfilter/avf_showwaves.c')
-rw-r--r--libavfilter/avf_showwaves.c12
1 files changed, 8 insertions, 4 deletions
diff --git a/libavfilter/avf_showwaves.c b/libavfilter/avf_showwaves.c
index bb7f4ea87e..0e683cf42d 100644
--- a/libavfilter/avf_showwaves.c
+++ b/libavfilter/avf_showwaves.c
@@ -559,7 +559,9 @@ static int push_single_pic(AVFilterLink *outlink)
AVFilterContext *ctx = outlink->src;
AVFilterLink *inlink = ctx->inputs[0];
ShowWavesContext *showwaves = ctx->priv;
- int64_t n = 0, max_samples = showwaves->total_samples / outlink->w;
+ int64_t n = 0, column_max_samples = showwaves->total_samples / outlink->w;
+ int64_t remaining_samples = showwaves->total_samples - (column_max_samples * outlink->w);
+ int64_t last_column_samples = column_max_samples + remaining_samples;
AVFrame *out = showwaves->outpicref;
struct frame_node *node;
const int nb_channels = inlink->channels;
@@ -569,12 +571,12 @@ static int push_single_pic(AVFilterLink *outlink)
int col = 0;
int64_t *sum = showwaves->sum;
- if (max_samples == 0) {
+ if (column_max_samples == 0) {
av_log(ctx, AV_LOG_ERROR, "Too few samples\n");
return AVERROR(EINVAL);
}
- av_log(ctx, AV_LOG_DEBUG, "Create frame averaging %"PRId64" samples per column\n", max_samples);
+ av_log(ctx, AV_LOG_DEBUG, "Create frame averaging %"PRId64" samples per column\n", column_max_samples);
memset(sum, 0, nb_channels);
@@ -584,11 +586,13 @@ static int push_single_pic(AVFilterLink *outlink)
const int16_t *p = (const int16_t *)frame->data[0];
for (i = 0; i < frame->nb_samples; i++) {
+ int64_t max_samples = col == outlink->w - 1 ? last_column_samples: column_max_samples;
int ch;
for (ch = 0; ch < nb_channels; ch++)
sum[ch] += abs(p[ch + i*nb_channels]) << 1;
- if (n++ == max_samples) {
+ n++;
+ if (n == max_samples) {
for (ch = 0; ch < nb_channels; ch++) {
int16_t sample = sum[ch] / max_samples;
uint8_t *buf = out->data[0] + col * pixstep;