| @@ -559,7 +559,9 @@ static int push_single_pic(AVFilterLink *outlink) | |||||
| AVFilterContext *ctx = outlink->src; | AVFilterContext *ctx = outlink->src; | ||||
| AVFilterLink *inlink = ctx->inputs[0]; | AVFilterLink *inlink = ctx->inputs[0]; | ||||
| ShowWavesContext *showwaves = ctx->priv; | 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; | AVFrame *out = showwaves->outpicref; | ||||
| struct frame_node *node; | struct frame_node *node; | ||||
| const int nb_channels = inlink->channels; | const int nb_channels = inlink->channels; | ||||
| @@ -569,12 +571,12 @@ static int push_single_pic(AVFilterLink *outlink) | |||||
| int col = 0; | int col = 0; | ||||
| int64_t *sum = showwaves->sum; | int64_t *sum = showwaves->sum; | ||||
| if (max_samples == 0) { | |||||
| if (column_max_samples == 0) { | |||||
| av_log(ctx, AV_LOG_ERROR, "Too few samples\n"); | av_log(ctx, AV_LOG_ERROR, "Too few samples\n"); | ||||
| return AVERROR(EINVAL); | 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); | 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]; | const int16_t *p = (const int16_t *)frame->data[0]; | ||||
| for (i = 0; i < frame->nb_samples; i++) { | for (i = 0; i < frame->nb_samples; i++) { | ||||
| int64_t max_samples = col == outlink->w - 1 ? last_column_samples: column_max_samples; | |||||
| int ch; | int ch; | ||||
| for (ch = 0; ch < nb_channels; ch++) | for (ch = 0; ch < nb_channels; ch++) | ||||
| sum[ch] += abs(p[ch + i*nb_channels]) << 1; | 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++) { | for (ch = 0; ch < nb_channels; ch++) { | ||||
| int16_t sample = sum[ch] / max_samples; | int16_t sample = sum[ch] / max_samples; | ||||
| uint8_t *buf = out->data[0] + col * pixstep; | uint8_t *buf = out->data[0] + col * pixstep; | ||||