X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/01111366c9b4ea40eee7f4b13ddfe6f6b9f886db..010d821b3138ae39c43403da64eb0bcde9af82ae:/src/gtk/brush.cpp diff --git a/src/gtk/brush.cpp b/src/gtk/brush.cpp index 29131bbede..2c29ba5cba 100644 --- a/src/gtk/brush.cpp +++ b/src/gtk/brush.cpp @@ -1,185 +1,159 @@ ///////////////////////////////////////////////////////////////////////////// -// 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__ -#pragma implementation "brush.h" -#endif +// For compilers that support precompilation, includes "wx.h". +#include "wx/wxprec.h" #include "wx/brush.h" +#ifndef WX_PRECOMP + #include "wx/bitmap.h" + #include "wx/colour.h" +#endif + //----------------------------------------------------------------------------- // wxBrush //----------------------------------------------------------------------------- -class wxBrushRefData: public wxObjectRefData -{ - public: - - wxBrushRefData(void); - wxBrushRefData( const wxBrushRefData& data ); - - int m_style; - wxBitmap m_stipple; - wxColour m_colour; +class wxBrushRefData: public wxGDIRefData +{ +public: + wxBrushRefData(const wxColour& colour = wxNullColour, wxBrushStyle style = wxBRUSHSTYLE_SOLID) + { + m_style = style; + m_colour = colour; + } + + wxBrushRefData( const wxBrushRefData& data ) + : wxGDIRefData() + { + m_style = data.m_style; + m_stipple = data.m_stipple; + m_colour = data.m_colour; + } + + bool operator == (const wxBrushRefData& data) const + { + return (m_style == data.m_style && + m_stipple.IsSameAs(data.m_stipple) && + m_colour == data.m_colour); + } + + wxBrushStyle m_style; + wxColour m_colour; + wxBitmap m_stipple; }; -wxBrushRefData::wxBrushRefData(void) -{ - m_style = 0; -} - -wxBrushRefData::wxBrushRefData( const wxBrushRefData& data ) -{ - m_style = data.m_style; - m_stipple = data.m_stipple; - m_colour = data.m_colour; -} - //----------------------------------------------------------------------------- #define M_BRUSHDATA ((wxBrushRefData *)m_refData) IMPLEMENT_DYNAMIC_CLASS(wxBrush,wxGDIObject) -wxBrush::wxBrush(void) +wxBrush::wxBrush( const wxColour &colour, wxBrushStyle style ) { - if (wxTheBrushList) wxTheBrushList->AddBrush( this ); + m_refData = new wxBrushRefData(colour, style); } -wxBrush::wxBrush( const wxColour &colour, int style ) +#if FUTURE_WXWIN_COMPATIBILITY_3_0 +wxBrush::wxBrush(const wxColour& col, 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(col, (wxBrushStyle)style); } +#endif wxBrush::wxBrush( const wxBitmap &stippleBitmap ) { - m_refData = new wxBrushRefData(); - M_BRUSHDATA->m_style = wxSTIPPLE; - M_BRUSHDATA->m_colour = *wxBLACK; - M_BRUSHDATA->m_stipple = stippleBitmap; - - if (wxTheBrushList) wxTheBrushList->AddBrush( this ); -} + wxBrushStyle style = wxBRUSHSTYLE_STIPPLE; + if (stippleBitmap.GetMask()) + style = wxBRUSHSTYLE_STIPPLE_MASK_OPAQUE; -wxBrush::wxBrush( const wxBrush &brush ) -{ - Ref( brush ); - - if (wxTheBrushList) wxTheBrushList->AddBrush( this ); + m_refData = new wxBrushRefData(*wxBLACK, style); + M_BRUSHDATA->m_stipple = stippleBitmap; } -wxBrush::wxBrush( const wxBrush *brush ) +wxBrush::~wxBrush() { - if (brush) Ref( *brush ); - - if (wxTheBrushList) wxTheBrushList->Append( this ); + // m_refData unrefed in ~wxObject } -wxBrush::~wxBrush(void) +wxGDIRefData *wxBrush::CreateGDIRefData() const { - if (wxTheBrushList) wxTheBrushList->RemoveBrush( this ); + return new wxBrushRefData; } -wxBrush& wxBrush::operator = ( const wxBrush& brush ) +wxGDIRefData *wxBrush::CloneGDIRefData(const wxGDIRefData *data) const { - if (*this == brush) return (*this); - Ref( brush ); - return *this; -} - -bool wxBrush::operator == ( const wxBrush& brush ) -{ - return m_refData == brush.m_refData; + return new wxBrushRefData(*(wxBrushRefData *)data); } -bool wxBrush::operator != ( const wxBrush& brush ) +bool wxBrush::operator==(const wxBrush& brush) const { - return m_refData != brush.m_refData; -} + if (m_refData == brush.m_refData) return true; -bool wxBrush::Ok(void) const -{ - return ((m_refData) && M_BRUSHDATA->m_colour.Ok()); + if (!m_refData || !brush.m_refData) return false; + + return ( *(wxBrushRefData*)m_refData == *(wxBrushRefData*)brush.m_refData ); } -int wxBrush::GetStyle(void) const +wxBrushStyle wxBrush::GetStyle() const { - if (m_refData == NULL) - { - wxFAIL_MSG( "invalid brush" ); - return 0; - } + wxCHECK_MSG( IsOk(), wxBRUSHSTYLE_INVALID, wxT("invalid brush") ); - return M_BRUSHDATA->m_style; + return M_BRUSHDATA->m_style; } -wxColour &wxBrush::GetColour(void) const +wxColour wxBrush::GetColour() const { - if (m_refData == NULL) - { - wxFAIL_MSG( "invalid brush" ); - return wxNullColour; - } - - return M_BRUSHDATA->m_colour; + wxCHECK_MSG( IsOk(), wxNullColour, wxT("invalid brush") ); + + return M_BRUSHDATA->m_colour; } -wxBitmap *wxBrush::GetStipple(void) const +wxBitmap *wxBrush::GetStipple() const { - if (m_refData == NULL) - { - wxFAIL_MSG( "invalid brush" ); - return &wxNullBitmap; - } - - return &M_BRUSHDATA->m_stipple; + wxCHECK_MSG( IsOk(), NULL, wxT("invalid brush") ); + + return &M_BRUSHDATA->m_stipple; } void wxBrush::SetColour( const wxColour& col ) { - Unshare(); - M_BRUSHDATA->m_colour = col; + AllocExclusive(); + + 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 ); + AllocExclusive(); + + M_BRUSHDATA->m_colour.Set( r, g, b ); } -void wxBrush::SetStyle( int style ) +void wxBrush::SetStyle( wxBrushStyle style ) { - Unshare(); - M_BRUSHDATA->m_style = style; + AllocExclusive(); + + M_BRUSHDATA->m_style = style; } void wxBrush::SetStipple( const wxBitmap& stipple ) { - Unshare(); - M_BRUSHDATA->m_stipple = stipple; -} + AllocExclusive(); -void wxBrush::Unshare(void) -{ - if (!m_refData) - { - m_refData = new wxBrushRefData(); - } - else - { - wxBrushRefData* ref = new wxBrushRefData( *(wxBrushRefData*)m_refData ); - UnRef(); - m_refData = ref; - } + M_BRUSHDATA->m_stipple = stipple; + if (M_BRUSHDATA->m_stipple.GetMask()) + { + M_BRUSHDATA->m_style = wxBRUSHSTYLE_STIPPLE_MASK_OPAQUE; + } + else + { + M_BRUSHDATA->m_style = wxBRUSHSTYLE_STIPPLE; + } } -