Fixed inverse masking on MSW imagelist
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@4331 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
parent
4e16881a08
commit
54b37e2e8b
@ -91,13 +91,36 @@ int wxImageList::Add(const wxBitmap& bitmap, const wxBitmap& mask)
|
||||
HBITMAP hBitmap2 = 0;
|
||||
if ( mask.Ok() )
|
||||
hBitmap2 = (HBITMAP) mask.GetHBITMAP();
|
||||
else if (bitmap.GetMask())
|
||||
hBitmap2 = (HBITMAP) bitmap.GetMask()->GetMaskBitmap();
|
||||
|
||||
int index = ImageList_Add((HIMAGELIST) GetHIMAGELIST(), hBitmap1, hBitmap2);
|
||||
HBITMAP hBitmapI=0;
|
||||
if(hBitmap2!=0) {
|
||||
// Microsoft imagelist masks are inverted from wxWindows mask standard (white is mask color)
|
||||
BITMAP bm;
|
||||
::GetObject(hBitmap2,sizeof(BITMAP),(LPVOID)&bm);
|
||||
int w=bm.bmWidth;
|
||||
int h=bm.bmHeight;
|
||||
HDC hdc = ::CreateCompatibleDC(NULL);
|
||||
HDC hdci = ::CreateCompatibleDC(NULL);
|
||||
hBitmapI = ::CreateCompatibleBitmap(hdci, w, h);
|
||||
::SelectObject(hdc, hBitmap2);
|
||||
::SelectObject(hdci, hBitmapI);
|
||||
::BitBlt(hdci, 0, 0, w, h, hdc, 0, 0, NOTSRCCOPY);
|
||||
::DeleteDC(hdc);
|
||||
::DeleteDC(hdci);
|
||||
}
|
||||
|
||||
int index = ImageList_Add((HIMAGELIST) GetHIMAGELIST(), hBitmap1, hBitmapI);
|
||||
if ( index == -1 )
|
||||
{
|
||||
wxLogError(_("Couldn't add an image to the image list."));
|
||||
}
|
||||
|
||||
// Clean up inverted mask
|
||||
if(hBitmapI!=0)
|
||||
::DeleteObject(hBitmapI);
|
||||
|
||||
return index;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user