Merge branch 'master' of git.opendreambox.org:/git/enigma2
authorghost <andreas.monzner@multimedia-labs.de>
Thu, 20 Nov 2008 00:17:48 +0000 (01:17 +0100)
committerghost <andreas.monzner@multimedia-labs.de>
Thu, 20 Nov 2008 00:17:48 +0000 (01:17 +0100)
lib/gdi/picload.cpp
png_load.diff [deleted file]

index 0fafeab..c162f89 100644 (file)
@@ -288,24 +288,12 @@ static unsigned char *png_load(const char *file, int *ox, int *oy)
        png_read_info(png_ptr, info_ptr);
        png_get_IHDR(png_ptr, info_ptr, &width, &height, &bit_depth, &color_type, &interlace_type, NULL, NULL);
 
-       if (color_type == PNG_COLOR_TYPE_PALETTE)
-       {
-               png_set_palette_to_rgb(png_ptr);
-               png_set_background(png_ptr, (png_color_16 *)&my_background, PNG_BACKGROUND_GAMMA_SCREEN, 0, 1.0);
-       }
-       if (color_type == PNG_COLOR_TYPE_GRAY || color_type == PNG_COLOR_TYPE_GRAY_ALPHA)
-       {
-               png_set_gray_to_rgb(png_ptr);
-               png_set_background(png_ptr, (png_color_16 *)&my_background, PNG_BACKGROUND_GAMMA_SCREEN, 0, 1.0);
-       }
-       if (color_type & PNG_COLOR_MASK_ALPHA)
-               png_set_strip_alpha(png_ptr);
-
-       if (bit_depth < 8)
-               png_set_packing(png_ptr);
-
+       if ((color_type == PNG_COLOR_TYPE_PALETTE)||(color_type == PNG_COLOR_TYPE_GRAY && bit_depth < 8)||(png_get_valid(png_ptr, info_ptr, PNG_INFO_tRNS)))
+               png_set_expand(png_ptr);
        if (bit_depth == 16)
                png_set_strip_16(png_ptr);
+       if (color_type == PNG_COLOR_TYPE_GRAY || color_type == PNG_COLOR_TYPE_GRAY_ALPHA)
+               png_set_gray_to_rgb(png_ptr);
 
        int number_passes = png_set_interlace_handling(png_ptr);
        png_read_update_info(png_ptr, info_ptr);
diff --git a/png_load.diff b/png_load.diff
deleted file mode 100644 (file)
index 9a5a689..0000000
+++ /dev/null
@@ -1,32 +0,0 @@
-diff -Naur enigma2.orig/lib/gdi/picload.cpp enigma2/lib/gdi/picload.cpp
---- enigma2.orig/lib/gdi/picload.cpp   2008-11-18 21:52:44.000000000 +0100
-+++ enigma2/lib/gdi/picload.cpp        2008-11-18 22:38:34.000000000 +0100
-@@ -288,24 +288,12 @@
-       png_read_info(png_ptr, info_ptr);
-       png_get_IHDR(png_ptr, info_ptr, &width, &height, &bit_depth, &color_type, &interlace_type, NULL, NULL);
--      if (color_type == PNG_COLOR_TYPE_PALETTE)
--      {
--              png_set_palette_to_rgb(png_ptr);
--              png_set_background(png_ptr, (png_color_16 *)&my_background, PNG_BACKGROUND_GAMMA_SCREEN, 0, 1.0);
--      }
--      if (color_type == PNG_COLOR_TYPE_GRAY || color_type == PNG_COLOR_TYPE_GRAY_ALPHA)
--      {
--              png_set_gray_to_rgb(png_ptr);
--              png_set_background(png_ptr, (png_color_16 *)&my_background, PNG_BACKGROUND_GAMMA_SCREEN, 0, 1.0);
--      }
--      if (color_type & PNG_COLOR_MASK_ALPHA)
--              png_set_strip_alpha(png_ptr);
--
--      if (bit_depth < 8)
--              png_set_packing(png_ptr);
--
-+      if ((color_type == PNG_COLOR_TYPE_PALETTE)||(color_type == PNG_COLOR_TYPE_GRAY && bit_depth < 8)||(png_get_valid(png_ptr, info_ptr, PNG_INFO_tRNS)))
-+              png_set_expand(png_ptr);
-       if (bit_depth == 16)
-               png_set_strip_16(png_ptr);
-+      if (color_type == PNG_COLOR_TYPE_GRAY || color_type == PNG_COLOR_TYPE_GRAY_ALPHA)
-+              png_set_gray_to_rgb(png_ptr);
-       int number_passes = png_set_interlace_handling(png_ptr);
-       png_read_update_info(png_ptr, info_ptr);