/////////////////////////////////////////////////////////////////////////////
// Name: brush.h
// Purpose: wxBrush class
-// Author: AUTHOR
+// Author: Stefan Csomor
// Modified by:
-// Created: ??/??/98
+// Created: 1998-01-01
// RCS-ID: $Id$
-// Copyright: (c) AUTHOR
-// Licence: wxWindows licence
+// Copyright: (c) Stefan Csomor
+// Licence: wxWindows licence
/////////////////////////////////////////////////////////////////////////////
#ifndef _WX_BRUSH_H_
#define _WX_BRUSH_H_
-#ifdef __GNUG__
+#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
#pragma interface "brush.h"
#endif
class WXDLLEXPORT wxBrush;
-class WXDLLEXPORT wxBrushRefData: public wxGDIRefData
+typedef enum
{
- friend class WXDLLEXPORT wxBrush;
-public:
- wxBrushRefData();
- wxBrushRefData(const wxBrushRefData& data);
- ~wxBrushRefData();
-
-protected:
- int m_style;
- wxBitmap m_stipple ;
- wxColour m_colour;
- bool m_isMacTheme ;
- ThemeBrush m_macThemeBrush ;
- bool m_isMacThemeBackground ;
- ThemeBackgroundKind m_macThemeBackground ;
-};
-
-#define M_BRUSHDATA ((wxBrushRefData *)m_refData)
+ kwxMacBrushColour ,
+ kwxMacBrushTheme ,
+ kwxMacBrushThemeBackground
+} wxMacBrushKind ;
// Brush
class WXDLLEXPORT wxBrush: public wxGDIObject
public:
wxBrush();
- wxBrush(ThemeBrush macThemeBrush ) ;
- wxBrush(const wxColour& col, int style);
+ wxBrush(short macThemeBrush ) ;
+ wxBrush(const wxColour& col, int style = wxSOLID);
wxBrush(const wxBitmap& stipple);
- inline wxBrush(const wxBrush& brush) { Ref(brush); }
+ wxBrush(const wxBrush& brush)
+ : wxGDIObject()
+ { Ref(brush); }
~wxBrush();
virtual void SetColour(const wxColour& col) ;
virtual void SetColour(unsigned char r, unsigned char g, unsigned char b) ;
virtual void SetStyle(int style) ;
virtual void SetStipple(const wxBitmap& stipple) ;
- virtual void SetMacTheme(ThemeBrush macThemeBrush) ;
- virtual void SetMacThemeBackground(ThemeBackgroundKind macThemeBackground ) ;
-
- inline wxBrush& operator = (const wxBrush& brush) { if (*this == brush) return (*this); Ref(brush); return *this; }
- inline bool operator == (const wxBrush& brush) { return m_refData == brush.m_refData; }
- inline bool operator != (const wxBrush& brush) { return m_refData != brush.m_refData; }
-
- inline bool IsMacTheme() const { return (M_BRUSHDATA ? M_BRUSHDATA->m_isMacTheme : false); };
- inline bool IsMacThemeBackground() const { return (M_BRUSHDATA ? M_BRUSHDATA->m_isMacThemeBackground : false); };
- inline ThemeBackgroundKind GetMacThemeBackground() const { return (M_BRUSHDATA ? ( M_BRUSHDATA->m_isMacThemeBackground ? M_BRUSHDATA->m_macThemeBackground : 0) : 0); };
- inline ThemeBrush GetMacTheme() const { return (M_BRUSHDATA ? ( M_BRUSHDATA->m_isMacTheme ? M_BRUSHDATA->m_macThemeBrush : kThemeBrushBlack) : kThemeBrushBlack); };
- inline wxColour& GetColour() const { return (M_BRUSHDATA ? M_BRUSHDATA->m_colour : wxNullColour); };
- inline int GetStyle() const { return (M_BRUSHDATA ? M_BRUSHDATA->m_style : 0); };
- inline wxBitmap *GetStipple() const { return (M_BRUSHDATA ? & M_BRUSHDATA->m_stipple : 0); };
+ virtual void SetMacTheme(short macThemeBrush) ;
+ virtual void SetMacThemeBackground(unsigned long macThemeBackground , WXRECTPTR extent) ;
+
+ wxBrush& operator = (const wxBrush& brush)
+ { if (*this == brush) return (*this); Ref(brush); return *this; }
+ bool operator == (const wxBrush& brush)
+ { return m_refData == brush.m_refData; }
+ bool operator != (const wxBrush& brush)
+ { return m_refData != brush.m_refData; }
+
+ wxMacBrushKind MacGetBrushKind() const ;
+
+ unsigned long GetMacThemeBackground(WXRECTPTR extent) const ;
+ short GetMacTheme() const ;
+ wxColour& GetColour() const ;
+ int GetStyle() const ;
+ wxBitmap *GetStipple() const ;
virtual bool Ok() const { return (m_refData != NULL) ; }