]> git.saurik.com Git - wxWidgets.git/blobdiff - wxPython/demo/ImageAlpha.py
applying patch 1622389, fixing two memory leaks
[wxWidgets.git] / wxPython / demo / ImageAlpha.py
index cb5210412f2da73c0d1e2a19759fa26946aac6d1..9613a8ce914c3dca3e9b922cff6cd8e6e55cfcef 100644 (file)
@@ -5,7 +5,7 @@ from Main import opj
 
 #----------------------------------------------------------------------
 
-msg = "This is some text that will appear behind the image..."
+msg = "Some text will appear mixed in the image's shadow..."
 
 class TestPanel(wx.Panel):
     def __init__(self, parent, log):
@@ -21,13 +21,26 @@ class TestPanel(wx.Panel):
         dc.Clear()
 
         dc.SetFont(wx.Font(16, wx.SWISS, wx.NORMAL, wx.BOLD, True))
-        dc.DrawText("Bitmap alpha blending (on wxMSW and wxMac only)",
+        dc.DrawText("Bitmap alpha blending (on all ports but gtk+ 1.2)",
                     25,25)
         
         bmp = wx.Bitmap(opj('bitmaps/toucan.png'))
-        if "__WXGTK__" in wx.PlatformInfo:
-            # try to make up for it a bit...
-            bmp.SetMaskColour("black")
+        if "gtk1" in wx.PlatformInfo:
+            # Try to make up for lack of alpha support in wxGTK (gtk+
+            # 1.2) by converting the alpha blending into a
+            # transparency mask.
+
+            # first convert to a wx.Image
+            img = bmp.ConvertToImage()
+
+            # Then convert the alpha channel to a mask, specifying the
+            # threshold below which alpha will be made fully
+            # transparent
+            img.ConvertAlphaToMask(220)
+
+            # convert back to a wx.Bitmap
+            bmp = img.ConvertToBitmap()
+
             
         dc.DrawBitmap(bmp, 25,100, True)