[FFmpeg-devel] [PATCH 1/2] avcodec/proresenc: make transparency honored in mov/QT

Stefano Sabatini stefasab at gmail.com
Wed Dec 27 13:54:28 EET 2023


On date Tuesday 2023-12-26 23:25:15 +0100, Clément Bœsch wrote:
> In the mov muxer (in mov_write_video_tag()), bits_per_coded_sample will
> be written under certain conditions and is required to be 32 for the
> transparency to be honored in QuickTime.
> 
> prores_kostya already has this setting but prores_anatoliy and
> prores_videotoolbox didn't.
> ---
>  libavcodec/proresenc_anatoliy.c | 3 +++
>  libavcodec/videotoolboxenc.c    | 2 ++
>  2 files changed, 5 insertions(+)
> 
> diff --git a/libavcodec/proresenc_anatoliy.c b/libavcodec/proresenc_anatoliy.c
> index a1cb46aa59..16741afd68 100644
> --- a/libavcodec/proresenc_anatoliy.c
> +++ b/libavcodec/proresenc_anatoliy.c
> @@ -930,6 +930,9 @@ static av_cold int prores_encode_init(AVCodecContext *avctx)
>          }
>      }
>  
> +    if (ctx->need_alpha)
> +        avctx->bits_per_coded_sample = 32;
> +
>      ff_fdctdsp_init(&ctx->fdsp, avctx);
>  
>      avctx->codec_tag = AV_RL32((const uint8_t*)profiles[avctx->profile].name);
> diff --git a/libavcodec/videotoolboxenc.c b/libavcodec/videotoolboxenc.c
> index 15e0e1fe29..644fd60b00 100644
> --- a/libavcodec/videotoolboxenc.c
> +++ b/libavcodec/videotoolboxenc.c
> @@ -521,6 +521,8 @@ static CMVideoCodecType get_cm_codec_type(AVCodecContext *avctx,
>          }
>          return kCMVideoCodecType_HEVC;
>      case AV_CODEC_ID_PRORES:
> +        if (desc && (desc->flags & AV_PIX_FMT_FLAG_ALPHA))
> +            avctx->bits_per_coded_sample = 32;
>          switch (profile) {
>          case AV_PROFILE_PRORES_PROXY:
>              return MKBETAG('a','p','c','o'); // kCMVideoCodecType_AppleProRes422Proxy

LGTM.


More information about the ffmpeg-devel mailing list