X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/32b8ec418aee4e38877d4cb79e2984c766dcc358..dbcbe229628c7667da2b6257198467d4f09ab28d:/src/mgl/dcclient.cpp diff --git a/src/mgl/dcclient.cpp b/src/mgl/dcclient.cpp index c0e73aabc0..8edae04c3b 100644 --- a/src/mgl/dcclient.cpp +++ b/src/mgl/dcclient.cpp @@ -1,9 +1,9 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: gtk/dcclient.cpp +// Name: dcclient.cpp // Purpose: -// Author: Robert Roebling +// Author: Vaclav Slavik // RCS-ID: $Id$ -// Copyright: (c) 1998 Robert Roebling, Markus Holzem, Chris Breeze +// Copyright: (c) 2001 SciTech Software, Inc. (www.scitechsoft.com) // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// @@ -11,9 +11,61 @@ #pragma implementation "dcclient.h" #endif -#include "wx/dcclient.h" -#include "wx/dcmemory.h" +// For compilers that support precompilation, includes "wx.h". +#include "wx/wxprec.h" + +#ifdef __BORLANDC__ + #pragma hdrstop +#endif + +#ifndef WX_PRECOMP + #include "wx/dcclient.h" + #include "wx/window.h" +#endif + +#include IMPLEMENT_DYNAMIC_CLASS(wxWindowDC, wxDC) -IMPLEMENT_DYNAMIC_CLASS(wxPaintDC, wxClientDC) IMPLEMENT_DYNAMIC_CLASS(wxClientDC,wxWindowDC) +IMPLEMENT_DYNAMIC_CLASS(wxPaintDC, wxClientDC) + +wxWindowDC::wxWindowDC(wxWindow *win) : m_wnd(win) +{ + MGLDevCtx *dc = win->GetPaintMGLDC(); + if ( dc ) + { + m_inPaintHandler = TRUE; + SetMGLDC(dc, FALSE); + } + else + { + m_inPaintHandler = FALSE; + SetMGLDC(new MGLDevCtx(MGL_wmBeginPaint(m_wnd->GetHandle())), TRUE); + // TRUE means that dtor will delete MGLDevCtx object + // but it won't destroy MGLDC returned by MGL_wmBeginPaint because + // ~MGLDevCtx() doesn't call destroy() + } +} + +wxWindowDC::~wxWindowDC() +{ + if ( m_inPaintHandler ) + { + // This is neccessary so that subsequently created wxPaintDCs won't get + // confused about clipping. Another reason is that the same MGL dc is reused + // for wxEraseEvent, wxNcPaintEvent and wxPaintEvent + DestroyClippingRegion(); + } + else + { + GetMGLDC()->setDC(NULL); + MGL_wmEndPaint(m_wnd->GetHandle()); + } +} + +wxClientDC::wxClientDC(wxWindow *win) : wxWindowDC(win) +{ + wxRect r = m_wnd->GetClientRect(); + SetClippingRegion(r); + SetDeviceOrigin(r.x, r.y); +}