X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f98bd6d6cf33f0475b5d737a2968b42b7ea0009f..52170c5b4419c63d6e0083df411aad420395ec98:/include/wx/gtk/dcmemory.h diff --git a/include/wx/gtk/dcmemory.h b/include/wx/gtk/dcmemory.h index b4e6be4c82..d165b61768 100644 --- a/include/wx/gtk/dcmemory.h +++ b/include/wx/gtk/dcmemory.h @@ -7,29 +7,36 @@ // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifndef __GTKDCMEMORYH__ -#define __GTKDCMEMORYH__ +#ifndef _WX_GTK_DCMEMORY_H_ +#define _WX_GTK_DCMEMORY_H_ -#include "wx/defs.h" #include "wx/dcclient.h" -//----------------------------------------------------------------------------- -// classes -//----------------------------------------------------------------------------- - -class WXDLLIMPEXP_CORE wxMemoryDC; - //----------------------------------------------------------------------------- // wxMemoryDC //----------------------------------------------------------------------------- -class WXDLLIMPEXP_CORE wxMemoryDC : public wxWindowDC + +#if wxUSE_NEW_DC +class WXDLLIMPEXP_CORE wxGTKMemoryImplDC : public wxGTKWindowImplDC, public wxMemoryImplDCBase +#else +#define wxGTKMemoryImplDC wxMemoryDC +class WXDLLIMPEXP_CORE wxMemoryDC : public wxWindowDC, public wxMemoryDCBase +#endif { public: + +#if wxUSE_NEW_DC + wxGTKMemoryImplDC( wxMemoryDC *owner ); + wxGTKMemoryImplDC( wxMemoryDC *owner, wxBitmap& bitmap ); + wxGTKMemoryImplDC( wxMemoryDC *owner, wxDC *dc ); +#else wxMemoryDC(); - wxMemoryDC( wxDC *dc ); // Create compatible DC - virtual ~wxMemoryDC(); - virtual void SelectObject( const wxBitmap& bitmap ); + wxMemoryDC(wxBitmap& bitmap); + wxMemoryDC( wxDC *dc ); +#endif + + virtual ~wxGTKMemoryImplDC(); // these get reimplemented for mono-bitmaps to behave // more like their Win32 couterparts. They now interpret @@ -42,15 +49,24 @@ public: virtual void SetTextBackground( const wxColour &col ); // implementation - virtual wxBitmap GetSelectedBitmap() const { return m_selected; } - wxBitmap m_selected; + wxBitmap GetSelectedBitmap() const { return m_selected; } protected: - void DoGetSize( int *width, int *height ) const; + // overridden from wxImplDC + virtual void DoGetSize( int *width, int *height ) const; + virtual wxBitmap DoGetAsBitmap(const wxRect *subrect) const; - DECLARE_DYNAMIC_CLASS(wxMemoryDC) -}; + // overridden from wxMemoryImplDCBase + virtual void DoSelect(const wxBitmap& bitmap); + virtual const wxBitmap& DoGetSelectedBitmap() const; + virtual wxBitmap& DoGetSelectedBitmap(); -#endif - // __GTKDCMEMORYH__ + wxBitmap m_selected; + +private: + void Init(); + + DECLARE_ABSTRACT_CLASS(wxGTKMemoryImplDC) +}; +#endif // _WX_GTK_DCMEMORY_H_