made wxNativePixelFormat usable under Mac
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@20917 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -120,7 +120,7 @@ struct WXDLLEXPORT wxPixelFormat
|
||||
enum { BitsPerPixel = Bpp };
|
||||
|
||||
// size of one pixel in ChannelType units (usually bytes)
|
||||
enum { SizePixel = BitsPerPixel / (8 * sizeof(ChannelType)) };
|
||||
enum { SizePixel = Bpp / (8 * sizeof(Channel)) };
|
||||
|
||||
// the channels indices inside the pixel
|
||||
enum
|
||||
@@ -143,29 +143,27 @@ struct WXDLLEXPORT wxPixelFormat
|
||||
typedef wxPixelFormat<unsigned char, 24, 0, 1, 2> wxImagePixelFormat;
|
||||
|
||||
// the (most common) native bitmap format without alpha support
|
||||
typedef wxPixelFormat<unsigned char, 24,
|
||||
#if defined(__WXMSW__)
|
||||
2, 1, 0
|
||||
// under MSW the RGB components are inversed, they're in BGR order
|
||||
typedef wxPixelFormat<unsigned char, 24, 2, 1, 0> wxNativePixelFormat;
|
||||
|
||||
#define wxPIXEL_FORMAT_ALPHA 3
|
||||
#elif defined(__WXMAC__)
|
||||
1, 2, 3
|
||||
#else // default for the others (not supported anyhow)
|
||||
0, 1, 2
|
||||
#endif // platform
|
||||
> wxNativePixelFormat;
|
||||
// under Mac, first component is unused but still present, hence we use
|
||||
// 32bpp, not 24
|
||||
typedef wxPixelFormat<unsigned char, 32, 1, 2, 3> wxNativePixelFormat;
|
||||
|
||||
#define wxPIXEL_FORMAT_ALPHA 0
|
||||
#endif
|
||||
|
||||
// the (most common) native format for bitmaps with alpha channel
|
||||
#ifdef wxPIXEL_FORMAT_ALPHA
|
||||
typedef wxPixelFormat<unsigned char, 32,
|
||||
wxNativePixelFormat::RED,
|
||||
wxNativePixelFormat::GREEN,
|
||||
wxNativePixelFormat::BLUE,
|
||||
#if defined(__WXMSW__)
|
||||
3
|
||||
#elif defined(__WXMAC__)
|
||||
0
|
||||
#else // default for the others (not supported anyhow)
|
||||
3
|
||||
#endif // platform
|
||||
> wxAlphaPixelFormat;
|
||||
wxPIXEL_FORMAT_ALPHA> wxAlphaPixelFormat;
|
||||
#endif // wxPIXEL_FORMAT_ALPHA
|
||||
|
||||
// we also define the (default/best) pixel format for the given class: this is
|
||||
// used as default value for the pixel format in wxPixelIterator template
|
||||
|
@@ -1349,14 +1349,11 @@ void *wxBitmap::GetRawData(wxPixelDataBase& data, int bpp)
|
||||
|
||||
GWorldPtr gworld = MAC_WXHBITMAP(M_BITMAPDATA->m_hBitmap);
|
||||
PixMapHandle hPixMap = GetGWorldPixMap(gworld);
|
||||
wxCHECK_MSG( hPixMap, NULL, _T("failed to get PixMap from GWorld?") );
|
||||
wxCHECK_MSG( hPixMap && *hPixMap, NULL,
|
||||
_T("GetRawData(): failed to get PixMap from GWorld?") );
|
||||
|
||||
if ( (*hPixMap)->pixelSize != bpp )
|
||||
{
|
||||
wxFAIL_MSG( _T("bpp mismatch in GetRawData()") );
|
||||
|
||||
return NULL;
|
||||
}
|
||||
wxCHECK_MSG( (*hPixMap)->pixelSize == bpp, NULL,
|
||||
_T("GetRawData(): pixel format mismatch") );
|
||||
|
||||
if ( !LockPixels(hPixMap) )
|
||||
{
|
||||
|
@@ -1349,14 +1349,11 @@ void *wxBitmap::GetRawData(wxPixelDataBase& data, int bpp)
|
||||
|
||||
GWorldPtr gworld = MAC_WXHBITMAP(M_BITMAPDATA->m_hBitmap);
|
||||
PixMapHandle hPixMap = GetGWorldPixMap(gworld);
|
||||
wxCHECK_MSG( hPixMap, NULL, _T("failed to get PixMap from GWorld?") );
|
||||
wxCHECK_MSG( hPixMap && *hPixMap, NULL,
|
||||
_T("GetRawData(): failed to get PixMap from GWorld?") );
|
||||
|
||||
if ( (*hPixMap)->pixelSize != bpp )
|
||||
{
|
||||
wxFAIL_MSG( _T("bpp mismatch in GetRawData()") );
|
||||
|
||||
return NULL;
|
||||
}
|
||||
wxCHECK_MSG( (*hPixMap)->pixelSize == bpp, NULL,
|
||||
_T("GetRawData(): pixel format mismatch") );
|
||||
|
||||
if ( !LockPixels(hPixMap) )
|
||||
{
|
||||
|
Reference in New Issue
Block a user