diff options
author | Andri Yngvason <andri@yngvason.is> | 2024-08-19 22:34:37 +0000 |
---|---|---|
committer | Andri Yngvason <andri@yngvason.is> | 2024-08-19 22:34:37 +0000 |
commit | 28cc17e309fc6117370b38ec11d803dc36e8ef01 (patch) | |
tree | 8799a228e44e961a6f58b4b7120d74d88829e8af | |
parent | e6fb0574d994c1f77abec08bcd47b6b46a93f4a9 (diff) | |
download | tigervnc-28cc17e309fc6117370b38ec11d803dc36e8ef01.tar.gz tigervnc-28cc17e309fc6117370b38ec11d803dc36e8ef01.zip |
H264Libav: Handle colour space conversion
The scaler is now informed of the colour space encoded into the stream
so that it may do the proper conversion.
-rw-r--r-- | common/rfb/H264LibavDecoderContext.cxx | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/common/rfb/H264LibavDecoderContext.cxx b/common/rfb/H264LibavDecoderContext.cxx index 38210205..c3153fd1 100644 --- a/common/rfb/H264LibavDecoderContext.cxx +++ b/common/rfb/H264LibavDecoderContext.cxx @@ -217,6 +217,21 @@ void H264LibavDecoderContext::decode(const uint8_t* h264_in_buffer, frame->width, frame->height, AV_PIX_FMT_RGB32, 0, nullptr, nullptr, nullptr); + int inFull, outFull, brightness, contrast, saturation; + const int* inTable; + const int* outTable; + + sws_getColorspaceDetails(sws, (int**)&inTable, &inFull, (int**)&outTable, + &outFull, &brightness, &contrast, &saturation); + if (frame->colorspace != AVCOL_SPC_UNSPECIFIED) { + inTable = sws_getCoefficients(frame->colorspace); + } + if (frame->color_range != AVCOL_RANGE_UNSPECIFIED) { + inFull = frame->color_range == AVCOL_RANGE_JPEG; + } + sws_setColorspaceDetails(sws, inTable, inFull, outTable, outFull, brightness, + contrast, saturation); + if (rgbFrame && (rgbFrame->width != frame->width || rgbFrame->height != frame->height)) { av_frame_free(&rgbFrame); |