From 162619a426c9af15ac4868c9c7ce882f9932db38 Mon Sep 17 00:00:00 2001 From: Perttu Ahola Date: Sun, 16 Oct 2011 23:41:43 +0300 Subject: Fix to-transparend conversion of backgrounds of sprite image files that don't have an alpha channel --- src/tile.cpp | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) (limited to 'src') diff --git a/src/tile.cpp b/src/tile.cpp index 4e441329a..e274d2d3e 100644 --- a/src/tile.cpp +++ b/src/tile.cpp @@ -1092,22 +1092,23 @@ bool generate_image(std::string part_of_name, video::IImage *& baseimg, core::dimension2d dim = image->getDimension(); baseimg = driver->createImage(video::ECF_A8R8G8B8, dim); + // Blit + image->copyTo(baseimg); + + image->drop(); + for(u32 y=0; ygetPixel(x,y); + video::SColor c = baseimg->getPixel(x,y); u32 r = c.getRed(); u32 g = c.getGreen(); u32 b = c.getBlue(); if(!(r == r1 && g == g1 && b == b1)) continue; c.setAlpha(0); - image->setPixel(x,y,c); + baseimg->setPixel(x,y,c); } - // Blit - image->copyTo(baseimg); - - image->drop(); } } /* @@ -1149,11 +1150,16 @@ bool generate_image(std::string part_of_name, video::IImage *& baseimg, { core::dimension2d dim = image->getDimension(); baseimg = driver->createImage(video::ECF_A8R8G8B8, dim); + + // Blit + image->copyTo(baseimg); + + image->drop(); for(u32 y=0; ygetPixel(x,y); + video::SColor c = baseimg->getPixel(x,y); u32 r = c.getRed(); u32 g = c.getGreen(); u32 b = c.getBlue(); @@ -1161,12 +1167,8 @@ bool generate_image(std::string part_of_name, video::IImage *& baseimg, !(r == r2 && g == g2 && b == b2)) continue; c.setAlpha(0); - image->setPixel(x,y,c); + baseimg->setPixel(x,y,c); } - // Blit - image->copyTo(baseimg); - - image->drop(); } } /* -- cgit v1.2.3