Merge branch 'master' of git.opendreambox.org:/git/enigma2
[enigma2.git] / png_load.diff
1 diff -Naur enigma2.orig/lib/gdi/picload.cpp enigma2/lib/gdi/picload.cpp
2 --- enigma2.orig/lib/gdi/picload.cpp    2008-11-18 21:52:44.000000000 +0100
3 +++ enigma2/lib/gdi/picload.cpp 2008-11-18 22:38:34.000000000 +0100
4 @@ -288,24 +288,12 @@
5         png_read_info(png_ptr, info_ptr);
6         png_get_IHDR(png_ptr, info_ptr, &width, &height, &bit_depth, &color_type, &interlace_type, NULL, NULL);
7  
8 -       if (color_type == PNG_COLOR_TYPE_PALETTE)
9 -       {
10 -               png_set_palette_to_rgb(png_ptr);
11 -               png_set_background(png_ptr, (png_color_16 *)&my_background, PNG_BACKGROUND_GAMMA_SCREEN, 0, 1.0);
12 -       }
13 -       if (color_type == PNG_COLOR_TYPE_GRAY || color_type == PNG_COLOR_TYPE_GRAY_ALPHA)
14 -       {
15 -               png_set_gray_to_rgb(png_ptr);
16 -               png_set_background(png_ptr, (png_color_16 *)&my_background, PNG_BACKGROUND_GAMMA_SCREEN, 0, 1.0);
17 -       }
18 -       if (color_type & PNG_COLOR_MASK_ALPHA)
19 -               png_set_strip_alpha(png_ptr);
20 -
21 -       if (bit_depth < 8)
22 -               png_set_packing(png_ptr);
23 -
24 +       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)))
25 +               png_set_expand(png_ptr);
26         if (bit_depth == 16)
27                 png_set_strip_16(png_ptr);
28 +       if (color_type == PNG_COLOR_TYPE_GRAY || color_type == PNG_COLOR_TYPE_GRAY_ALPHA)
29 +               png_set_gray_to_rgb(png_ptr);
30  
31         int number_passes = png_set_interlace_handling(png_ptr);
32         png_read_update_info(png_ptr, info_ptr);