1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: wxRegion class
4 // Author: Julian Smart
8 // Copyright: (c) Julian Smart, Robert Roebling
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
15 #if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
16 #pragma interface "region.h"
20 #include "wx/gdiobj.h"
21 #include "wx/gdicmn.h"
23 //-----------------------------------------------------------------------------
25 //-----------------------------------------------------------------------------
29 //-----------------------------------------------------------------------------
31 //-----------------------------------------------------------------------------
40 // So far, for internal use only
43 wxRGN_AND
, // Creates the intersection of the two combined regions.
44 wxRGN_COPY
, // Creates a copy of the region identified by hrgnSrc1.
45 wxRGN_DIFF
, // Combines the parts of hrgnSrc1 that are not part of hrgnSrc2.
46 wxRGN_OR
, // Creates the union of two combined regions.
47 wxRGN_XOR
// Creates the union of two combined regions except for any overlapping areas.
50 // ----------------------------------------------------------------------------
52 // ----------------------------------------------------------------------------
54 class wxRegion
: public wxGDIObject
59 wxRegion( wxCoord x
, wxCoord y
, wxCoord w
, wxCoord h
)
64 wxRegion( const wxPoint
& topLeft
, const wxPoint
& bottomRight
)
66 InitRect(topLeft
.x
, topLeft
.y
,
67 bottomRight
.x
- topLeft
.x
, bottomRight
.y
- topLeft
.y
);
70 wxRegion( const wxRect
& rect
)
72 InitRect(rect
.x
, rect
.y
, rect
.width
, rect
.height
);
75 wxRegion( size_t n
, const wxPoint
*points
, int fillStyle
= wxODDEVEN_RULE
);
77 wxRegion( const wxBitmap
& bmp
,
78 const wxColour
& transColour
= wxNullColour
,
81 Union(bmp
, transColour
, tolerance
);
86 wxRegion( const wxRegion
& region
) { Ref(region
); }
87 wxRegion
& operator = ( const wxRegion
& region
) { Ref(region
); return *this; }
89 bool Ok() const { return m_refData
!= NULL
; }
91 bool operator == ( const wxRegion
& region
);
92 bool operator != ( const wxRegion
& region
) { return !(*this == region
); }
96 bool Offset( wxCoord x
, wxCoord y
);
98 bool Union( wxCoord x
, wxCoord y
, wxCoord width
, wxCoord height
);
99 bool Union( const wxRect
& rect
);
100 bool Union( const wxRegion
& region
);
102 bool Intersect( wxCoord x
, wxCoord y
, wxCoord width
, wxCoord height
);
103 bool Intersect( const wxRect
& rect
);
104 bool Intersect( const wxRegion
& region
);
106 bool Subtract( wxCoord x
, wxCoord y
, wxCoord width
, wxCoord height
);
107 bool Subtract( const wxRect
& rect
);
108 bool Subtract( const wxRegion
& region
);
110 bool Xor( wxCoord x
, wxCoord y
, wxCoord width
, wxCoord height
);
111 bool Xor( const wxRect
& rect
);
112 bool Xor( const wxRegion
& region
);
114 void GetBox( wxCoord
& x
, wxCoord
& y
, wxCoord
&w
, wxCoord
&h
) const;
115 wxRect
GetBox() const ;
118 bool IsEmpty() const { return Empty(); }
120 wxRegionContain
Contains( wxCoord x
, wxCoord y
) const;
121 wxRegionContain
Contains( wxCoord x
, wxCoord y
, wxCoord w
, wxCoord h
) const;
122 wxRegionContain
Contains(const wxPoint
& pt
) const;
123 wxRegionContain
Contains(const wxRect
& rect
) const;
125 // Convert the region to a B&W bitmap with the white pixels being inside
127 wxBitmap
ConvertToBitmap() const;
129 // Use the non-transparent pixels of a wxBitmap for the region to combine
130 // with this region. If the bitmap has a mask then it will be used,
131 // otherwise the colour to be treated as transparent may be specified,
132 // along with an optional tolerance value.
133 bool Union(const wxBitmap
& bmp
,
134 const wxColour
& transColour
= wxNullColour
,
139 WXRegion
*GetX11Region() const;
143 virtual wxObjectRefData
*CreateRefData() const;
144 virtual wxObjectRefData
*CloneRefData(const wxObjectRefData
*data
) const;
146 // common part of ctors for a rectangle region
147 void InitRect(wxCoord x
, wxCoord y
, wxCoord w
, wxCoord h
);
150 DECLARE_DYNAMIC_CLASS(wxRegion
);
153 // ----------------------------------------------------------------------------
154 // wxRegionIterator: decomposes a region into rectangles
155 // ----------------------------------------------------------------------------
157 class wxRegionIterator
: public wxObject
161 wxRegionIterator(const wxRegion
& region
);
163 void Reset() { m_current
= 0u; }
164 void Reset(const wxRegion
& region
);
166 operator bool () const;
167 bool HaveRects() const;
170 void operator ++ (int);
172 wxCoord
GetX() const;
173 wxCoord
GetY() const;
174 wxCoord
GetW() const;
175 wxCoord
GetWidth() const { return GetW(); }
176 wxCoord
GetH() const;
177 wxCoord
GetHeight() const { return GetH(); }
178 wxRect
GetRect() const;
185 DECLARE_DYNAMIC_CLASS(wxRegionIterator
);