mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-03-03 14:32:16 +02:00
avcodec/libx264: leave full range flag unchanged if unknown
By default the x264 full range flag is set to -1. By not setting it to something else, we can let libx264 handle the RGB case. Additionally, change the preference order to user-specified range first, and then any fall-back logic left for the YUVJ pix_fmts. Fixes the capture part of #9374
This commit is contained in:
parent
ed47a4a842
commit
7ca71b79f2
@ -857,10 +857,12 @@ static av_cold int X264_init(AVCodecContext *avctx)
|
||||
|
||||
x4->params.i_slice_count = avctx->slices;
|
||||
|
||||
x4->params.vui.b_fullrange = avctx->pix_fmt == AV_PIX_FMT_YUVJ420P ||
|
||||
if (avctx->color_range != AVCOL_RANGE_UNSPECIFIED)
|
||||
x4->params.vui.b_fullrange = avctx->color_range == AVCOL_RANGE_JPEG;
|
||||
else if (avctx->pix_fmt == AV_PIX_FMT_YUVJ420P ||
|
||||
avctx->pix_fmt == AV_PIX_FMT_YUVJ422P ||
|
||||
avctx->pix_fmt == AV_PIX_FMT_YUVJ444P ||
|
||||
avctx->color_range == AVCOL_RANGE_JPEG;
|
||||
avctx->pix_fmt == AV_PIX_FMT_YUVJ444P)
|
||||
x4->params.vui.b_fullrange = 1;
|
||||
|
||||
if (avctx->colorspace != AVCOL_SPC_UNSPECIFIED)
|
||||
x4->params.vui.i_colmatrix = avctx->colorspace;
|
||||
|
Loading…
x
Reference in New Issue
Block a user