X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/ef344ff86223f1f0961f025c0b249c898529c095..00c813596e3eefdd028365acf9542355937e5531:/src/mgl/bitmap.cpp?ds=sidebyside diff --git a/src/mgl/bitmap.cpp b/src/mgl/bitmap.cpp index 4e9e1051eb..ca87f8483b 100644 --- a/src/mgl/bitmap.cpp +++ b/src/mgl/bitmap.cpp @@ -48,6 +48,29 @@ static pixel_format_t gs_pixel_format_24 = static pixel_format_t gs_pixel_format_32 = {0xFF,0x18,0, 0xFF,0x10,0, 0xFF,0x08,0, 0xFF,0x00,0}; // RGBA 32bpp +static pixel_format_t gs_pixel_format_wxImage = + {0xFF,0x00,0, 0xFF,0x08,0, 0xFF,0x10,0, 0x00,0x00,0}; // RGB 24bpp for wxImage + +//----------------------------------------------------------------------------- +// helpers +//----------------------------------------------------------------------------- + +// Convert wxColour into it's quantized value in lower-precision +// pixel format (needed for masking by colour). +static wxColour wxQuantizeColour(const wxColour& clr, const wxBitmap& bmp) +{ + pixel_format_t *pf = bmp.GetMGLbitmap_t()->pf; + + if ( pf->redAdjust == 0 && pf->greenAdjust == 0 && pf->blueAdjust == 0 ) + return clr; + else + return wxColour((clr.Red() >> pf->redAdjust) << pf->redAdjust, + (clr.Green() >> pf->greenAdjust) << pf->greenAdjust, + (clr.Blue() >> pf->blueAdjust) << pf->blueAdjust); +} + + + //----------------------------------------------------------------------------- // wxMask //----------------------------------------------------------------------------- @@ -86,11 +109,14 @@ bool wxMask::Create(const wxBitmap& bitmap, const wxColour& colour) { delete m_bitmap; m_bitmap = NULL; + + wxColour clr(wxQuantizeColour(colour, bitmap)); - wxImage image = bitmap.ConvertToImage().ConvertToMono( - colour.Red(), colour.Green(), colour.Blue()); + wxImage imgSrc(bitmap.ConvertToImage()); + imgSrc.SetMask(FALSE); + wxImage image(imgSrc.ConvertToMono(clr.Red(), clr.Green(), clr.Blue())); if ( !image.Ok() ) return FALSE; - + m_bitmap = new wxBitmap(image, 1); return m_bitmap->Ok(); @@ -275,7 +301,7 @@ wxBitmap::wxBitmap(const wxImage& image, int depth = -1) if ( !Create(width, height, depth) ) return; - MGLMemoryDC idc(width, height, 24, &gs_pixel_format_24, + MGLMemoryDC idc(width, height, 24, &gs_pixel_format_wxImage, width * 3, (void*)image.GetData(), NULL); wxASSERT_MSG( idc.isValid(), wxT("cannot create custom MGLDC") ); @@ -309,7 +335,7 @@ wxImage wxBitmap::ConvertToImage() const wxImage image(width, height); wxASSERT_MSG( image.Ok(), wxT("cannot create image") ); - MGLMemoryDC idc(width, height, 24, &gs_pixel_format_24, + MGLMemoryDC idc(width, height, 24, &gs_pixel_format_wxImage, width * 3, (void*)image.GetData(), NULL); wxASSERT_MSG( idc.isValid(), wxT("cannot create custom MGLDC") );