X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ad81651f00edc6f489d9b6a0839d316a964fd521..8def743e8fcd51ba3e68cb6b59154d3557e18f79:/src/msw/bmpbuttn.cpp diff --git a/src/msw/bmpbuttn.cpp b/src/msw/bmpbuttn.cpp index 22234319d3..4eb6795442 100644 --- a/src/msw/bmpbuttn.cpp +++ b/src/msw/bmpbuttn.cpp @@ -39,7 +39,10 @@ bool wxBitmapButton::Create(wxWindow *parent, wxWindowID id, const wxBitmap& bit { m_buttonBitmap = bitmap; SetName(name); + +#if wxUSE_VALIDATORS SetValidator(validator); +#endif // wxUSE_VALIDATORS parent->AddChild(this); @@ -172,21 +175,40 @@ bool wxBitmapButton::MSWOnDraw(WXDRAWITEMSTRUCT *item) } BOOL ok; + + // no MaskBlt() under Win16 +#ifdef __WIN32__ wxMask *mask = bitmap->GetMask(); if ( mask ) { // the fg ROP is applied for the pixels of the mask bitmap which are 1 // (for a wxMask this means that this is a non transparent pixel), the // bg ROP is applied for all the others + + HBRUSH hbrBackground = + ::CreateSolidBrush(wxColourToRGB(GetBackgroundColour())); + HBRUSH hbrOld = (HBRUSH)::SelectObject(hDC, hbrBackground); + ok = ::MaskBlt( hDC, x1, y1, wBmp, hBmp, // dst memDC, 0, 0, // src (HBITMAP)mask->GetMaskBitmap(), 0, 0, // mask MAKEROP4(SRCCOPY, // fg ROP - SRCPAINT) // bg ROP + PATCOPY) // bg ROP ); + + ::SelectObject(hDC, hbrOld); + ::DeleteObject(hbrBackground); } else + { + // this will make the check below fail and BitBlt() will be used if + // MaskBlt() is not supported (for example, under Win95) + ok = FALSE; + } + + if ( !ok ) +#endif // Win32 { ok = ::BitBlt(hDC, x1, y1, wBmp, hBmp, // dst memDC, 0, 0, // src