Commit | Line | Data |
---|---|---|
83df96d6 JS |
1 | ///////////////////////////////////////////////////////////////////////////// |
2 | // Name: region.h | |
3 | // Purpose: wxRegion class | |
4 | // Author: Julian Smart | |
5 | // Modified by: | |
6 | // Created: 17/09/98 | |
7 | // RCS-ID: $Id$ | |
1934d291 | 8 | // Copyright: (c) Julian Smart, Robert Roebling |
65571936 | 9 | // Licence: wxWindows licence |
83df96d6 JS |
10 | ///////////////////////////////////////////////////////////////////////////// |
11 | ||
12 | #ifndef _WX_REGION_H_ | |
13 | #define _WX_REGION_H_ | |
14 | ||
83df96d6 JS |
15 | #include "wx/list.h" |
16 | #include "wx/gdiobj.h" | |
17 | #include "wx/gdicmn.h" | |
18 | ||
1934d291 RR |
19 | //----------------------------------------------------------------------------- |
20 | // classes | |
21 | //----------------------------------------------------------------------------- | |
83df96d6 | 22 | |
968eb2ef | 23 | class WXDLLIMPEXP_CORE wxRegion; |
83df96d6 | 24 | |
1934d291 RR |
25 | //----------------------------------------------------------------------------- |
26 | // constants | |
27 | //----------------------------------------------------------------------------- | |
83df96d6 | 28 | |
1934d291 RR |
29 | enum wxRegionContain |
30 | { | |
31 | wxOutRegion = 0, | |
32 | wxPartRegion = 1, | |
33 | wxInRegion = 2 | |
83df96d6 JS |
34 | }; |
35 | ||
36 | // So far, for internal use only | |
1934d291 RR |
37 | enum wxRegionOp |
38 | { | |
39 | wxRGN_AND, // Creates the intersection of the two combined regions. | |
40 | wxRGN_COPY, // Creates a copy of the region identified by hrgnSrc1. | |
41 | wxRGN_DIFF, // Combines the parts of hrgnSrc1 that are not part of hrgnSrc2. | |
42 | wxRGN_OR, // Creates the union of two combined regions. | |
43 | wxRGN_XOR // Creates the union of two combined regions except for any overlapping areas. | |
83df96d6 JS |
44 | }; |
45 | ||
1934d291 RR |
46 | // ---------------------------------------------------------------------------- |
47 | // wxRegion | |
48 | // ---------------------------------------------------------------------------- | |
49 | ||
968eb2ef | 50 | class WXDLLIMPEXP_CORE wxRegion : public wxGDIObject |
1934d291 | 51 | { |
83df96d6 | 52 | public: |
1934d291 RR |
53 | wxRegion() { } |
54 | ||
55 | wxRegion( wxCoord x, wxCoord y, wxCoord w, wxCoord h ) | |
56 | { | |
57 | InitRect(x, y, w, h); | |
58 | } | |
59 | ||
60 | wxRegion( const wxPoint& topLeft, const wxPoint& bottomRight ) | |
61 | { | |
62 | InitRect(topLeft.x, topLeft.y, | |
63 | bottomRight.x - topLeft.x, bottomRight.y - topLeft.y); | |
64 | } | |
65 | ||
66 | wxRegion( const wxRect& rect ) | |
67 | { | |
68 | InitRect(rect.x, rect.y, rect.width, rect.height); | |
69 | } | |
70 | ||
71 | wxRegion( size_t n, const wxPoint *points, int fillStyle = wxODDEVEN_RULE ); | |
1542ea39 | 72 | |
85f6b408 VS |
73 | wxRegion( const wxBitmap& bmp) |
74 | { | |
75 | Union(bmp); | |
76 | } | |
1542ea39 | 77 | wxRegion( const wxBitmap& bmp, |
85f6b408 | 78 | const wxColour& transColour, int tolerance = 0) |
1542ea39 RD |
79 | { |
80 | Union(bmp, transColour, tolerance); | |
81 | } | |
82 | ||
83df96d6 | 83 | ~wxRegion(); |
1934d291 | 84 | |
1934d291 RR |
85 | bool Ok() const { return m_refData != NULL; } |
86 | ||
fbfb8bcc VZ |
87 | bool operator == ( const wxRegion& region ) const; |
88 | bool operator != ( const wxRegion& region ) const { return !(*this == region); } | |
1934d291 | 89 | |
83df96d6 | 90 | void Clear(); |
1934d291 RR |
91 | |
92 | bool Offset( wxCoord x, wxCoord y ); | |
93 | ||
94 | bool Union( wxCoord x, wxCoord y, wxCoord width, wxCoord height ); | |
95 | bool Union( const wxRect& rect ); | |
96 | bool Union( const wxRegion& region ); | |
97 | ||
98 | bool Intersect( wxCoord x, wxCoord y, wxCoord width, wxCoord height ); | |
99 | bool Intersect( const wxRect& rect ); | |
100 | bool Intersect( const wxRegion& region ); | |
101 | ||
102 | bool Subtract( wxCoord x, wxCoord y, wxCoord width, wxCoord height ); | |
103 | bool Subtract( const wxRect& rect ); | |
104 | bool Subtract( const wxRegion& region ); | |
105 | ||
106 | bool Xor( wxCoord x, wxCoord y, wxCoord width, wxCoord height ); | |
107 | bool Xor( const wxRect& rect ); | |
108 | bool Xor( const wxRegion& region ); | |
109 | ||
110 | void GetBox( wxCoord& x, wxCoord& y, wxCoord&w, wxCoord &h ) const; | |
83df96d6 | 111 | wxRect GetBox() const ; |
1934d291 | 112 | |
83df96d6 | 113 | bool Empty() const; |
1934d291 RR |
114 | bool IsEmpty() const { return Empty(); } |
115 | ||
116 | wxRegionContain Contains( wxCoord x, wxCoord y ) const; | |
117 | wxRegionContain Contains( wxCoord x, wxCoord y, wxCoord w, wxCoord h ) const; | |
83df96d6 | 118 | wxRegionContain Contains(const wxPoint& pt) const; |
83df96d6 | 119 | wxRegionContain Contains(const wxRect& rect) const; |
1934d291 | 120 | |
819451b6 | 121 | // Convert the region to a B&W bitmap with the white pixels being inside |
1542ea39 RD |
122 | // the region. |
123 | wxBitmap ConvertToBitmap() const; | |
124 | ||
125 | // Use the non-transparent pixels of a wxBitmap for the region to combine | |
85f6b408 VS |
126 | // with this region. First version takes transparency from bitmap's mask, |
127 | // second lets the user specify the colour to be treated as transparent | |
1542ea39 | 128 | // along with an optional tolerance value. |
85f6b408 VS |
129 | // NOTE: implemented in common/rgncmn.cpp |
130 | bool Union(const wxBitmap& bmp); | |
1542ea39 | 131 | bool Union(const wxBitmap& bmp, |
85f6b408 | 132 | const wxColour& transColour, int tolerance = 0); |
1542ea39 RD |
133 | |
134 | ||
1934d291 RR |
135 | public: |
136 | WXRegion *GetX11Region() const; | |
137 | ||
138 | protected: | |
139 | // ref counting code | |
140 | virtual wxObjectRefData *CreateRefData() const; | |
141 | virtual wxObjectRefData *CloneRefData(const wxObjectRefData *data) const; | |
1542ea39 | 142 | |
1934d291 RR |
143 | // common part of ctors for a rectangle region |
144 | void InitRect(wxCoord x, wxCoord y, wxCoord w, wxCoord h); | |
145 | ||
146 | private: | |
777105f2 | 147 | DECLARE_DYNAMIC_CLASS(wxRegion) |
83df96d6 JS |
148 | }; |
149 | ||
1934d291 RR |
150 | // ---------------------------------------------------------------------------- |
151 | // wxRegionIterator: decomposes a region into rectangles | |
152 | // ---------------------------------------------------------------------------- | |
153 | ||
968eb2ef | 154 | class WXDLLIMPEXP_CORE wxRegionIterator: public wxObject |
1934d291 | 155 | { |
83df96d6 JS |
156 | public: |
157 | wxRegionIterator(); | |
158 | wxRegionIterator(const wxRegion& region); | |
1934d291 RR |
159 | |
160 | void Reset() { m_current = 0u; } | |
83df96d6 | 161 | void Reset(const wxRegion& region); |
1934d291 RR |
162 | |
163 | operator bool () const; | |
164 | bool HaveRects() const; | |
165 | ||
83df96d6 JS |
166 | void operator ++ (); |
167 | void operator ++ (int); | |
1934d291 | 168 | |
83df96d6 JS |
169 | wxCoord GetX() const; |
170 | wxCoord GetY() const; | |
171 | wxCoord GetW() const; | |
172 | wxCoord GetWidth() const { return GetW(); } | |
173 | wxCoord GetH() const; | |
174 | wxCoord GetHeight() const { return GetH(); } | |
1934d291 RR |
175 | wxRect GetRect() const; |
176 | ||
83df96d6 | 177 | private: |
1934d291 | 178 | size_t m_current; |
83df96d6 | 179 | wxRegion m_region; |
1934d291 RR |
180 | |
181 | private: | |
777105f2 | 182 | DECLARE_DYNAMIC_CLASS(wxRegionIterator) |
83df96d6 JS |
183 | }; |
184 | ||
185 | #endif | |
186 | // _WX_REGION_H_ |