2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: region.h
|
2008-03-10 15:24:38 +00:00
|
|
|
// Purpose: interface of wxRegionIterator
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxRegionIterator
|
|
|
|
@wxheader{region.h}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
This class is used to iterate through the rectangles in a region,
|
|
|
|
typically when examining the damaged regions of a window within an OnPaint call.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
To use it, construct an iterator object on the stack and loop through the
|
|
|
|
regions, testing the object and incrementing the iterator at the end of the
|
|
|
|
loop.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
See wxPaintEvent for an example of use.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxcore}
|
|
|
|
@category{FIXME}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxPaintEvent
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxRegionIterator : public wxObject
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Creates an iterator object given a region.
|
|
|
|
*/
|
|
|
|
wxRegionIterator();
|
2008-03-08 14:43:31 +00:00
|
|
|
wxRegionIterator(const wxRegion& region);
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
An alias for GetHeight.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxCoord GetH() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the height value for the current region.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxCoord GetHeight() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the current rectangle.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxRect GetRect() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
An alias for GetWidth.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxCoord GetW() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the width value for the current region.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxCoord GetWidth() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the x value for the current region.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxCoord GetX() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns the y value for the current region.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxCoord GetY() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if there are still some rectangles; otherwise returns @false.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool HaveRects() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Resets the iterator to the given region.
|
|
|
|
*/
|
|
|
|
void Reset();
|
2008-03-08 14:43:31 +00:00
|
|
|
void Reset(const wxRegion& region);
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Increment operator. Increments the iterator to the next region.
|
|
|
|
*/
|
|
|
|
void operator ++();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if there are still some rectangles; otherwise returns @false.
|
|
|
|
You can use this to test the iterator object as if it were of type bool.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
operator bool() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
/**
|
|
|
|
@class wxRegion
|
|
|
|
@wxheader{region.h}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
A wxRegion represents a simple or complex region on a device context or window.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
This class uses @ref overview_trefcount "reference counting and copy-on-write"
|
|
|
|
internally so that assignments between two instances of this class are very
|
|
|
|
cheap. You can therefore use actual objects instead of pointers without
|
|
|
|
efficiency problems. If an instance of this class is changed it will create
|
|
|
|
its own data internally so that other instances, which previously shared the
|
|
|
|
data using the reference counting, are not affected.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxcore}
|
2008-03-14 14:42:46 +00:00
|
|
|
@category{data,gdi}
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-10 15:24:38 +00:00
|
|
|
@see wxRegionIterator
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxRegion : public wxGDIObject
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Constructs a region using the non-transparent pixels of a bitmap. See
|
|
|
|
Union() for more details.
|
|
|
|
*/
|
|
|
|
wxRegion();
|
2008-03-08 14:43:31 +00:00
|
|
|
wxRegion(wxCoord x, wxCoord y, wxCoord width, wxCoord height);
|
|
|
|
wxRegion(const wxPoint& topLeft, const wxPoint& bottomRight);
|
|
|
|
wxRegion(const wxRect& rect);
|
|
|
|
wxRegion(const wxRegion& region);
|
|
|
|
wxRegion(size_t n, const wxPoint points,
|
|
|
|
int fillStyle = wxWINDING_RULE);
|
|
|
|
wxRegion(const wxBitmap& bmp);
|
|
|
|
wxRegion(const wxBitmap& bmp, const wxColour& transColour,
|
|
|
|
int tolerance = 0);
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Destructor.
|
|
|
|
See @ref overview_refcountdestruct "reference-counted object destruction" for
|
|
|
|
more info.
|
|
|
|
*/
|
|
|
|
~wxRegion();
|
|
|
|
|
|
|
|
/**
|
|
|
|
Clears the current region.
|
|
|
|
*/
|
|
|
|
void Clear();
|
|
|
|
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Returns a value indicating whether the given rectangle is contained within the
|
|
|
|
region.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@returns The return value is one of wxOutRegion, wxPartRegion and
|
2008-03-09 12:33:59 +00:00
|
|
|
wxInRegion.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxRegionContain Contains(long& x, long& y) const;
|
|
|
|
const wxRegionContain Contains(const wxPoint& pt) const;
|
|
|
|
const wxRegionContain Contains(long& x, long& y,
|
|
|
|
long& width,
|
|
|
|
long& height) const;
|
|
|
|
const wxRegionContain Contains(const wxRect& rect) const;
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Convert the region to a black and white bitmap with the white pixels
|
|
|
|
being inside the region.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxBitmap ConvertToBitmap() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Returns the outer bounds of the region.
|
|
|
|
*/
|
|
|
|
void GetBox(wxCoord& x, wxCoord& y, wxCoord& width,
|
2008-03-09 16:24:26 +00:00
|
|
|
wxCoord& height) const;
|
|
|
|
const wxRect GetBox() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Finds the intersection of this region and another region.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@returns @true if successful, @false otherwise.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@remarks Creates the intersection of the two regions, that is, the parts
|
2008-03-09 12:33:59 +00:00
|
|
|
which are in both regions. The result is stored in this
|
|
|
|
region.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
bool Intersect(wxCoord x, wxCoord y, wxCoord width,
|
|
|
|
wxCoord height);
|
2008-03-08 14:43:31 +00:00
|
|
|
bool Intersect(const wxRect& rect);
|
|
|
|
bool Intersect(const wxRegion& region);
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if the region is empty, @false otherwise.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool IsEmpty() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true if the region is equal to, i.e. covers the same area as,
|
2008-03-09 12:33:59 +00:00
|
|
|
another one. Note that if both this region and @a region are invalid, they
|
2008-03-08 13:52:38 +00:00
|
|
|
are considered to be equal.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool IsEqual(const wxRegion& region) const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Moves the region by the specified offsets in horizontal and vertical
|
|
|
|
directions.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@returns @true if successful, @false otherwise (the region is unchanged
|
2008-03-09 12:33:59 +00:00
|
|
|
then).
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
bool Offset(wxCoord x, wxCoord y);
|
2008-03-08 14:43:31 +00:00
|
|
|
bool Offset(const wxPoint& pt);
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Subtracts a region from this region.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@returns @true if successful, @false otherwise.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@remarks This operation combines the parts of 'this' region that are not
|
2008-03-09 12:33:59 +00:00
|
|
|
part of the second region. The result is stored in this
|
|
|
|
region.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
bool Subtract(const wxRect& rect);
|
2008-03-08 14:43:31 +00:00
|
|
|
bool Subtract(const wxRegion& region);
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Finds the union of this region and the non-transparent pixels of a
|
|
|
|
bitmap. Colour to be treated as transparent is specified in the
|
2008-03-09 12:33:59 +00:00
|
|
|
@a transColour argument, along with an
|
2008-03-08 13:52:38 +00:00
|
|
|
optional colour tolerance value.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@returns @true if successful, @false otherwise.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@remarks This operation creates a region that combines all of this region
|
2008-03-09 12:33:59 +00:00
|
|
|
and the second region. The result is stored in this
|
|
|
|
region.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
bool Union(wxCoord x, wxCoord y, wxCoord width, wxCoord height);
|
2008-03-08 14:43:31 +00:00
|
|
|
bool Union(const wxRect& rect);
|
|
|
|
bool Union(const wxRegion& region);
|
|
|
|
bool Union(const wxBitmap& bmp);
|
|
|
|
bool Union(const wxBitmap& bmp, const wxColour& transColour,
|
|
|
|
int tolerance = 0);
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
//@{
|
|
|
|
/**
|
|
|
|
Finds the Xor of this region and another region.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@returns @true if successful, @false otherwise.
|
2008-03-20 13:45:17 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@remarks This operation creates a region that combines all of this region
|
2008-03-09 12:33:59 +00:00
|
|
|
and the second region, except for any overlapping
|
|
|
|
areas. The result is stored in this region.
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
bool Xor(wxCoord x, wxCoord y, wxCoord width, wxCoord height);
|
2008-03-08 14:43:31 +00:00
|
|
|
bool Xor(const wxRect& rect);
|
|
|
|
bool Xor(const wxRegion& region);
|
2008-03-08 13:52:38 +00:00
|
|
|
//@}
|
|
|
|
|
|
|
|
/**
|
|
|
|
Assignment operator, using @ref overview_trefcount "reference counting".
|
|
|
|
*/
|
|
|
|
void operator =(const wxRegion& region);
|
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|