mirror of
https://github.com/FFmpeg/FFmpeg.git
synced 2025-01-19 05:49:09 +02:00
avcodec/libx265: add support for setting chroma sample location
Unlike libx264, libx265 does not handle the chroma format check on its own side, so in order to not write out values which are supposed to be ignored according to the specification, we limit the writing out of chroma sample location to 4:2:0 only.
This commit is contained in:
parent
c500dc7cca
commit
9b2281a4a3
@ -211,6 +211,19 @@ static av_cold int libx265_encode_init(AVCodecContext *avctx)
|
||||
ctx->params->vui.matrixCoeffs = avctx->colorspace;
|
||||
}
|
||||
|
||||
// chroma sample location values are to be ignored in case of non-4:2:0
|
||||
// according to the specification, so we only write them out in case of
|
||||
// 4:2:0 (log2_chroma_{w,h} == 1).
|
||||
ctx->params->vui.bEnableChromaLocInfoPresentFlag =
|
||||
avctx->chroma_sample_location != AVCHROMA_LOC_UNSPECIFIED &&
|
||||
desc->log2_chroma_w == 1 && desc->log2_chroma_h == 1;
|
||||
|
||||
if (ctx->params->vui.bEnableChromaLocInfoPresentFlag) {
|
||||
ctx->params->vui.chromaSampleLocTypeTopField =
|
||||
ctx->params->vui.chromaSampleLocTypeBottomField =
|
||||
avctx->chroma_sample_location - 1;
|
||||
}
|
||||
|
||||
if (avctx->sample_aspect_ratio.num > 0 && avctx->sample_aspect_ratio.den > 0) {
|
||||
char sar[12];
|
||||
int sar_num, sar_den;
|
||||
|
Loading…
x
Reference in New Issue
Block a user