]> git.saurik.com Git - wxWidgets.git/blame_incremental - src/gtk1/pen.cpp
#ifdefed out Ole... functions for Cygwin.
[wxWidgets.git] / src / gtk1 / pen.cpp
... / ...
CommitLineData
1/////////////////////////////////////////////////////////////////////////////
2// Name: pen.cpp
3// Purpose:
4// Author: Robert Roebling
5// Id: $Id$
6// Copyright: (c) 1998 Robert Roebling
7// Licence: wxWindows licence
8/////////////////////////////////////////////////////////////////////////////
9
10
11#ifdef __GNUG__
12#pragma implementation "pen.h"
13#endif
14
15#include "wx/pen.h"
16
17//-----------------------------------------------------------------------------
18// wxPen
19//-----------------------------------------------------------------------------
20
21class wxPenRefData: public wxObjectRefData
22{
23public:
24
25 wxPenRefData(void);
26 wxPenRefData(const wxPenRefData& data);
27
28 int m_width;
29 int m_style;
30 int m_joinStyle;
31 int m_capStyle;
32 wxColour m_colour;
33};
34
35wxPenRefData::wxPenRefData()
36{
37 m_width = 1;
38 m_style = wxSOLID;
39 m_joinStyle = wxJOIN_ROUND;
40 m_capStyle = wxCAP_ROUND;
41}
42
43wxPenRefData::wxPenRefData( const wxPenRefData& data )
44{
45 m_style = data.m_style;
46 m_width = data.m_width;
47 m_joinStyle = data.m_joinStyle;
48 m_capStyle = data.m_capStyle;
49 m_colour = data.m_colour;
50}
51
52//-----------------------------------------------------------------------------
53
54#define M_PENDATA ((wxPenRefData *)m_refData)
55
56IMPLEMENT_DYNAMIC_CLASS(wxPen,wxGDIObject)
57
58wxPen::wxPen()
59{
60 if (wxThePenList) wxThePenList->AddPen( this );
61}
62
63wxPen::wxPen( const wxColour &colour, int width, int style )
64{
65 m_refData = new wxPenRefData();
66 M_PENDATA->m_width = width;
67 M_PENDATA->m_style = style;
68 M_PENDATA->m_colour = colour;
69
70 if (wxThePenList) wxThePenList->AddPen( this );
71}
72
73wxPen::wxPen( const wxPen& pen )
74{
75 Ref( pen );
76 if (wxThePenList) wxThePenList->AddPen( this );
77}
78
79wxPen::~wxPen()
80{
81 if (wxThePenList) wxThePenList->RemovePen( this );
82}
83
84wxPen& wxPen::operator = ( const wxPen& pen )
85{
86 if (*this == pen) return (*this);
87 Ref( pen );
88 return *this;
89}
90
91bool wxPen::operator == ( const wxPen& pen )
92{
93 return m_refData == pen.m_refData;
94}
95
96bool wxPen::operator != ( const wxPen& pen )
97{
98 return m_refData != pen.m_refData;
99}
100
101void wxPen::SetColour( const wxColour &colour )
102{
103 Unshare();
104 M_PENDATA->m_colour = colour;
105}
106
107void wxPen::SetColour( int red, int green, int blue )
108{
109 Unshare();
110 M_PENDATA->m_colour.Set( red, green, blue );
111}
112
113void wxPen::SetCap( int capStyle )
114{
115 Unshare();
116 M_PENDATA->m_capStyle = capStyle;
117}
118
119void wxPen::SetJoin( int joinStyle )
120{
121 Unshare();
122 M_PENDATA->m_joinStyle = joinStyle;
123}
124
125void wxPen::SetStyle( int style )
126{
127 Unshare();
128 M_PENDATA->m_style = style;
129}
130
131void wxPen::SetWidth( int width )
132{
133 Unshare();
134 M_PENDATA->m_width = width;
135}
136
137int wxPen::GetCap() const
138{
139 wxCHECK_MSG( Ok(), -1, "invalid pen" );
140
141 return M_PENDATA->m_capStyle;
142}
143
144int wxPen::GetJoin() const
145{
146 wxCHECK_MSG( Ok(), -1, "invalid pen" );
147
148 return M_PENDATA->m_joinStyle;
149}
150
151int wxPen::GetStyle() const
152{
153 wxCHECK_MSG( Ok(), -1, "invalid pen" );
154
155 return M_PENDATA->m_style;
156}
157
158int wxPen::GetWidth() const
159{
160 wxCHECK_MSG( Ok(), -1, "invalid pen" );
161
162 return M_PENDATA->m_width;
163}
164
165wxColour &wxPen::GetColour() const
166{
167 wxCHECK_MSG( Ok(), wxNullColour, "invalid pen" );
168
169 return M_PENDATA->m_colour;
170}
171
172bool wxPen::Ok() const
173{
174 return (m_refData != NULL);
175}
176
177void wxPen::Unshare()
178{
179 if (!m_refData)
180 {
181 m_refData = new wxPenRefData();
182 }
183 else
184 {
185 wxPenRefData* ref = new wxPenRefData( *(wxPenRefData*)m_refData );
186 UnRef();
187 m_refData = ref;
188 }
189}
190