From a61f0d90494b39249135314cc81d74776b38a3e6 Mon Sep 17 00:00:00 2001 From: truelight Date: Thu, 14 Jun 2007 14:11:08 +0000 Subject: [PATCH] (svn r10156) -Fix: PNG loader can now load 8bpp palette images and greyscale images --- src/spriteloader/png.cpp | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/src/spriteloader/png.cpp b/src/spriteloader/png.cpp index bd735ce433..71f64a2bf6 100644 --- a/src/spriteloader/png.cpp +++ b/src/spriteloader/png.cpp @@ -114,8 +114,14 @@ static bool LoadPNG(SpriteLoader::Sprite *sprite, const char *filename, uint32 i if (!mask) { if (bit_depth == 16) png_set_strip_16(png_ptr); - if (color_type == PNG_COLOR_TYPE_PALETTE) png_set_palette_to_rgb(png_ptr); - /* TODO 32bpp: Convert grayscale to rgb */ + if (color_type == PNG_COLOR_TYPE_PALETTE) { + png_set_palette_to_rgb(png_ptr); + color_type = PNG_COLOR_TYPE_RGB; + } + if (color_type == PNG_COLOR_TYPE_GRAY || color_type == PNG_COLOR_TYPE_GRAY_ALPHA) { + png_set_gray_to_rgb(png_ptr); + color_type = PNG_COLOR_TYPE_RGB; + } #ifdef TTD_LITTLE_ENDIAN png_set_bgr(png_ptr);