]> git.sesse.net Git - ffmpeg/commitdiff
pgssub: Fix subpicture colorspace and range
authorJan Ekström <jeebjp@gmail.com>
Sun, 24 Apr 2016 18:33:45 +0000 (20:33 +0200)
committerLuca Barbato <lu_zero@gentoo.org>
Tue, 10 May 2016 09:30:25 +0000 (11:30 +0200)
Widen the values from limited to full range and use BT.709 where it
should be used according to the video resolution:

SD is BT.601, HD is BT.709

Default to BT.709 due to most observed HDMV content being HD.

libavcodec/pgssubdec.c

index 7bcb1ed792ce4780e9cf7a26c0416b9a28291f72..a4cb66b0ae96f86a89ab1a5d8116209f2e23588f 100644 (file)
@@ -351,8 +351,14 @@ static int parse_palette_segment(AVCodecContext *avctx,
         cb        = bytestream_get_byte(&buf);
         alpha     = bytestream_get_byte(&buf);
 
-        YUV_TO_RGB1(cb, cr);
-        YUV_TO_RGB2(r, g, b, y);
+        /* Default to BT.709 colorspace. In case of <= 576 height use BT.601 */
+        if (avctx->height <= 0 || avctx->height > 576) {
+            YUV_TO_RGB1_CCIR_BT709(cb, cr);
+        } else {
+            YUV_TO_RGB1_CCIR(cb, cr);
+        }
+
+        YUV_TO_RGB2_CCIR(r, g, b, y);
 
         ff_dlog(avctx, "Color %d := (%d,%d,%d,%d)\n", color_id, r, g, b, alpha);