]> git.saurik.com Git - wxWidgets.git/commitdiff
unmultiply by alpha when converting from wxDIB to wxImage as the former uses premulti...
authorVadim Zeitlin <vadim@wxwidgets.org>
Sun, 19 Nov 2006 12:35:16 +0000 (12:35 +0000)
committerVadim Zeitlin <vadim@wxwidgets.org>
Sun, 19 Nov 2006 12:35:16 +0000 (12:35 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@43511 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

docs/changes.txt
src/msw/dib.cpp

index 7b0d6dbc258957ceeb595b11df6463bf857f81c8..7e54a29355533a355a1469aea910476d2eccb57c 100644 (file)
@@ -98,6 +98,7 @@ wxMSW:
 
 - Fixed version script problems when using configure with cygwin/mingw32.
 - Use system default paper size for printing instead of A4
+- Fix colours when converting wxBitmap with alpha to wxImage (nusi)
 
 2.7.2
 -----
index ee17d5d2b1a48b4a8d8bf469d151b8834c1fb192..0c89e7e5add0de12fe4b3f1f5993db65889dabae 100644 (file)
@@ -775,14 +775,26 @@ wxImage wxDIB::ConvertToImage() const
             dst[1] = *src++;
             dst[0] = *src++;
 
-            dst += 3;
-
             if ( is32bit )
             {
                 if ( alpha )
-                    *alpha++ = *src;
+                {
+                    // wxImage uses non premultiplied alpha so undo
+                    // premultiplication done in Create() above
+                    const unsigned char a = *src;
+                    *alpha++ = a;
+                    if ( a > 0 )
+                    {
+                        dst[0] = (dst[0] * 255 - 127) / a;
+                        dst[1] = (dst[1] * 255 - 127) / a;
+                        dst[2] = (dst[2] * 255 - 127) / a;
+                    }
+                }
+
                 src++;
             }
+
+            dst += 3;
         }
 
         // pass to the previous line in the image