X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/8bbe427f8e5a2078b266e282453595b5a634d35c..4efb5650d15789f9f409b963eb4f9f6de999b51e:/src/gtk/brush.cpp diff --git a/src/gtk/brush.cpp b/src/gtk/brush.cpp index 146a4d0d88..68d4d985f9 100644 --- a/src/gtk/brush.cpp +++ b/src/gtk/brush.cpp @@ -1,10 +1,10 @@ ///////////////////////////////////////////////////////////////////////////// -// Name: brush.cpp +// Name: src/gtk/brush.cpp // Purpose: // Author: Robert Roebling // Id: $Id$ // Copyright: (c) 1998 Robert Roebling -// Licence: wxWindows licence +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// #ifdef __GNUG__ @@ -13,14 +13,15 @@ #include "wx/brush.h" +#include + //----------------------------------------------------------------------------- // wxBrush //----------------------------------------------------------------------------- class wxBrushRefData: public wxObjectRefData { - public: - +public: wxBrushRefData(); wxBrushRefData( const wxBrushRefData& data ); @@ -31,14 +32,14 @@ class wxBrushRefData: public wxObjectRefData wxBrushRefData::wxBrushRefData() { - m_style = 0; + m_style = 0; } wxBrushRefData::wxBrushRefData( const wxBrushRefData& data ) { - m_style = data.m_style; - m_stipple = data.m_stipple; - m_colour = data.m_colour; + m_style = data.m_style; + m_stipple = data.m_stipple; + m_colour = data.m_colour; } //----------------------------------------------------------------------------- @@ -49,130 +50,136 @@ IMPLEMENT_DYNAMIC_CLASS(wxBrush,wxGDIObject) wxBrush::wxBrush() { - if (wxTheBrushList) wxTheBrushList->AddBrush( this ); } wxBrush::wxBrush( const wxColour &colour, int style ) { - m_refData = new wxBrushRefData(); - M_BRUSHDATA->m_style = style; - M_BRUSHDATA->m_colour = colour; - - if (wxTheBrushList) wxTheBrushList->AddBrush( this ); + m_refData = new wxBrushRefData(); + M_BRUSHDATA->m_style = style; + M_BRUSHDATA->m_colour = colour; } wxBrush::wxBrush( const wxBitmap &stippleBitmap ) { - m_refData = new wxBrushRefData(); - M_BRUSHDATA->m_style = wxSTIPPLE; - M_BRUSHDATA->m_colour = *wxBLACK; - M_BRUSHDATA->m_stipple = stippleBitmap; + m_refData = new wxBrushRefData(); + M_BRUSHDATA->m_colour = *wxBLACK; - if (wxTheBrushList) wxTheBrushList->AddBrush( this ); + M_BRUSHDATA->m_stipple = stippleBitmap; + + if (M_BRUSHDATA->m_stipple.GetMask()) + M_BRUSHDATA->m_style = wxSTIPPLE_MASK_OPAQUE; + else + M_BRUSHDATA->m_style = wxSTIPPLE; } wxBrush::wxBrush( const wxBrush &brush ) { - Ref( brush ); - - if (wxTheBrushList) wxTheBrushList->AddBrush( this ); + Ref( brush ); } wxBrush::~wxBrush() { - if (wxTheBrushList) wxTheBrushList->RemoveBrush( this ); } wxBrush& wxBrush::operator = ( const wxBrush& brush ) { - if (*this == brush) return (*this); - Ref( brush ); - return *this; + if ( m_refData != brush.m_refData ) + Ref( brush ); + + return *this; } -bool wxBrush::operator == ( const wxBrush& brush ) +bool wxBrush::operator == ( const wxBrush& brush ) const { - return m_refData == brush.m_refData; + return m_refData == brush.m_refData; } -bool wxBrush::operator != ( const wxBrush& brush ) +bool wxBrush::operator != ( const wxBrush& brush ) const { - return m_refData != brush.m_refData; + return m_refData != brush.m_refData; } bool wxBrush::Ok() const { - return ((m_refData) && M_BRUSHDATA->m_colour.Ok()); + return ((m_refData) && M_BRUSHDATA->m_colour.Ok()); } int wxBrush::GetStyle() const { - if (m_refData == NULL) - { - wxFAIL_MSG( "invalid brush" ); - return 0; - } + if (m_refData == NULL) + { + wxFAIL_MSG( wxT("invalid brush") ); + return 0; + } - return M_BRUSHDATA->m_style; + return M_BRUSHDATA->m_style; } wxColour &wxBrush::GetColour() const { - if (m_refData == NULL) - { - wxFAIL_MSG( "invalid brush" ); - return wxNullColour; - } + if (m_refData == NULL) + { + wxFAIL_MSG( wxT("invalid brush") ); + return wxNullColour; + } - return M_BRUSHDATA->m_colour; + return M_BRUSHDATA->m_colour; } wxBitmap *wxBrush::GetStipple() const { - if (m_refData == NULL) - { - wxFAIL_MSG( "invalid brush" ); - return &wxNullBitmap; - } + if (m_refData == NULL) + { + wxFAIL_MSG( wxT("invalid brush") ); + return &wxNullBitmap; + } - return &M_BRUSHDATA->m_stipple; + return &M_BRUSHDATA->m_stipple; } void wxBrush::SetColour( const wxColour& col ) { - Unshare(); - M_BRUSHDATA->m_colour = col; + Unshare(); + M_BRUSHDATA->m_colour = col; } void wxBrush::SetColour( unsigned char r, unsigned char g, unsigned char b ) { - Unshare(); - M_BRUSHDATA->m_colour.Set( r, g, b ); + Unshare(); + M_BRUSHDATA->m_colour.Set( r, g, b ); } void wxBrush::SetStyle( int style ) { - Unshare(); - M_BRUSHDATA->m_style = style; + Unshare(); + M_BRUSHDATA->m_style = style; } void wxBrush::SetStipple( const wxBitmap& stipple ) { - Unshare(); - M_BRUSHDATA->m_stipple = stipple; + Unshare(); + M_BRUSHDATA->m_stipple = stipple; + if (M_BRUSHDATA->m_stipple.GetMask()) + { + M_BRUSHDATA->m_style = wxSTIPPLE_MASK_OPAQUE; + } + else + { + M_BRUSHDATA->m_style = wxSTIPPLE; + } } void wxBrush::Unshare() { - if (!m_refData) - { - m_refData = new wxBrushRefData(); - } - else - { - wxBrushRefData* ref = new wxBrushRefData( *(wxBrushRefData*)m_refData ); - UnRef(); - m_refData = ref; - } + if (!m_refData) + { + m_refData = new wxBrushRefData(); + } + else + { + wxBrushRefData* ref = new wxBrushRefData( *(wxBrushRefData*)m_refData ); + UnRef(); + m_refData = ref; + } }