mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2024-11-21 10:55:51 +02:00
fftools/ffmpeg_mux_init: switch to avcodec_get_supported_config()
This commit is contained in:
parent
377652da19
commit
7b0eca1e51
@ -511,13 +511,19 @@ static int fmt_in_list(const int *formats, int format)
|
||||
}
|
||||
|
||||
static enum AVPixelFormat
|
||||
choose_pixel_fmt(const AVCodec *codec, enum AVPixelFormat target)
|
||||
choose_pixel_fmt(const AVCodecContext *avctx, enum AVPixelFormat target)
|
||||
{
|
||||
const enum AVPixelFormat *p = codec->pix_fmts;
|
||||
const enum AVPixelFormat *p;
|
||||
const AVPixFmtDescriptor *desc = av_pix_fmt_desc_get(target);
|
||||
//FIXME: This should check for AV_PIX_FMT_FLAG_ALPHA after PAL8 pixel format without alpha is implemented
|
||||
int has_alpha = desc ? desc->nb_components % 2 == 0 : 0;
|
||||
enum AVPixelFormat best= AV_PIX_FMT_NONE;
|
||||
int ret;
|
||||
|
||||
ret = avcodec_get_supported_config(avctx, NULL, AV_CODEC_CONFIG_PIX_FORMAT,
|
||||
0, (const void **) &p, NULL);
|
||||
if (ret < 0)
|
||||
return AV_PIX_FMT_NONE;
|
||||
|
||||
for (; *p != AV_PIX_FMT_NONE; p++) {
|
||||
best = av_find_best_pix_fmt_of_2(best, *p, target, has_alpha, NULL);
|
||||
@ -529,7 +535,7 @@ choose_pixel_fmt(const AVCodec *codec, enum AVPixelFormat target)
|
||||
av_log(NULL, AV_LOG_WARNING,
|
||||
"Incompatible pixel format '%s' for codec '%s', auto-selecting format '%s'\n",
|
||||
av_get_pix_fmt_name(target),
|
||||
codec->name,
|
||||
avctx->codec->name,
|
||||
av_get_pix_fmt_name(best));
|
||||
return best;
|
||||
}
|
||||
@ -538,8 +544,9 @@ choose_pixel_fmt(const AVCodec *codec, enum AVPixelFormat target)
|
||||
|
||||
static enum AVPixelFormat pix_fmt_parse(OutputStream *ost, const char *name)
|
||||
{
|
||||
const enum AVPixelFormat *fmts = ost->enc_ctx->codec->pix_fmts;
|
||||
const enum AVPixelFormat *fmts;
|
||||
enum AVPixelFormat fmt;
|
||||
int ret;
|
||||
|
||||
fmt = av_get_pix_fmt(name);
|
||||
if (fmt == AV_PIX_FMT_NONE) {
|
||||
@ -547,6 +554,11 @@ static enum AVPixelFormat pix_fmt_parse(OutputStream *ost, const char *name)
|
||||
return AV_PIX_FMT_NONE;
|
||||
}
|
||||
|
||||
ret = avcodec_get_supported_config(ost->enc_ctx, NULL, AV_CODEC_CONFIG_PIX_FORMAT,
|
||||
0, (const void **) &fmts, NULL);
|
||||
if (ret < 0)
|
||||
return AV_PIX_FMT_NONE;
|
||||
|
||||
/* when the user specified-format is an alias for an endianness-specific
|
||||
* one (e.g. rgb48 -> rgb48be/le), it gets translated into the native
|
||||
* endianness by av_get_pix_fmt();
|
||||
@ -574,7 +586,7 @@ static enum AVPixelFormat pix_fmt_parse(OutputStream *ost, const char *name)
|
||||
}
|
||||
|
||||
if (fmts && !fmt_in_list(fmts, fmt))
|
||||
fmt = choose_pixel_fmt(ost->enc_ctx->codec, fmt);
|
||||
fmt = choose_pixel_fmt(ost->enc_ctx, fmt);
|
||||
|
||||
return fmt;
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user