changeset 25298:23894348d1e5

Convert vobsub custom colors from rgb to yuv using a common function.
author ulion
date Sun, 09 Dec 2007 06:58:57 +0000
parents 949e15337e50
children 0335de28ee01
files libmpdemux/demux_mkv.c vobsub.c
diffstat 2 files changed, 16 insertions(+), 9 deletions(-) [+]
line wrap: on
line diff
--- a/libmpdemux/demux_mkv.c	Sat Dec 08 23:21:08 2007 +0000
+++ b/libmpdemux/demux_mkv.c	Sun Dec 09 06:58:57 2007 +0000
@@ -356,13 +356,15 @@
           use_custom_colors ? "ON" : "OFF");
    if ((start = strstr(start, "colors:")) != NULL)
      {
+       unsigned int tmp;
        start += 7;
        while (isspace(*start))
          start++;
        for (i = 0; i < 4; i++)
          {
-           if (sscanf(start, "%06x", &sh->colors[i]) != 1)
+           if (sscanf(start, "%06x", &tmp) != 1)
              break;
+           sh->colors[i] = vobsub_rgb_to_yuv(tmp);
            start += 6;
            while ((*start == ',') || isspace(*start))
              start++;
--- a/vobsub.c	Sat Dec 08 23:21:08 2007 +0000
+++ b/vobsub.c	Sun Dec 09 06:58:57 2007 +0000
@@ -817,6 +817,18 @@
     return y << 16 | u << 8 | v;
 }
 
+unsigned int vobsub_rgb_to_yuv(unsigned int rgb)
+{
+    int r, g, b, y, u, v;
+    r = rgb >> 16 & 0xff;
+    g = rgb >> 8 & 0xff;
+    b = rgb & 0xff;
+    y = ( 0.299   * r + 0.587   * g + 0.114   * b) * 219 / 255 + 16.5;
+    u = (-0.16874 * r - 0.33126 * g + 0.5     * b) * 224 / 255 + 128.5;
+    v = ( 0.5     * r - 0.41869 * g - 0.08131 * b) * 224 / 255 + 128.5;
+    return y << 16 | u << 8 | v;
+}
+
 static int
 vobsub_parse_palette(vobsub_t *vob, const char *line)
 {
@@ -863,7 +875,6 @@
 {
     //colors: XXXXXX, XXXXXX, XXXXXX, XXXXXX
     unsigned int n, tmp;
-    int r, g, b, y, u, v;
     n = 0;
     line += 40;
     while(1){
@@ -876,13 +887,7 @@
 	if (p - line !=6)
 	    return -1;
 	tmp = strtoul(line, NULL, 16);
-	r = tmp >> 16 & 0xff;
-	g = tmp >> 8 & 0xff;
-	b = tmp & 0xff;
-	y = av_clip_uint8( 0.1494  * r + 0.6061 * g + 0.2445 * b);
-	u = av_clip_uint8( 0.6066  * r - 0.4322 * g - 0.1744 * b + 128);
-	v = av_clip_uint8(-0.08435 * r - 0.3422 * g + 0.4266 * b + 128);
-	vob->cuspal[n++] = y << 16 | u << 8 | v;
+	vob->cuspal[n++] = vobsub_rgb_to_yuv(tmp);
 	if (n==4)
 	    break;
 	if(*p == ',')