From 7a39daf179c1ad163ab28ee58d2433289a96c46e Mon Sep 17 00:00:00 2001 From: Cameron Gutman Date: Wed, 12 Oct 2022 23:52:29 -0500 Subject: [PATCH] Implement Rec 601 Full Range support in SDLRenderer --- app/streaming/video/ffmpeg-renderers/sdlvid.cpp | 14 ++++++++++++-- app/streaming/video/ffmpeg.cpp | 1 + 2 files changed, 13 insertions(+), 2 deletions(-) diff --git a/app/streaming/video/ffmpeg-renderers/sdlvid.cpp b/app/streaming/video/ffmpeg-renderers/sdlvid.cpp index 2b03a187..7cc18e62 100644 --- a/app/streaming/video/ffmpeg-renderers/sdlvid.cpp +++ b/app/streaming/video/ffmpeg-renderers/sdlvid.cpp @@ -77,6 +77,7 @@ bool SdlRenderer::isPixelFormatSupported(int, AVPixelFormat pixelFormat) switch (pixelFormat) { case AV_PIX_FMT_YUV420P: + case AV_PIX_FMT_YUVJ420P: case AV_PIX_FMT_NV12: case AV_PIX_FMT_NV21: return true; @@ -397,6 +398,7 @@ ReadbackRetry: switch (frame->format) { case AV_PIX_FMT_YUV420P: + case AV_PIX_FMT_YUVJ420P: sdlFormat = SDL_PIXELFORMAT_YV12; break; case AV_PIX_FMT_CUDA: @@ -414,11 +416,19 @@ ReadbackRetry: switch (colorspace) { case COLORSPACE_REC_709: + SDL_assert(!isFrameFullRange(frame)); SDL_SetYUVConversionMode(SDL_YUV_CONVERSION_BT709); break; case COLORSPACE_REC_601: + if (isFrameFullRange(frame)) { + // SDL's JPEG mode is Rec 601 Full Range + SDL_SetYUVConversionMode(SDL_YUV_CONVERSION_JPEG); + } + else { + SDL_SetYUVConversionMode(SDL_YUV_CONVERSION_BT601); + } + break; default: - SDL_SetYUVConversionMode(SDL_YUV_CONVERSION_BT601); break; } @@ -461,7 +471,7 @@ ReadbackRetry: goto Exit; #endif } - else if (frame->format == AV_PIX_FMT_YUV420P) { + else if (frame->format == AV_PIX_FMT_YUV420P || frame->format == AV_PIX_FMT_YUVJ420P) { SDL_UpdateYUVTexture(m_Texture, nullptr, frame->data[0], frame->linesize[0], diff --git a/app/streaming/video/ffmpeg.cpp b/app/streaming/video/ffmpeg.cpp index 9a71f083..bb1ecaf4 100644 --- a/app/streaming/video/ffmpeg.cpp +++ b/app/streaming/video/ffmpeg.cpp @@ -822,6 +822,7 @@ bool FFmpegVideoDecoder::initialize(PDECODER_PARAMETERS params) // - AV_PIX_FMT_DRM_PRIME // - AV_PIX_FMT_MMAL // - AV_PIX_FMT_YUV420P + // - AV_PIX_FMT_YUVJ420P // - AV_PIX_FMT_NV12 // - AV_PIX_FMT_NV21 {