X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4ca64d4137439844a5e6c95b4da16f32cf7840ab..cbbb1f548962b30c43849e29fd64eceb4d8720e8:/src/dfb/overlay.cpp diff --git a/src/dfb/overlay.cpp b/src/dfb/overlay.cpp index 56f3dfb5f1..cee282298a 100644 --- a/src/dfb/overlay.cpp +++ b/src/dfb/overlay.cpp @@ -23,7 +23,13 @@ #pragma hdrstop #endif +#ifndef WX_PRECOMP + #include "wx/window.h" + #include "wx/dcclient.h" +#endif + #include "wx/private/overlay.h" +#include "wx/dfb/dcclient.h" #include "wx/dfb/private.h" // ============================================================================ @@ -50,10 +56,14 @@ bool wxOverlayImpl::IsOk() return m_window != NULL; } -void wxOverlayImpl::Init(wxWindowDC *dc, int x, int y, int width, int height) +void wxOverlayImpl::Init(wxDC *dc, int x, int y, int width, int height) { + wxCHECK_RET( dc, "NULL dc pointer" ); wxASSERT_MSG( !IsOk() , _("You cannot Init an overlay twice") ); + wxDFBDCImpl * const dcimpl = wxDynamicCast(dc->GetImpl(), wxDFBDCImpl); + wxCHECK_RET( dcimpl, "must have a DFB wxDC" ); + m_window = dc->GetWindow(); m_rect = wxRect(x, y, width, height); @@ -61,18 +71,22 @@ void wxOverlayImpl::Init(wxWindowDC *dc, int x, int y, int width, int height) m_rect.Offset(m_window->GetClientAreaOrigin()); // FIXME: create surface with transparency or key color (?) - m_surface = - dc->GetDirectFBSurface()->CreateCompatible - ( - m_rect.GetSize(), - wxIDirectFBSurface::CreateCompatible_NoBackBuffer - ); + m_surface = dcimpl->GetDirectFBSurface()->CreateCompatible + ( + m_rect.GetSize(), + wxIDirectFBSurface::CreateCompatible_NoBackBuffer + ); m_window->AddOverlay(this); } -void wxOverlayImpl::BeginDrawing(wxWindowDC *dc) +void wxOverlayImpl::BeginDrawing(wxDC *dc) { + wxCHECK_RET( dc, "NULL dc pointer" ); + + wxWindowDCImpl * const + dcimpl = static_cast(dc->GetImpl()); + wxPoint origin(m_rect.GetPosition()); if ( wxDynamicCast(dc, wxClientDC) ) origin -= m_window->GetClientAreaOrigin(); @@ -81,22 +95,22 @@ void wxOverlayImpl::BeginDrawing(wxWindowDC *dc) // another DC, so we have to change the DC to draw on the overlay's surface. // Setting m_shouldFlip is done to avoid flipping and drawing of overlays // in ~wxWindowDC (we do it EndDrawing). - dc->DFBInit(m_surface); + dcimpl->DFBInit(m_surface); + dcimpl->m_shouldFlip = false; dc->SetDeviceOrigin(-origin.x, -origin.y); - dc->m_shouldFlip = false; m_isEmpty = false; } -void wxOverlayImpl::EndDrawing(wxWindowDC *dc) +void wxOverlayImpl::EndDrawing(wxDC *WXUNUSED(dc)) { m_window->RefreshWindowRect(m_rect); } -void wxOverlayImpl::Clear(wxWindowDC *dc) +void wxOverlayImpl::Clear(wxDC *WXUNUSED(dc)) { wxASSERT_MSG( IsOk(), - _T("You cannot Clear an overlay that is not initialized") ); + "You cannot Clear an overlay that is not initialized" ); m_isEmpty = true; }