X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4f37154e988c597e32a840e43783cf0b23e5f8b4..bb996f289574defb0ae4339ae8e46ff3cf6fa54c:/src/gtk/dcmemory.cpp?ds=sidebyside diff --git a/src/gtk/dcmemory.cpp b/src/gtk/dcmemory.cpp index 948f09826a..1933d5000b 100644 --- a/src/gtk/dcmemory.cpp +++ b/src/gtk/dcmemory.cpp @@ -10,65 +10,41 @@ // For compilers that support precompilation, includes "wx.h". #include "wx/wxprec.h" -#include "wx/dcmemory.h" +#include "wx/gtk/dcmemory.h" -#include #include //----------------------------------------------------------------------------- -// wxMemoryDC +// wxMemoryDCImpl //----------------------------------------------------------------------------- -#if wxUSE_NEW_DC -IMPLEMENT_ABSTRACT_CLASS(wxGTKMemoryImplDC, wxGTKWindowImplDC) -#else -IMPLEMENT_ABSTRACT_CLASS(wxMemoryDC,wxWindowDC) -#endif +IMPLEMENT_ABSTRACT_CLASS(wxMemoryDCImpl, wxWindowDCImpl) -#if wxUSE_NEW_DC -wxGTKMemoryImplDC::wxGTKMemoryImplDC( wxMemoryDC *owner ) - : wxGTKWindowImplDC( owner ) -{ - Init(); -} - -wxGTKMemoryImplDC::wxGTKMemoryImplDC( wxMemoryDC *owner, wxBitmap& bitmap) - : wxGTKWindowImplDC( owner ) -{ - Init(); - owner->SelectObject(bitmap); -} - -wxGTKMemoryImplDC::wxGTKMemoryImplDC( wxMemoryDC *owner, wxDC *WXUNUSED(dc) ) - : wxGTKWindowImplDC( owner ) +wxMemoryDCImpl::wxMemoryDCImpl( wxMemoryDC *owner ) + : wxWindowDCImpl( owner ) { Init(); } -#else -wxMemoryDC::wxMemoryDC() -{ - Init(); -} -wxMemoryDC::wxMemoryDC(wxBitmap& bitmap) -{ - Init(); - SelectObject(bitmap); +wxMemoryDCImpl::wxMemoryDCImpl( wxMemoryDC *owner, wxBitmap& bitmap) + : wxWindowDCImpl( owner ) +{ + Init(); + DoSelect(bitmap); } -wxMemoryDC::wxMemoryDC( wxDC *WXUNUSED(dc) ) - : wxWindowDC() +wxMemoryDCImpl::wxMemoryDCImpl( wxMemoryDC *owner, wxDC *WXUNUSED(dc) ) + : wxWindowDCImpl( owner ) { Init(); } -#endif -wxGTKMemoryImplDC::~wxGTKMemoryImplDC() +wxMemoryDCImpl::~wxMemoryDCImpl() { g_object_unref(m_context); } -void wxGTKMemoryImplDC::Init() +void wxMemoryDCImpl::Init() { m_ok = false; @@ -82,14 +58,14 @@ void wxGTKMemoryImplDC::Init() m_fontdesc = pango_font_description_copy( pango_context_get_font_description( m_context ) ); } -void wxGTKMemoryImplDC::DoSelect( const wxBitmap& bitmap ) +void wxMemoryDCImpl::DoSelect( const wxBitmap& bitmap ) { Destroy(); m_selected = bitmap; - if (m_selected.Ok()) + if (m_selected.IsOk()) { - m_window = m_selected.GetPixmap(); + m_gdkwindow = m_selected.GetPixmap(); m_selected.PurgeOtherRepresentations(wxBitmap::Pixmap); @@ -98,77 +74,69 @@ void wxGTKMemoryImplDC::DoSelect( const wxBitmap& bitmap ) else { m_ok = false; - m_window = (GdkWindow *) NULL; + m_gdkwindow = NULL; } } -void wxGTKMemoryImplDC::SetPen( const wxPen& penOrig ) +void wxMemoryDCImpl::SetPen( const wxPen& penOrig ) { wxPen pen( penOrig ); - if ( m_selected.Ok() && + if ( m_selected.IsOk() && m_selected.GetDepth() == 1 && (pen != *wxTRANSPARENT_PEN) ) { pen.SetColour( pen.GetColour() == *wxWHITE ? *wxBLACK : *wxWHITE ); } - wxGTKWindowImplDC::SetPen( pen ); + wxWindowDCImpl::SetPen( pen ); } -void wxGTKMemoryImplDC::SetBrush( const wxBrush& brushOrig ) +void wxMemoryDCImpl::SetBrush( const wxBrush& brushOrig ) { wxBrush brush( brushOrig ); - if ( m_selected.Ok() && + if ( m_selected.IsOk() && m_selected.GetDepth() == 1 && (brush != *wxTRANSPARENT_BRUSH) ) { brush.SetColour( brush.GetColour() == *wxWHITE ? *wxBLACK : *wxWHITE); } - wxGTKWindowImplDC::SetBrush( brush ); + wxWindowDCImpl::SetBrush( brush ); } -void wxGTKMemoryImplDC::SetBackground( const wxBrush& brushOrig ) +void wxMemoryDCImpl::SetBackground( const wxBrush& brushOrig ) { wxBrush brush(brushOrig); - if ( m_selected.Ok() && + if ( m_selected.IsOk() && m_selected.GetDepth() == 1 && (brush != *wxTRANSPARENT_BRUSH) ) { brush.SetColour( brush.GetColour() == *wxWHITE ? *wxBLACK : *wxWHITE ); } - wxGTKWindowImplDC::SetBackground( brush ); + wxWindowDCImpl::SetBackground( brush ); } -void wxGTKMemoryImplDC::SetTextForeground( const wxColour& col ) +void wxMemoryDCImpl::SetTextForeground( const wxColour& col ) { - if ( m_selected.Ok() && m_selected.GetDepth() == 1 ) - { - wxGTKWindowImplDC::SetTextForeground( col == *wxWHITE ? *wxBLACK : *wxWHITE); - } + if ( m_selected.IsOk() && m_selected.GetDepth() == 1 ) + wxWindowDCImpl::SetTextForeground( col == *wxWHITE ? *wxBLACK : *wxWHITE); else - { - wxGTKWindowImplDC::SetTextForeground( col ); - } + wxWindowDCImpl::SetTextForeground( col ); } -void wxGTKMemoryImplDC::SetTextBackground( const wxColour &col ) +void wxMemoryDCImpl::SetTextBackground( const wxColour &col ) { - if (m_selected.Ok() && m_selected.GetDepth() == 1) - { - wxGTKWindowImplDC::SetTextBackground( col == *wxWHITE ? *wxBLACK : *wxWHITE ); - } + if (m_selected.IsOk() && m_selected.GetDepth() == 1) + wxWindowDCImpl::SetTextBackground( col == *wxWHITE ? *wxBLACK : *wxWHITE ); else - { - wxGTKWindowImplDC::SetTextBackground( col ); - } + wxWindowDCImpl::SetTextBackground( col ); } -void wxGTKMemoryImplDC::DoGetSize( int *width, int *height ) const +void wxMemoryDCImpl::DoGetSize( int *width, int *height ) const { - if (m_selected.Ok()) + if (m_selected.IsOk()) { if (width) (*width) = m_selected.GetWidth(); if (height) (*height) = m_selected.GetHeight(); @@ -180,19 +148,24 @@ void wxGTKMemoryImplDC::DoGetSize( int *width, int *height ) const } } -wxBitmap wxGTKMemoryImplDC::DoGetAsBitmap(const wxRect *subrect) const +wxBitmap wxMemoryDCImpl::DoGetAsBitmap(const wxRect *subrect) const { wxBitmap bmp = GetSelectedBitmap(); return subrect ? bmp.GetSubBitmap(*subrect) : bmp; } -const wxBitmap& wxGTKMemoryImplDC::GetSelectedBitmap() const +const wxBitmap& wxMemoryDCImpl::GetSelectedBitmap() const { return m_selected; } -wxBitmap& wxGTKMemoryImplDC::GetSelectedBitmap() +wxBitmap& wxMemoryDCImpl::GetSelectedBitmap() { return m_selected; } +void* wxMemoryDCImpl::GetHandle() const +{ + const wxBitmap& bmp = GetSelectedBitmap(); + return bmp.GetPixmap(); +}