#include "wx/image.h"
#endif
+#include "wx/os2/dc.h"
#include "wx/os2/private.h"
#include "wx/xpmdecod.h"
if (tocopy.m_pBitmapMask)
m_pBitmapMask = new wxMask(*tocopy.m_pBitmapMask);
- // TODO: how to copy an HBITMAP?
- m_hBitmap = tocopy.m_hBitmap;
+ m_hBitmap = wxCopyBmp(tocopy.m_hBitmap);
}
void wxBitmapRefData::Free()
// wxBitmap creation
// ----------------------------------------------------------------------------
-wxObjectRefData* wxBitmap::CreateRefData() const
-{
- return new wxBitmapRefData;
-}
-
-wxObjectRefData* wxBitmap::CloneRefData(const wxObjectRefData* data) const
+wxGDIRefData* wxBitmap::CloneGDIRefData(const wxGDIRefData* data) const
{
return new wxBitmapRefData(*wx_static_cast(const wxBitmapRefData *, data));
}
//
// May already be selected into a PS
//
- if ((pDC = GetSelectedInto()) != NULL)
+ pDC = GetSelectedInto();
+ const wxPMDCImpl *impl;
+ if (pDC != NULL &&
+ (impl = wxDynamicCast( pDC->GetImpl(), wxPMDCImpl )) != NULL)
{
- hPSMem = pDC->GetHPS();
+ hPSMem = impl->GetHPS();
}
else
{
wxMask::wxMask(const wxMask& tocopy)
{
- // TODO: how to copy a WXHBITMAP?
- m_hMaskBitmap = tocopy.m_hMaskBitmap;
+ m_hMaskBitmap = wxCopyBmp(tocopy.m_hMaskBitmap);
} // end of wxMask::wxMask
// Construct a mask from a bitmap and a colour indicating
return hBmpInvMask;
} // end of WxWinGdi_InvertMask
-HBITMAP wxFlipBmp( HBITMAP hBmp, int nWidth, int nHeight )
+HBITMAP wxCopyBmp( HBITMAP hBmp, bool flip, int nWidth, int nHeight )
{
- wxCHECK_MSG( hBmp, 0, _T("invalid bitmap in wxFlipBmp") );
+ wxCHECK_MSG( hBmp, 0, _T("invalid bitmap in wxCopyBmp") );
//
// Get width/height from the bitmap if not given
{nWidth, 0},
{0, 0},
{nWidth, nHeight} };
-
+ if (!flip)
+ {
+ vPoint[0].y = 0;
+ vPoint[1].y = nHeight;
+ }
memset(&vBmih, '\0', 16);
vBmih.cbFix = 16;
vBmih.cx = nWidth;