X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/6670f56440ae9209b3e2e51e06acf3bc5aaf1905..404b319a85dadd7decf7a5a5331020520031a41c:/src/os2/dcmemory.cpp?ds=sidebyside diff --git a/src/os2/dcmemory.cpp b/src/os2/dcmemory.cpp index 26e11bfe8d..64acc9f90d 100644 --- a/src/os2/dcmemory.cpp +++ b/src/os2/dcmemory.cpp @@ -1,5 +1,5 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: dcmemory.cpp +// Name: src/os2/dcmemory.cpp // Purpose: wxMemoryDC class // Author: David Webster // Modified by: @@ -12,39 +12,48 @@ // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" +#include "wx/dcmemory.h" +#include "wx/os2/dcmemory.h" + #ifndef WX_PRECOMP -#include "wx/utils.h" -#include "wx/app.h" -#include "wx/log.h" + #include "wx/utils.h" + #include "wx/app.h" + #include "wx/log.h" #endif #include "wx/os2/private.h" -#include "wx/dcmemory.h" - -IMPLEMENT_DYNAMIC_CLASS(wxMemoryDC, wxDC) +IMPLEMENT_ABSTRACT_CLASS(wxMemoryDCImpl, wxPMDCImpl) ///////////////////////////////////////////////////////////////////////////// // Memory DC ///////////////////////////////////////////////////////////////////////////// -wxMemoryDC::wxMemoryDC(void) +wxMemoryDCImpl::wxMemoryDCImpl( wxMemoryDC *owner ) + : wxPMDCImpl( owner ) { CreateCompatible(NULL); Init(); -} // end of wxMemoryDC::wxMemoryDC +} -wxMemoryDC::wxMemoryDC( - wxDC* pOldDC -) +wxMemoryDCImpl::wxMemoryDCImpl( wxMemoryDC *owner, wxBitmap& bitmap ) + : wxPMDCImpl( owner ) { - pOldDC->BeginDrawing(); + CreateCompatible(NULL); + Init(); + DoSelect(bitmap); +} + +wxMemoryDCImpl::wxMemoryDCImpl( wxMemoryDC *owner, wxDC *pOldDC) + : wxPMDCImpl( owner ) +{ + wxCHECK_RET( pOldDC, wxT("NULL dc in wxMemoryDC ctor") ); + CreateCompatible(pOldDC); - pOldDC->EndDrawing(); Init(); } // end of wxMemoryDC::wxMemoryDC -void wxMemoryDC::Init() +void wxMemoryDCImpl::Init() { if (m_ok) { @@ -58,7 +67,7 @@ void wxMemoryDC::Init() memset(&m_vRclPaint, 0, sizeof(m_vRclPaint)); } // end of wxMemoryDC::Init -bool wxMemoryDC::CreateCompatible( wxDC* WXUNUSED(pDC) ) +bool wxMemoryDCImpl::CreateCompatible( wxDC* WXUNUSED(pDC) ) { HDC hDC; HPS hPS; @@ -100,16 +109,16 @@ bool wxMemoryDC::CreateCompatible( wxDC* WXUNUSED(pDC) ) { m_hPS = NULLHANDLE; m_hDC = NULLHANDLE; - m_ok = FALSE; - m_bOwnsDC = FALSE; + m_ok = false; + m_bOwnsDC = false; } } else { m_hPS = NULLHANDLE; m_hDC = NULLHANDLE; - m_ok = FALSE; - m_bOwnsDC = FALSE; + m_ok = false; + m_bOwnsDC = false; } // @@ -120,7 +129,7 @@ bool wxMemoryDC::CreateCompatible( wxDC* WXUNUSED(pDC) ) return m_ok; } // end of wxMemoryDC::CreateCompatible -void wxMemoryDC::SelectObject( +void wxMemoryDCImpl::DoSelect( const wxBitmap& rBitmap ) { @@ -130,7 +139,7 @@ void wxMemoryDC::SelectObject( if (m_hOldBitmap) { ::GpiSetBitmap(m_hPS, NULLHANDLE); - if (m_vSelectedBitmap.Ok()) + if (m_vSelectedBitmap.IsOk()) { m_vSelectedBitmap.SetSelectedInto(NULL); m_vSelectedBitmap = wxNullBitmap; @@ -141,7 +150,7 @@ void wxMemoryDC::SelectObject( // Check for whether the bitmap is already selected into a device context // wxCHECK_RET( !rBitmap.GetSelectedInto() || - (rBitmap.GetSelectedInto() == this), + (rBitmap.GetSelectedInto() == GetOwner()), wxT("Bitmap is selected in another wxMemoryDC, delete the first wxMemoryDC or use SelectObject(NULL)") ); WXHBITMAP hBmp = rBitmap.GetHBITMAP(); @@ -167,6 +176,7 @@ void wxMemoryDC::SelectObject( ); m_vSelectedBitmap.SetSelectedInto(NULL); } + m_vSelectedBitmap = rBitmap; @@ -176,7 +186,7 @@ void wxMemoryDC::SelectObject( m_hOldBitmap = (WXHBITMAP)::GpiSetBitmap(m_hPS, NULLHANDLE); return; } - m_vSelectedBitmap.SetSelectedInto(this); + m_vSelectedBitmap.SetSelectedInto(GetOwner()); m_hOldBitmap = (WXHBITMAP)::GpiSetBitmap(m_hPS, (HBITMAP)hBmp); if (m_hOldBitmap == HBM_ERROR) @@ -186,12 +196,12 @@ void wxMemoryDC::SelectObject( } } // end of wxMemoryDC::SelectObject -void wxMemoryDC::DoGetSize( +void wxMemoryDCImpl::DoGetSize( int* pWidth , int* pHeight ) const { - if (!m_vSelectedBitmap.Ok()) + if (!m_vSelectedBitmap.IsOk()) { *pWidth = 0; *pHeight = 0;