X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f38924e863cd44e2abd49d20d201d72aa773c51e..0d0b1695e01f1572540e79cbb7bd360c1f2d5979:/src/msw/dcmemory.cpp diff --git a/src/msw/dcmemory.cpp b/src/msw/dcmemory.cpp index e68fe93b10..6869e6f4e4 100644 --- a/src/msw/dcmemory.cpp +++ b/src/msw/dcmemory.cpp @@ -25,6 +25,7 @@ #endif #include "wx/dcmemory.h" +#include "wx/msw/dcmemory.h" #ifndef WX_PRECOMP #include "wx/utils.h" @@ -34,27 +35,28 @@ #include "wx/msw/private.h" // ---------------------------------------------------------------------------- -// wxWin macros +// wxMemoryDCImpl // ---------------------------------------------------------------------------- -IMPLEMENT_DYNAMIC_CLASS(wxMemoryDC, wxDC) +IMPLEMENT_ABSTRACT_CLASS(wxMemoryDCImpl, wxMSWDCImpl) -// ============================================================================ -// implementation -// ============================================================================ - -// ---------------------------------------------------------------------------- -// wxMemoryDC -// ---------------------------------------------------------------------------- - -wxMemoryDC::wxMemoryDC() +wxMemoryDCImpl::wxMemoryDCImpl( wxMemoryDC *owner ) + : wxMSWDCImpl( owner ) { - CreateCompatible(NULL); + CreateCompatible(NULL); + Init(); +} - Init(); +wxMemoryDCImpl::wxMemoryDCImpl( wxMemoryDC *owner, wxBitmap& bitmap ) + : wxMSWDCImpl( owner ) +{ + CreateCompatible(NULL); + Init(); + DoSelect(bitmap); } -wxMemoryDC::wxMemoryDC(wxDC *dc) +wxMemoryDCImpl::wxMemoryDCImpl( wxMemoryDC *owner, wxDC *dc ) + : wxMSWDCImpl( owner ) { wxCHECK_RET( dc, _T("NULL dc in wxMemoryDC ctor") ); @@ -63,7 +65,7 @@ wxMemoryDC::wxMemoryDC(wxDC *dc) Init(); } -void wxMemoryDC::Init() +void wxMemoryDCImpl::Init() { if ( m_ok ) { @@ -76,9 +78,17 @@ void wxMemoryDC::Init() } } -bool wxMemoryDC::CreateCompatible(wxDC *dc) +bool wxMemoryDCImpl::CreateCompatible(wxDC *dc) { - m_hDC = (WXHDC)::CreateCompatibleDC(dc ? GetHdcOf(*dc) : NULL); + wxDCImpl *impl = dc ? dc->GetImpl() : NULL ; + wxMSWDCImpl *msw_impl = wxDynamicCast( impl, wxMSWDCImpl ); + if ( dc && !msw_impl) + { + m_ok = false; + return false; + } + + m_hDC = (WXHDC)::CreateCompatibleDC(dc ? GetHdcOf(*msw_impl) : NULL); // as we created the DC, we must delete it in the dtor m_bOwnsDC = true; @@ -88,7 +98,7 @@ bool wxMemoryDC::CreateCompatible(wxDC *dc) return m_ok; } -void wxMemoryDC::SelectObject(const wxBitmap& bitmap) +void wxMemoryDCImpl::DoSelect( const wxBitmap& bitmap ) { // select old bitmap out of the device context if ( m_oldBitmap ) @@ -105,7 +115,7 @@ void wxMemoryDC::SelectObject(const wxBitmap& bitmap) // check for whether the bitmap is already selected into a device context wxASSERT_MSG( !bitmap.GetSelectedInto() || - (bitmap.GetSelectedInto() == this), + (bitmap.GetSelectedInto() == GetOwner()), wxT("Bitmap is selected in another wxMemoryDC, delete the first wxMemoryDC or use SelectObject(NULL)") ); m_selectedBitmap = bitmap; @@ -114,7 +124,7 @@ void wxMemoryDC::SelectObject(const wxBitmap& bitmap) return; #ifdef __WXDEBUG__ - m_selectedBitmap.SetSelectedInto(this); + m_selectedBitmap.SetSelectedInto(GetOwner()); #endif hBmp = (WXHBITMAP)::SelectObject(GetHdc(), (HBITMAP)hBmp); @@ -130,7 +140,7 @@ void wxMemoryDC::SelectObject(const wxBitmap& bitmap) } } -void wxMemoryDC::DoGetSize(int *width, int *height) const +void wxMemoryDCImpl::DoGetSize(int *width, int *height) const { if ( m_selectedBitmap.Ok() ) { @@ -181,7 +191,7 @@ static void wxDrawRectangle(wxDC& dc, wxCoord x, wxCoord y, wxCoord width, wxCoo #endif // wxUSE_MEMORY_DC_DRAW_RECTANGLE -void wxMemoryDC::DoDrawRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord height) +void wxMemoryDCImpl::DoDrawRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord height) { // Set this to 1 to work around an apparent video driver bug // (visible with e.g. 70x70 rectangle on a memory DC; see Drawing sample) @@ -196,6 +206,6 @@ void wxMemoryDC::DoDrawRectangle(wxCoord x, wxCoord y, wxCoord width, wxCoord he else #endif // wxUSE_MEMORY_DC_DRAW_RECTANGLE { - wxDC::DoDrawRectangle(x, y, width, height); + wxMSWDCImpl::DoDrawRectangle(x, y, width, height); } }