]> git.saurik.com Git - wxWidgets.git/blame - include/wx/gtk/region.h
doc fix
[wxWidgets.git] / include / wx / gtk / region.h
CommitLineData
c801d85f 1/////////////////////////////////////////////////////////////////////////////
5fc7ede9 2// Name: wx/gtk/region.h
c801d85f
KB
3// Purpose:
4// Author: Robert Roebling
58614078
RR
5// Id: $Id$
6// Copyright: (c) 1998 Robert Roebling
5fc7ede9 7// Licence: wxWindows licence
c801d85f
KB
8/////////////////////////////////////////////////////////////////////////////
9
5fc7ede9
VZ
10#ifndef _WX_GTK_REGION_H_
11#define _WX_GTK_REGION_H_
c801d85f 12
12028905 13#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
c801d85f
KB
14#pragma interface
15#endif
16
17#include "wx/list.h"
18#include "wx/gdiobj.h"
19#include "wx/gdicmn.h"
20
21//-----------------------------------------------------------------------------
22// classes
23//-----------------------------------------------------------------------------
24
25class wxRegion;
26
27//-----------------------------------------------------------------------------
28// constants
29//-----------------------------------------------------------------------------
30
5fc7ede9 31enum wxRegionContain
c801d85f 32{
1e6feb95
VZ
33 wxOutRegion = 0,
34 wxPartRegion = 1,
e1208c31 35 wxInRegion = 2
c801d85f
KB
36};
37
38// So far, for internal use only
1e6feb95 39enum wxRegionOp
e1208c31
RR
40{
41 wxRGN_AND, // Creates the intersection of the two combined regions.
42 wxRGN_COPY, // Creates a copy of the region identified by hrgnSrc1.
43 wxRGN_DIFF, // Combines the parts of hrgnSrc1 that are not part of hrgnSrc2.
44 wxRGN_OR, // Creates the union of two combined regions.
45 wxRGN_XOR // Creates the union of two combined regions except for any overlapping areas.
c801d85f
KB
46};
47
1e6feb95 48// ----------------------------------------------------------------------------
c801d85f 49// wxRegion
1e6feb95 50// ----------------------------------------------------------------------------
c801d85f 51
5fc7ede9 52class wxRegion : public wxGDIObject
c801d85f 53{
e1208c31 54public:
9fe4c99c 55 wxRegion() { }
1542ea39 56
9fe4c99c
VZ
57 wxRegion( wxCoord x, wxCoord y, wxCoord w, wxCoord h )
58 {
59 InitRect(x, y, w, h);
60 }
61
62 wxRegion( const wxPoint& topLeft, const wxPoint& bottomRight )
63 {
64 InitRect(topLeft.x, topLeft.y,
65 bottomRight.x - topLeft.x, bottomRight.y - topLeft.y);
66 }
67
68 wxRegion( const wxRect& rect )
69 {
70 InitRect(rect.x, rect.y, rect.width, rect.height);
71 }
72
73 wxRegion( size_t n, const wxPoint *points, int fillStyle = wxODDEVEN_RULE );
1542ea39
RD
74
75 wxRegion( const wxBitmap& bmp,
76 const wxColour& transColour = wxNullColour,
77 int tolerance = 0)
78 {
79 Union(bmp, transColour, tolerance);
80 }
81
c89f5c02 82 ~wxRegion();
c801d85f 83
d84afea9
GD
84 wxRegion( const wxRegion& region )
85 : wxGDIObject()
86 { Ref(region); }
c89f5c02
RR
87 wxRegion& operator = ( const wxRegion& region ) { Ref(region); return *this; }
88
89 bool Ok() const { return m_refData != NULL; }
c801d85f 90
76ed8f8d 91 bool operator == ( const wxRegion& region );
c89f5c02 92 bool operator != ( const wxRegion& region ) { return !(*this == region); }
5fc7ede9 93
07818da8 94 void Clear();
9fe4c99c 95
35917d22 96 bool Offset( wxCoord x, wxCoord y );
c801d85f 97
5fc7ede9 98 bool Union( wxCoord x, wxCoord y, wxCoord width, wxCoord height );
c801d85f
KB
99 bool Union( const wxRect& rect );
100 bool Union( const wxRegion& region );
101
5fc7ede9 102 bool Intersect( wxCoord x, wxCoord y, wxCoord width, wxCoord height );
c801d85f
KB
103 bool Intersect( const wxRect& rect );
104 bool Intersect( const wxRegion& region );
105
5fc7ede9 106 bool Subtract( wxCoord x, wxCoord y, wxCoord width, wxCoord height );
c801d85f
KB
107 bool Subtract( const wxRect& rect );
108 bool Subtract( const wxRegion& region );
109
5fc7ede9 110 bool Xor( wxCoord x, wxCoord y, wxCoord width, wxCoord height );
c801d85f
KB
111 bool Xor( const wxRect& rect );
112 bool Xor( const wxRegion& region );
113
5fc7ede9 114 void GetBox( wxCoord& x, wxCoord& y, wxCoord&w, wxCoord &h ) const;
07818da8 115 wxRect GetBox() const ;
c801d85f 116
07818da8
VZ
117 bool Empty() const;
118 bool IsEmpty() const { return Empty(); }
c801d85f 119
5fc7ede9
VZ
120 wxRegionContain Contains( wxCoord x, wxCoord y ) const;
121 wxRegionContain Contains( wxCoord x, wxCoord y, wxCoord w, wxCoord h ) const;
8429bec1
RR
122 wxRegionContain Contains(const wxPoint& pt) const;
123 wxRegionContain Contains(const wxRect& rect) const;
5fc7ede9 124
819451b6 125 // Convert the region to a B&W bitmap with the white pixels being inside
1542ea39
RD
126 // the region.
127 wxBitmap ConvertToBitmap() const;
128
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,
135 int tolerance = 0);
136
137
e1208c31 138public:
331a0b6b
RR
139 // Init with GdkRegion, set ref count to 2 so that
140 // the C++ class will not destroy the region!
141 wxRegion( GdkRegion *region );
1542ea39 142
07818da8 143 GdkRegion *GetRegion() const;
1e6feb95
VZ
144
145protected:
e0f0b197
RR
146 // ref counting code
147 virtual wxObjectRefData *CreateRefData() const;
148 virtual wxObjectRefData *CloneRefData(const wxObjectRefData *data) const;
1542ea39 149
9fe4c99c
VZ
150 // common part of ctors for a rectangle region
151 void InitRect(wxCoord x, wxCoord y, wxCoord w, wxCoord h);
152
e1208c31 153private:
1e6feb95 154 DECLARE_DYNAMIC_CLASS(wxRegion);
c801d85f
KB
155};
156
1e6feb95
VZ
157// ----------------------------------------------------------------------------
158// wxRegionIterator: decomposes a region into rectangles
159// ----------------------------------------------------------------------------
160
5fc7ede9 161class wxRegionIterator: public wxObject
8429bec1 162{
738f9e5a 163public:
07818da8 164 wxRegionIterator();
8429bec1
RR
165 wxRegionIterator(const wxRegion& region);
166
6f2a55e3 167 void Reset() { m_current = 0u; }
8429bec1
RR
168 void Reset(const wxRegion& region);
169
07818da8 170 bool HaveRects() const;
2b5f62a0 171 operator bool () const { return HaveRects(); }
8429bec1 172
2b5f62a0
VZ
173 wxRegionIterator& operator ++ ();
174 wxRegionIterator operator ++ (int);
8429bec1 175
b02da6b1
VZ
176 wxCoord GetX() const;
177 wxCoord GetY() const;
178 wxCoord GetW() const;
179 wxCoord GetWidth() const { return GetW(); }
180 wxCoord GetH() const;
181 wxCoord GetHeight() const { return GetH(); }
1e6feb95 182 wxRect GetRect() const;
8429bec1 183
738f9e5a 184private:
6f2a55e3
VZ
185 size_t m_current;
186 wxRegion m_region;
738f9e5a
RR
187
188private:
189 DECLARE_DYNAMIC_CLASS(wxRegionIterator);
8429bec1
RR
190};
191
192
c801d85f 193#endif
5fc7ede9 194 // _WX_GTK_REGION_H_