aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2012-04-11 13:46:31 +0200
committerMichael Niedermayer <michaelni@gmx.at>2012-04-11 14:10:22 +0200
commit6c704d9c30425c9a2c8bb1d1787b62643a3439f4 (patch)
treeecb5915bd0b7cb160bb44ca75645c2a2b13d6e59
parentbe4cde226a2c7b1fe3864224d8a18f32b97edd45 (diff)
downloadffmpeg-6c704d9c30425c9a2c8bb1d1787b62643a3439f4.tar.gz
ffmpeg: support changing dither parameters for swr
Signed-off-by: Michael Niedermayer <michaelni@gmx.at>
-rw-r--r--ffmpeg.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/ffmpeg.c b/ffmpeg.c
index 66f96ccebd..61ec3aeacf 100644
--- a/ffmpeg.c
+++ b/ffmpeg.c
@@ -276,6 +276,8 @@ typedef struct OutputStream {
AVFilterGraph *graph;
int64_t sws_flags;
+ int64_t swr_dither_method;
+ double swr_dither_scale;
AVDictionary *opts;
int is_past_recording_time;
int stream_copy;
@@ -1199,6 +1201,8 @@ static void do_audio_out(AVFormatContext *s, OutputStream *ost,
enc->channel_layout, enc->sample_fmt, enc->sample_rate,
dec->channel_layout, dec->sample_fmt, dec->sample_rate,
0, NULL);
+ av_opt_set_int(ost->swr, "dither_method", ost->swr_dither_method,0);
+ av_opt_set_int(ost->swr, "dither_scale", ost->swr_dither_scale,0);
if (ost->audio_channels_mapped)
swr_set_channel_mapping(ost->swr, ost->audio_channels_map);
av_opt_set_double(ost->swr, "rmvol", ost->rematrix_volume, 0);
@@ -3965,6 +3969,8 @@ static OutputStream *new_output_stream(OptionsContext *o, AVFormatContext *oc, e
st->codec->flags |= CODEC_FLAG_GLOBAL_HEADER;
av_opt_get_int(sws_opts, "sws_flags", 0, &ost->sws_flags);
+ av_opt_get_int (swr_opts, "dither_method", 0, &ost->swr_dither_method);
+ av_opt_get_double(swr_opts, "dither_scale" , 0, &ost->swr_dither_scale);
ost->source_index = source_index;
if (source_index >= 0) {