diff --git a/libavfilter/vf_fade.c b/libavfilter/vf_fade.c index ab2dccf85b7c188937f21cd4cb3d63463936c662..3e6aa7fe870cc81eca7f5383974c33682c8a817e 100644 --- a/libavfilter/vf_fade.c +++ b/libavfilter/vf_fade.c @@ -115,12 +115,30 @@ static int query_formats(AVFilterContext *ctx) AV_PIX_FMT_RGBA, AV_PIX_FMT_BGRA, AV_PIX_FMT_NONE }; + static const enum AVPixelFormat pix_fmts_alpha[] = { + AV_PIX_FMT_YUVA420P, AV_PIX_FMT_YUVA422P, AV_PIX_FMT_YUVA444P, + AV_PIX_FMT_ARGB, AV_PIX_FMT_ABGR, + AV_PIX_FMT_RGBA, AV_PIX_FMT_BGRA, + AV_PIX_FMT_NONE + }; + static const enum AVPixelFormat pix_fmts_rgba[] = { + AV_PIX_FMT_ARGB, AV_PIX_FMT_ABGR, + AV_PIX_FMT_RGBA, AV_PIX_FMT_BGRA, + AV_PIX_FMT_NONE + }; AVFilterFormats *fmts_list; - if (s->black_fade) - fmts_list = ff_make_format_list(pix_fmts); - else - fmts_list = ff_make_format_list(pix_fmts_rgb); + if (s->alpha) { + if (s->black_fade) + fmts_list = ff_make_format_list(pix_fmts_alpha); + else + fmts_list = ff_make_format_list(pix_fmts_rgba); + } else { + if (s->black_fade) + fmts_list = ff_make_format_list(pix_fmts); + else + fmts_list = ff_make_format_list(pix_fmts_rgb); + } if (!fmts_list) return AVERROR(ENOMEM); return ff_set_common_formats(ctx, fmts_list);