mirror of
https://git.ffmpeg.org/ffmpeg.git
synced 2025-02-27 01:01:07 +00:00
libfdk-aacdec: Add an option for setting the decoder's DRC album mode
Signed-off-by: Martin Storsjö <martin@martin.st>
This commit is contained in:
parent
e1a14479a8
commit
340a78afeb
@ -56,6 +56,7 @@ typedef struct FDKAACDecContext {
|
|||||||
int drc_heavy;
|
int drc_heavy;
|
||||||
int drc_effect;
|
int drc_effect;
|
||||||
int drc_cut;
|
int drc_cut;
|
||||||
|
int album_mode;
|
||||||
int level_limit;
|
int level_limit;
|
||||||
int output_delay;
|
int output_delay;
|
||||||
} FDKAACDecContext;
|
} FDKAACDecContext;
|
||||||
@ -87,6 +88,10 @@ static const AVOption fdk_aac_dec_options[] = {
|
|||||||
#if FDKDEC_VER_AT_LEAST(3, 0) // 3.0.0
|
#if FDKDEC_VER_AT_LEAST(3, 0) // 3.0.0
|
||||||
{ "drc_effect","Dynamic Range Control: effect type, where e.g. [0] is none and [6] is general",
|
{ "drc_effect","Dynamic Range Control: effect type, where e.g. [0] is none and [6] is general",
|
||||||
OFFSET(drc_effect), AV_OPT_TYPE_INT, { .i64 = -1}, -1, 8, AD, NULL },
|
OFFSET(drc_effect), AV_OPT_TYPE_INT, { .i64 = -1}, -1, 8, AD, NULL },
|
||||||
|
#endif
|
||||||
|
#if FDKDEC_VER_AT_LEAST(3, 1) // 3.1.0
|
||||||
|
{ "album_mode","Dynamic Range Control: album mode, where [0] is off and [1] is on",
|
||||||
|
OFFSET(album_mode), AV_OPT_TYPE_INT, { .i64 = -1}, -1, 1, AD, NULL },
|
||||||
#endif
|
#endif
|
||||||
{ NULL }
|
{ NULL }
|
||||||
};
|
};
|
||||||
@ -335,6 +340,15 @@ static av_cold int fdk_aac_decode_init(AVCodecContext *avctx)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if FDKDEC_VER_AT_LEAST(3, 1) // 3.1.0
|
||||||
|
if (s->album_mode != -1) {
|
||||||
|
if (aacDecoder_SetParam(s->handle, AAC_UNIDRC_ALBUM_MODE, s->album_mode) != AAC_DEC_OK) {
|
||||||
|
av_log(avctx, AV_LOG_ERROR, "Unable to set album mode in the decoder\n");
|
||||||
|
return AVERROR_UNKNOWN;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
avctx->sample_fmt = AV_SAMPLE_FMT_S16;
|
avctx->sample_fmt = AV_SAMPLE_FMT_S16;
|
||||||
|
|
||||||
s->decoder_buffer_size = DECODER_BUFFSIZE * DECODER_MAX_CHANNELS;
|
s->decoder_buffer_size = DECODER_BUFFSIZE * DECODER_MAX_CHANNELS;
|
||||||
|
Loading…
Reference in New Issue
Block a user