From: Robin Dunn Date: Wed, 25 May 2005 17:06:58 +0000 (+0000) Subject: When converting a wxIcon to a bitmap check if the icon has an alpha X-Git-Url: https://git.saurik.com/wxWidgets.git/commitdiff_plain/5a60b5f0414e4b5663d968344b1aaae861a0797f When converting a wxIcon to a bitmap check if the icon has an alpha channel and set the bitmap to use it. git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@34340 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- diff --git a/docs/changes.txt b/docs/changes.txt index 2783bf3832..1527fe6172 100644 --- a/docs/changes.txt +++ b/docs/changes.txt @@ -37,6 +37,8 @@ wxMSW: - Compiles again with WIN64. - Restored separators on toolbars under XP themes. - Winelib compilation now works. +- When converting a wxIcon to a bitmap check if the icon has an alpha + channel and set the bitmap to use it. wxGTK: diff --git a/src/msw/bitmap.cpp b/src/msw/bitmap.cpp index adb8e3f5ba..015c8309bd 100644 --- a/src/msw/bitmap.cpp +++ b/src/msw/bitmap.cpp @@ -310,11 +310,38 @@ bool wxBitmap::CopyFromIconOrCursor(const wxGDIImage& icon) refData->m_hBitmap = (WXHBITMAP)iconInfo.hbmColor; - // the mask returned by GetIconInfo() is inversed compared to the usual - // wxWin convention - refData->SetMask(wxInvertMask(iconInfo.hbmMask, w, h)); - - +#if wxUSE_WXDIB + // If the icon is 32 bits per pixel then it may have alpha channel data, + // although there are some icons that are 32 bpp but have no alpha... So + // convert to a DIB and manually check the 4th byte for each pixel. + BITMAP bm; + if ( ::GetObject(iconInfo.hbmColor, sizeof(BITMAP), (LPVOID)&bm) + && bm.bmBitsPixel == 32) + { + wxDIB dib(iconInfo.hbmColor); + if (dib.IsOk()) + { + unsigned char* pixels = dib.GetData(); + for (int idx=0; idxm_hasAlpha = true; + break; + } + } + } + } +#endif + if ( !refData->m_hasAlpha ) + { + // the mask returned by GetIconInfo() is inversed compared to the usual + // wxWin convention + refData->SetMask(wxInvertMask(iconInfo.hbmMask, w, h)); + } + // delete the old one now as we don't need it any more ::DeleteObject(iconInfo.hbmMask);