summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--basegfx/Package_inc.mk1
-rw-r--r--basegfx/inc/basegfx/range/b1drange.hxx54
-rw-r--r--basegfx/inc/basegfx/range/b1ibox.hxx52
-rw-r--r--basegfx/inc/basegfx/range/b1irange.hxx53
-rw-r--r--basegfx/inc/basegfx/range/b2drange.hxx62
-rw-r--r--basegfx/inc/basegfx/range/b2ibox.hxx74
-rw-r--r--basegfx/inc/basegfx/range/b2irange.hxx70
-rw-r--r--basegfx/inc/basegfx/range/b3drange.hxx26
-rw-r--r--basegfx/inc/basegfx/range/b3ibox.hxx6
-rw-r--r--basegfx/inc/basegfx/range/b3irange.hxx21
-rw-r--r--basegfx/inc/basegfx/range/basicbox.hxx7
-rw-r--r--basegfx/inc/basegfx/range/rangeexpander.hxx86
-rw-r--r--basegfx/test/basegfx2d.cxx4
13 files changed, 287 insertions, 229 deletions
diff --git a/basegfx/Package_inc.mk b/basegfx/Package_inc.mk
index 2ecc260b6fee..1263c50712df 100644
--- a/basegfx/Package_inc.mk
+++ b/basegfx/Package_inc.mk
@@ -52,7 +52,6 @@ $(eval $(call gb_Package_add_file,basegfx_inc,inc/basegfx/range/basicbox.hxx,bas
$(eval $(call gb_Package_add_file,basegfx_inc,inc/basegfx/range/b2dconnectedranges.hxx,basegfx/range/b2dconnectedranges.hxx))
$(eval $(call gb_Package_add_file,basegfx_inc,inc/basegfx/range/b3drange.hxx,basegfx/range/b3drange.hxx))
$(eval $(call gb_Package_add_file,basegfx_inc,inc/basegfx/range/b2drange.hxx,basegfx/range/b2drange.hxx))
-$(eval $(call gb_Package_add_file,basegfx_inc,inc/basegfx/range/rangeexpander.hxx,basegfx/range/rangeexpander.hxx))
$(eval $(call gb_Package_add_file,basegfx_inc,inc/basegfx/range/b2irange.hxx,basegfx/range/b2irange.hxx))
$(eval $(call gb_Package_add_file,basegfx_inc,inc/basegfx/range/b1ibox.hxx,basegfx/range/b1ibox.hxx))
$(eval $(call gb_Package_add_file,basegfx_inc,inc/basegfx/range/b2dpolyrange.hxx,basegfx/range/b2dpolyrange.hxx))
diff --git a/basegfx/inc/basegfx/range/b1drange.hxx b/basegfx/inc/basegfx/range/b1drange.hxx
index 83bca953734e..cac1efb075b6 100644
--- a/basegfx/inc/basegfx/range/b1drange.hxx
+++ b/basegfx/inc/basegfx/range/b1drange.hxx
@@ -37,38 +37,53 @@ namespace basegfx
{
class B1IRange;
- class BASEGFX_DLLPUBLIC B1DRange
+ /** A one-dimensional interval over doubles
+
+ This is a set of real numbers, bounded by a lower and an upper
+ value. All inbetween values are included in the set (see also
+ http://en.wikipedia.org/wiki/Interval_%28mathematics%29).
+
+ The set is closed, i.e. the upper and the lower bound are
+ included (if you're used to the notation - we're talking about
+ [a,b] here, compared to half-open [a,b) or open intervals
+ (a,b)).
+
+ That means, isInside(val) will return true also for values of
+ val=a or val=b.
+ */
+ class B1DRange
{
::basegfx::BasicRange< double, DoubleTraits > maRange;
public:
- B1DRange()
- {
- }
+ B1DRange() {}
+ /// Create degenerate interval consisting of a single double number
explicit B1DRange(double fStartValue)
: maRange(fStartValue)
{
}
+ /// Create proper interval between the two given double values
B1DRange(double fStartValue1, double fStartValue2)
: maRange(fStartValue1)
{
expand(fStartValue2);
}
- B1DRange(const B1DRange& rRange)
- : maRange(rRange.maRange)
- {
- }
+ BASEGFX_DLLPUBLIC explicit B1DRange( const B1IRange& rRange );
- explicit B1DRange( const B1IRange& rRange );
+ /** Check if the interval set is empty
+ @return false, if no value is in this set - having a
+ single value included will already return true.
+ */
bool isEmpty() const
{
return maRange.isEmpty();
}
+ /// reset the object to empty state again, clearing all values
void reset()
{
maRange.reset();
@@ -84,72 +99,78 @@ namespace basegfx
return (maRange != rRange.maRange);
}
- B1DRange& operator=(const B1DRange& rRange)
- {
- maRange = rRange.maRange;
- return *this;
- }
-
bool equal(const B1DRange& rRange) const
{
return (maRange.equal(rRange.maRange));
}
+ /// get lower bound of the set. returns arbitrary values for empty sets.
double getMinimum() const
{
return maRange.getMinimum();
}
+ /// get upper bound of the set. returns arbitrary values for empty sets.
double getMaximum() const
{
return maRange.getMaximum();
}
+ /// return difference between upper and lower value. returns 0 for empty sets.
double getRange() const
{
return maRange.getRange();
}
+ /// return middle of upper and lower value. returns 0 for empty sets.
double getCenter() const
{
return maRange.getCenter();
}
+ /// yields true if value is contained in set
bool isInside(double fValue) const
{
return maRange.isInside(fValue);
}
+ /// yields true if rRange is inside, or equal to set
bool isInside(const B1DRange& rRange) const
{
return maRange.isInside(rRange.maRange);
}
+ /// yields true if rRange at least partly inside set
bool overlaps(const B1DRange& rRange) const
{
return maRange.overlaps(rRange.maRange);
}
+ /// yields true if overlaps(rRange) does, and the overlap is larger than infinitesimal
bool overlapsMore(const B1DRange& rRange) const
{
return maRange.overlapsMore(rRange.maRange);
}
+ /// add fValue to the set, expanding as necessary
void expand(double fValue)
{
maRange.expand(fValue);
}
+ /// add rRange to the set, expanding as necessary
void expand(const B1DRange& rRange)
{
maRange.expand(rRange.maRange);
}
+ /// calc set intersection
void intersect(const B1DRange& rRange)
{
maRange.intersect(rRange.maRange);
}
+ /// grow set by fValue on both sides
void grow(double fValue)
{
maRange.grow(fValue);
@@ -160,7 +181,8 @@ namespace basegfx
@return the nearest integer for this range
*/
- B1IRange fround(const B1DRange& rRange);
+ BASEGFX_DLLPUBLIC B1IRange fround(const B1DRange& rRange);
+
} // end of namespace basegfx
diff --git a/basegfx/inc/basegfx/range/b1ibox.hxx b/basegfx/inc/basegfx/range/b1ibox.hxx
index f40c7637fa8f..5bfe9f7170c4 100644
--- a/basegfx/inc/basegfx/range/b1ibox.hxx
+++ b/basegfx/inc/basegfx/range/b1ibox.hxx
@@ -35,36 +35,56 @@
namespace basegfx
{
- class BASEGFX_DLLPUBLIC B1IBox
+ /** A one-dimensional interval over integers
+
+ This is most easily depicted as a set of integers, bounded by
+ a lower and an upper value - but excluding the upper
+ value. All inbetween values are included in the set (see also
+ http://en.wikipedia.org/wiki/Interval_%28mathematics%29).
+
+ The set is half-open, i.e. the lower bound is included, the
+ upper bound not (if you're used to the notation - we're
+ talking about [a,b) here, compared to closed [a,b] or fully
+ open intervals (a,b)).
+
+ If you don't need a half-open interval, check B1IRange.
+
+ That means, isInside(val) will return true also for values of
+ val=a, but not for val=b.
+
+ @see B1IRange
+ */
+ class B1IBox
{
::basegfx::BasicBox maRange;
public:
- B1IBox()
- {
- }
+ B1IBox() {}
+ /// Create degenerate interval that's still empty
explicit B1IBox(sal_Int32 nStartValue)
: maRange(nStartValue)
{
}
+ /// Create proper interval between the two given values
B1IBox(sal_Int32 nStartValue1, sal_Int32 nStartValue2)
: maRange(nStartValue1)
{
expand(nStartValue2);
}
- B1IBox(const B1IBox& rBox)
- : maRange(rBox.maRange)
- {
- }
+ /** Check if the interval set is empty
+ @return false, if no value is in this set - having a
+ single value included will still return false.
+ */
bool isEmpty() const
{
return maRange.isEmpty();
}
+ /// reset the object to empty state again, clearing all values
void reset()
{
maRange.reset();
@@ -80,61 +100,67 @@ namespace basegfx
return (maRange != rBox.maRange);
}
- void operator=(const B1IBox& rBox)
- {
- maRange = rBox.maRange;
- }
-
+ /// get lower bound of the set. returns arbitrary values for empty sets.
sal_Int32 getMinimum() const
{
return maRange.getMinimum();
}
+ /// get upper bound of the set. returns arbitrary values for empty sets.
sal_Int32 getMaximum() const
{
return maRange.getMaximum();
}
+ /// return difference between upper and lower value. returns 0 for empty sets.
Int32Traits::DifferenceType getRange() const
{
return maRange.getRange();
}
+ /// return middle of upper and lower value. returns 0 for empty sets.
double getCenter() const
{
return maRange.getCenter();
}
+ /// yields true if value is contained in set
bool isInside(sal_Int32 nValue) const
{
return maRange.isInside(nValue);
}
+ /// yields true if rRange is inside, or equal to set
bool isInside(const B1IBox& rBox) const
{
return maRange.isInside(rBox.maRange);
}
+ /// yields true if rRange at least partly inside set
bool overlaps(const B1IBox& rBox) const
{
return maRange.overlaps(rBox.maRange);
}
+ /// add nValue to the set, expanding as necessary
void expand(sal_Int32 nValue)
{
maRange.expand(nValue);
}
+ /// add rBox to the set, expanding as necessary
void expand(const B1IBox& rBox)
{
maRange.expand(rBox.maRange);
}
+ /// calc set intersection
void intersect(const B1IBox& rBox)
{
maRange.intersect(rBox.maRange);
}
+ /// grow set by nValue on both sides
void grow(sal_Int32 nValue)
{
maRange.grow(nValue);
diff --git a/basegfx/inc/basegfx/range/b1irange.hxx b/basegfx/inc/basegfx/range/b1irange.hxx
index 81e19ef29904..6d0333521ceb 100644
--- a/basegfx/inc/basegfx/range/b1irange.hxx
+++ b/basegfx/inc/basegfx/range/b1irange.hxx
@@ -35,36 +35,55 @@
namespace basegfx
{
- class BASEGFX_DLLPUBLIC B1IRange
+ /** A one-dimensional interval over integers
+
+ This is a set of real numbers, bounded by a lower and an upper
+ value. All inbetween values are included in the set (see also
+ http://en.wikipedia.org/wiki/Interval_%28mathematics%29).
+
+ Probably you rather want B1IBox for integers.
+
+ The set is closed, i.e. the upper and the lower bound are
+ included (if you're used to the notation - we're talking about
+ [a,b] here, compared to half-open [a,b) or open intervals
+ (a,b)).
+
+ That means, isInside(val) will return true also for values of
+ val=a or val=b.
+
+ @see B1IBox
+ */
+ class B1IRange
{
::basegfx::BasicRange< sal_Int32, Int32Traits > maRange;
public:
- B1IRange()
- {
- }
+ B1IRange() {}
+ /// Create degenerate interval consisting of a single double number
explicit B1IRange(sal_Int32 nStartValue)
: maRange(nStartValue)
{
}
+ /// Create proper interval between the two given values
B1IRange(sal_Int32 nStartValue1, sal_Int32 nStartValue2)
: maRange(nStartValue1)
{
expand(nStartValue2);
}
- B1IRange(const B1IRange& rRange)
- : maRange(rRange.maRange)
- {
- }
+ /** Check if the interval set is empty
+ @return false, if no value is in this set - having a
+ single value included will already return true.
+ */
bool isEmpty() const
{
return maRange.isEmpty();
}
+ /// reset the object to empty state again, clearing all values
void reset()
{
maRange.reset();
@@ -80,67 +99,73 @@ namespace basegfx
return (maRange != rRange.maRange);
}
- B1IRange& operator=(const B1IRange& rRange)
- {
- maRange = rRange.maRange;
- return *this;
- }
-
+ /// get lower bound of the set. returns arbitrary values for empty sets.
sal_Int32 getMinimum() const
{
return maRange.getMinimum();
}
+ /// get upper bound of the set. returns arbitrary values for empty sets.
sal_Int32 getMaximum() const
{
return maRange.getMaximum();
}
+ /// return difference between upper and lower value. returns 0 for empty sets.
Int32Traits::DifferenceType getRange() const
{
return maRange.getRange();
}
+ /// return middle of upper and lower value. returns 0 for empty sets.
double getCenter() const
{
return maRange.getCenter();
}
+ /// yields true if value is contained in set
bool isInside(sal_Int32 nValue) const
{
return maRange.isInside(nValue);
}
+ /// yields true if rRange is inside, or equal to set
bool isInside(const B1IRange& rRange) const
{
return maRange.isInside(rRange.maRange);
}
+ /// yields true if rRange at least partly inside set
bool overlaps(const B1IRange& rRange) const
{
return maRange.overlaps(rRange.maRange);
}
+ /// yields true if overlaps(rRange) does, and the overlap is larger than infinitesimal
bool overlapsMore(const B1IRange& rRange) const
{
return maRange.overlapsMore(rRange.maRange);
}
+ /// add nValue to the set, expanding as necessary
void expand(sal_Int32 nValue)
{
maRange.expand(nValue);
}
+ /// add rRange to the set, expanding as necessary
void expand(const B1IRange& rRange)
{
maRange.expand(rRange.maRange);
}
+ /// calc set intersection
void intersect(const B1IRange& rRange)
{
maRange.intersect(rRange.maRange);
}
+ /// grow set by nValue on both sides
void grow(sal_Int32 nValue)
{
maRange.grow(nValue);
diff --git a/basegfx/inc/basegfx/range/b2drange.hxx b/basegfx/inc/basegfx/range/b2drange.hxx
index 0631f5e2cb70..b8a51aeb8800 100644
--- a/basegfx/inc/basegfx/range/b2drange.hxx
+++ b/basegfx/inc/basegfx/range/b2drange.hxx
@@ -43,22 +43,38 @@ namespace basegfx
class B2IRange;
class B2DHomMatrix;
+ /** A two-dimensional interval over doubles
+
+ This is a set of real numbers, bounded by a lower and an upper
+ pair. All inbetween values are included in the set (see also
+ http://en.wikipedia.org/wiki/Interval_%28mathematics%29).
+
+ The set is closed, i.e. the upper and the lower bound are
+ included (if you're used to the notation - we're talking about
+ [a,b] here, compared to half-open [a,b) or open intervals
+ (a,b)).
+
+ That means, isInside(val) will return true also for values of
+ val=a or val=b.
+
+ @see B1DRange
+ */
class B2DRange
{
public:
typedef double ValueType;
typedef DoubleTraits TraitsType;
- B2DRange()
- {
- }
+ B2DRange() {}
+ /// Create degenerate interval consisting of a single point
explicit B2DRange(const B2DTuple& rTuple)
: maRangeX(rTuple.getX()),
maRangeY(rTuple.getY())
{
}
+ /// Create proper interval between the two given double pairs
B2DRange(double x1,
double y1,
double x2,
@@ -70,6 +86,7 @@ namespace basegfx
maRangeY.expand(y2);
}
+ /// Create proper interval between the two given points
B2DRange(const B2DTuple& rTuple1,
const B2DTuple& rTuple2)
: maRangeX(rTuple1.getX()),
@@ -78,14 +95,13 @@ namespace basegfx
expand( rTuple2 );
}
- B2DRange(const B2DRange& rRange)
- : maRangeX(rRange.maRangeX),
- maRangeY(rRange.maRangeY)
- {
- }
-
BASEGFX_DLLPUBLIC explicit B2DRange(const B2IRange& rRange);
+ /** Check if the interval set is empty
+
+ @return false, if no value is in this set - having a
+ single point included will already return true.
+ */
bool isEmpty() const
{
return (
@@ -94,6 +110,7 @@ namespace basegfx
);
}
+ /// reset the object to empty state again, clearing all values
void reset()
{
maRangeX.reset();
@@ -112,49 +129,49 @@ namespace basegfx
|| maRangeY != rRange.maRangeY);
}
- B2DRange& operator=(const B2DRange& rRange)
- {
- maRangeX = rRange.maRangeX;
- maRangeY = rRange.maRangeY;
- return *this;
- }
-
bool equal(const B2DRange& rRange) const
{
return (maRangeX.equal(rRange.maRangeX)
&& maRangeY.equal(rRange.maRangeY));
}
+ /// get lower bound of the set. returns arbitrary values for empty sets.
double getMinX() const
{
return maRangeX.getMinimum();
}
+ /// get lower bound of the set. returns arbitrary values for empty sets.
double getMinY() const
{
return maRangeY.getMinimum();
}
+ /// get upper bound of the set. returns arbitrary values for empty sets.
double getMaxX() const
{
return maRangeX.getMaximum();
}
+ /// get upper bound of the set. returns arbitrary values for empty sets.
double getMaxY() const
{
return maRangeY.getMaximum();
}
+ /// return difference between upper and lower X value. returns 0 for empty sets.
double getWidth() const
{
return maRangeX.getRange();
}
+ /// return difference between upper and lower Y value. returns 0 for empty sets.
double getHeight() const
{
return maRangeY.getRange();
}
+ /// get lower bound of the set. returns arbitrary values for empty sets.
B2DPoint getMinimum() const
{
return B2DPoint(
@@ -163,6 +180,7 @@ namespace basegfx
);
}
+ /// get upper bound of the set. returns arbitrary values for empty sets.
B2DPoint getMaximum() const
{
return B2DPoint(
@@ -171,6 +189,7 @@ namespace basegfx
);
}
+ /// return difference between upper and lower point. returns (0,0) for empty sets.
B2DVector getRange() const
{
return B2DVector(
@@ -179,6 +198,7 @@ namespace basegfx
);
}
+ /// return center point of set. returns (0,0) for empty sets.
B2DPoint getCenter() const
{
return B2DPoint(
@@ -187,16 +207,19 @@ namespace basegfx
);
}
+ /// return center X value of set. returns 0 for empty sets.
double getCenterX() const
{
return maRangeX.getCenter();
}
+ /// return center Y value of set. returns 0 for empty sets.
double getCenterY() const
{
return maRangeY.getCenter();
}
+ /// yields true if given point is contained in set
bool isInside(const B2DTuple& rTuple) const
{
return (
@@ -205,6 +228,7 @@ namespace basegfx
);
}
+ /// yields true if rRange is inside, or equal to set
bool isInside(const B2DRange& rRange) const
{
return (
@@ -213,6 +237,7 @@ namespace basegfx
);
}
+ /// yields true if rRange at least partly inside set
bool overlaps(const B2DRange& rRange) const
{
return (
@@ -221,6 +246,7 @@ namespace basegfx
);
}
+ /// yields true if overlaps(rRange) does, and the overlap is larger than infinitesimal
bool overlapsMore(const B2DRange& rRange) const
{
return (
@@ -229,24 +255,28 @@ namespace basegfx
);
}
+ /// add point to the set, expanding as necessary
void expand(const B2DTuple& rTuple)
{
maRangeX.expand(rTuple.getX());
maRangeY.expand(rTuple.getY());
}
+ /// add rRange to the set, expanding as necessary
void expand(const B2DRange& rRange)
{
maRangeX.expand(rRange.maRangeX);
maRangeY.expand(rRange.maRangeY);
}
+ /// calc set intersection
void intersect(const B2DRange& rRange)
{
maRangeX.intersect(rRange.maRangeX);
maRangeY.intersect(rRange.maRangeY);
}
+ /// grow set by fValue on all sides
void grow(double fValue)
{
maRangeX.grow(fValue);
diff --git a/basegfx/inc/basegfx/range/b2ibox.hxx b/basegfx/inc/basegfx/range/b2ibox.hxx
index 0a123018f090..dd23b7058e2e 100644
--- a/basegfx/inc/basegfx/range/b2ibox.hxx
+++ b/basegfx/inc/basegfx/range/b2ibox.hxx
@@ -40,22 +40,48 @@
namespace basegfx
{
- class BASEGFX_DLLPUBLIC B2IBox
+ /** A two-dimensional interval over integers
+
+ This is most easily depicted as a set of integers, bounded by
+ a lower and an upper value - but excluding the upper
+ value. All inbetween values are included in the set (see also
+ http://en.wikipedia.org/wiki/Interval_%28mathematics%29).
+
+ The set is half-open, i.e. the lower bound is included, the
+ upper bound not (if you're used to the notation - we're
+ talking about [a,b) here, compared to closed [a,b] or fully
+ open intervals (a,b)).
+
+ If you don't need a half-open interval, check B2IRange.
+
+ That means, isInside(val) will return true also for values of
+ val=a, but not for val=b.
+
+ Alternatively, consider this a rectangle, where the rightmost
+ pixel column and the bottommost pixel row are excluded - this
+ is much like polygon filling. As a result, filling a given
+ rectangle with basebmp::BitmapDevice::fillPolyPolygon(), will
+ affect exactly the same set of pixel as isInside() would
+ return true for.
+
+ @see B2IRange
+ */
+ class B2IBox
{
public:
typedef sal_Int32 ValueType;
typedef Int32Traits TraitsType;
- B2IBox()
- {
- }
+ B2IBox() {}
+ /// Create degenerate interval that's still empty
explicit B2IBox(const B2ITuple& rTuple)
: maRangeX(rTuple.getX()),
maRangeY(rTuple.getY())
{
}
+ /// Create proper interval between the two given points
B2IBox(sal_Int32 x1,
sal_Int32 y1,
sal_Int32 x2,
@@ -67,6 +93,7 @@ namespace basegfx
maRangeY.expand(y2);
}
+ /// Create proper interval between the two given points
B2IBox(const B2ITuple& rTuple1,
const B2ITuple& rTuple2) :
maRangeX(rTuple1.getX()),
@@ -75,17 +102,17 @@ namespace basegfx
expand( rTuple2 );
}
- B2IBox(const B2IBox& rBox) :
- maRangeX(rBox.maRangeX),
- maRangeY(rBox.maRangeY)
- {
- }
+ /** Check if the interval set is empty
+ @return false, if no value is in this set - having a
+ single value included will still return false.
+ */
bool isEmpty() const
{
return maRangeX.isEmpty() || maRangeY.isEmpty();
}
+ /// reset the object to empty state again, clearing all values
void reset()
{
maRangeX.reset();
@@ -104,42 +131,43 @@ namespace basegfx
|| maRangeY != rBox.maRangeY);
}
- void operator=(const B2IBox& rBox)
- {
- maRangeX = rBox.maRangeX;
- maRangeY = rBox.maRangeY;
- }
-
+ /// get lower bound of the set. returns arbitrary values for empty sets.
sal_Int32 getMinX() const
{
return maRangeX.getMinimum();
}
+ /// get lower bound of the set. returns arbitrary values for empty sets.
sal_Int32 getMinY() const
{
return maRangeY.getMinimum();
}
+ /// get upper bound of the set. returns arbitrary values for empty sets.
sal_Int32 getMaxX() const
{
return maRangeX.getMaximum();
}
+ /// get upper bound of the set. returns arbitrary values for empty sets.
sal_Int32 getMaxY() const
{
return maRangeY.getMaximum();
}
+ /// return difference between upper and lower X value. returns 0 for empty sets.
sal_Int64 getWidth() const
{
return maRangeX.getRange();
}
+ /// return difference between upper and lower Y value. returns 0 for empty sets.
sal_Int64 getHeight() const
{
return maRangeY.getRange();
}
+ /// get lower bound of the set. returns arbitrary values for empty sets.
B2IPoint getMinimum() const
{
return B2IPoint(
@@ -148,6 +176,7 @@ namespace basegfx
);
}
+ /// get upper bound of the set. returns arbitrary values for empty sets.
B2IPoint getMaximum() const
{
return B2IPoint(
@@ -156,6 +185,7 @@ namespace basegfx
);
}
+ /// return difference between upper and lower value. returns (0,0) for empty sets.
B2I64Tuple getRange() const
{
return B2I64Tuple(
@@ -164,6 +194,7 @@ namespace basegfx
);
}
+ /// return center point of set. returns (0,0) for empty sets.
B2DPoint getCenter() const
{
return B2DPoint(
@@ -172,6 +203,7 @@ namespace basegfx
);
}
+ /// yields true if point is contained in set
bool isInside(const B2ITuple& rTuple) const
{
return (
@@ -180,6 +212,7 @@ namespace basegfx
);
}
+ /// yields true if rBox is inside, or equal to set
bool isInside(const B2IBox& rBox) const
{
return (
@@ -188,6 +221,7 @@ namespace basegfx
);
}
+ /// yields true if rBox at least partly inside set
bool overlaps(const B2IBox& rBox) const
{
return (
@@ -196,24 +230,28 @@ namespace basegfx
);
}
+ /// add point to the set, expanding as necessary
void expand(const B2ITuple& rTuple)
{
maRangeX.expand(rTuple.getX());
maRangeY.expand(rTuple.getY());
}
+ /// add rBox to the set, expanding as necessary
void expand(const B2IBox& rBox)
{
maRangeX.expand(rBox.maRangeX);
maRangeY.expand(rBox.maRangeY);
}
+ /// calc set intersection
void intersect(const B2IBox& rBox)
{
maRangeX.intersect(rBox.maRangeX);
maRangeY.intersect(rBox.maRangeY);
}
+ /// grow set by nValue on all sides
void grow(sal_Int32 nValue)
{
maRangeX.grow(nValue);
@@ -244,9 +282,9 @@ namespace basegfx
@return the input vector
*/
- ::std::vector< B2IBox >& computeSetDifference( ::std::vector< B2IBox >& o_rResult,
- const B2IBox& rFirst,
- const B2IBox& rSecond );
+ BASEGFX_DLLPUBLIC ::std::vector< B2IBox >& computeSetDifference( ::std::vector< B2IBox >& o_rResult,
+ const B2IBox& rFirst,
+ const B2IBox& rSecond );
} // end of namespace basegfx
diff --git a/basegfx/inc/basegfx/range/b2irange.hxx b/basegfx/inc/basegfx/range/b2irange.hxx
index b899b0e04f6f..6f1f84a315b9 100644
--- a/basegfx/inc/basegfx/range/b2irange.hxx
+++ b/basegfx/inc/basegfx/range/b2irange.hxx
@@ -40,22 +40,40 @@
namespace basegfx
{
- class BASEGFX_DLLPUBLIC B2IRange
+ /** A two-dimensional interval over integers
+
+ This is a set of real numbers, bounded by a lower and an upper
+ pair. All inbetween values are included in the set (see also
+ http://en.wikipedia.org/wiki/Interval_%28mathematics%29).
+
+ Probably you rather want B2IBox for integers.
+
+ The set is closed, i.e. the upper and the lower bound are
+ included (if you're used to the notation - we're talking about
+ [a,b] here, compared to half-open [a,b) or open intervals
+ (a,b)).
+
+ That means, isInside(val) will return true also for values of
+ val=a or val=b.
+
+ @see B2IBox
+ */
+ class B2IRange
{
public:
typedef sal_Int32 ValueType;
typedef Int32Traits TraitsType;
- B2IRange()
- {
- }
+ B2IRange() {}
+ /// Create degenerate interval consisting of a single point
explicit B2IRange(const B2ITuple& rTuple)
: maRangeX(rTuple.getX()),
maRangeY(rTuple.getY())
{
}
+ /// Create proper interval between the two given integer pairs
B2IRange(sal_Int32 x1,
sal_Int32 y1,
sal_Int32 x2,
@@ -67,6 +85,7 @@ namespace basegfx
maRangeY.expand(y2);
}
+ /// Create proper interval between the two given points
B2IRange(const B2ITuple& rTuple1,
const B2ITuple& rTuple2)
: maRangeX(rTuple1.getX()),
@@ -75,17 +94,17 @@ namespace basegfx
expand( rTuple2 );
}
- B2IRange(const B2IRange& rRange)
- : maRangeX(rRange.maRangeX),
- maRangeY(rRange.maRangeY)
- {
- }
+ /** Check if the interval set is empty
+ @return false, if no value is in this set - having a
+ single point included will already return true.
+ */
bool isEmpty() const
{
return maRangeX.isEmpty() || maRangeY.isEmpty();
}
+ /// reset the object to empty state again, clearing all values
void reset()
{
maRangeX.reset();
@@ -104,43 +123,43 @@ namespace basegfx
|| maRangeY != rRange.maRangeY);
}
- B2IRange& operator=(const B2IRange& rRange)
- {
- maRangeX = rRange.maRangeX;
- maRangeY = rRange.maRangeY;
- return *this;
- }
-
+ /// get lower bound of the set. returns arbitrary values for empty sets.
sal_Int32 getMinX() const
{
return maRangeX.getMinimum();
}
+ /// get lower bound of the set. returns arbitrary values for empty sets.
sal_Int32 getMinY() const
{
return maRangeY.getMinimum();
}
+ /// get upper bound of the set. returns arbitrary values for empty sets.
sal_Int32 getMaxX() const
{
return maRangeX.getMaximum();
}
+ /// get upper bound of the set. returns arbitrary values for empty sets.
sal_Int32 getMaxY() const
{
return maRangeY.getMaximum();
}
+ /// return difference between upper and lower X value. returns 0 for empty sets.
sal_Int64 getWidth() const
{
return maRangeX.getRange();
}
+ /// return difference between upper and lower Y value. returns 0 for empty sets.
sal_Int64 getHeight() const
{
return maRangeY.getRange();
}
+ /// get lower bound of the set. returns arbitrary values for empty sets.
B2IPoint getMinimum() const
{
return B2IPoint(
@@ -149,6 +168,7 @@ namespace basegfx
);
}
+ /// get upper bound of the set. returns arbitrary values for empty sets.
B2IPoint getMaximum() const
{
return B2IPoint(
@@ -157,6 +177,7 @@ namespace basegfx
);
}
+ /// return difference between upper and lower point. returns (0,0) for empty sets.
B2I64Tuple getRange() const
{
return B2I64Tuple(
@@ -165,6 +186,7 @@ namespace basegfx
);
}
+ /// return center point of set. returns (0,0) for empty sets.
B2DPoint getCenter() const
{
return B2DPoint(
@@ -173,6 +195,7 @@ namespace basegfx
);
}
+ /// yields true if given point is contained in set
bool isInside(const B2ITuple& rTuple) const
{
return (
@@ -181,6 +204,7 @@ namespace basegfx
);
}
+ /// yields true if rRange is inside, or equal to set
bool isInside(const B2IRange& rRange) const
{
return (
@@ -189,6 +213,7 @@ namespace basegfx
);
}
+ /// yields true if rRange at least partly inside set
bool overlaps(const B2IRange& rRange) const
{
return (
@@ -197,24 +222,37 @@ namespace basegfx
);
}
+ /// yields true if overlaps(rRange) does, and the overlap is larger than infinitesimal
+ bool overlapsMore(const B2IRange& rRange) const
+ {
+ return (
+ maRangeX.overlapsMore(rRange.maRangeX)
+ && maRangeY.overlapsMore(rRange.maRangeY)
+ );
+ }
+
+ /// add point to the set, expanding as necessary
void expand(const B2ITuple& rTuple)
{
maRangeX.expand(rTuple.getX());
maRangeY.expand(rTuple.getY());
}
+ /// add rRange to the set, expanding as necessary
void expand(const B2IRange& rRange)
{
maRangeX.expand(rRange.maRangeX);
maRangeY.expand(rRange.maRangeY);
}
+ /// calc set intersection
void intersect(const B2IRange& rRange)
{
maRangeX.intersect(rRange.maRangeX);
maRangeY.intersect(rRange.maRangeY);
}
+ /// grow set by nValue on all sides
void grow(sal_Int32 nValue)
{
maRangeX.grow(nValue);
diff --git a/basegfx/inc/basegfx/range/b3drange.hxx b/basegfx/inc/basegfx/range/b3drange.hxx
index ca51b4f04a35..353d16cddc69 100644
--- a/basegfx/inc/basegfx/range/b3drange.hxx
+++ b/basegfx/inc/basegfx/range/b3drange.hxx
@@ -41,7 +41,7 @@ namespace basegfx
class B3IRange;
class B3DHomMatrix;
- class BASEGFX_DLLPUBLIC B3DRange
+ class B3DRange
{
typedef ::basegfx::BasicRange< double, DoubleTraits > MyBasicRange;
@@ -50,9 +50,7 @@ namespace basegfx
MyBasicRange maRangeZ;
public:
- B3DRange()
- {
- }
+ B3DRange() {}
explicit B3DRange(const B3DTuple& rTuple)
: maRangeX(rTuple.getX()),
@@ -85,14 +83,7 @@ namespace basegfx
expand(rTuple2);
}
- B3DRange(const B3DRange& rRange)
- : maRangeX(rRange.maRangeX),
- maRangeY(rRange.maRangeY),
- maRangeZ(rRange.maRangeZ)
- {
- }
-
- explicit B3DRange(const B3IRange& rRange);
+ BASEGFX_DLLPUBLIC explicit B3DRange(const B3IRange& rRange);
bool isEmpty() const
{
@@ -124,14 +115,6 @@ namespace basegfx
|| maRangeZ != rRange.maRangeZ);
}
- B3DRange& operator=(const B3DRange& rRange)
- {
- maRangeX = rRange.maRangeX;
- maRangeY = rRange.maRangeY;
- maRangeZ = rRange.maRangeZ;
- return *this;
- }
-
bool equal(const B3DRange& rRange) const
{
return (maRangeX.equal(rRange.maRangeX)
@@ -290,7 +273,7 @@ namespace basegfx
maRangeZ.grow(fValue);
}
- void transform(const B3DHomMatrix& rMatrix);
+ BASEGFX_DLLPUBLIC void transform(const B3DHomMatrix& rMatrix);
};
/** Round double to nearest integer for 3D range
@@ -298,6 +281,7 @@ namespace basegfx
@return the nearest integer for this range
*/
BASEGFX_DLLPUBLIC B3IRange fround(const B3DRange& rRange);
+
} // end of namespace basegfx
diff --git a/basegfx/inc/basegfx/range/b3ibox.hxx b/basegfx/inc/basegfx/range/b3ibox.hxx
index 4ee65cd922f4..32f021f5c8b9 100644
--- a/basegfx/inc/basegfx/range/b3ibox.hxx
+++ b/basegfx/inc/basegfx/range/b3ibox.hxx
@@ -38,16 +38,14 @@
namespace basegfx
{
- class BASEGFX_DLLPUBLIC B3IBox
+ class B3IBox
{
BasicBox maRangeX;
BasicBox maRangeY;
BasicBox maRangeZ;
public:
- B3IBox()
- {
- }
+ B3IBox() {}
explicit B3IBox(const B3ITuple& rTuple) :
maRangeX(rTuple.getX()),
diff --git a/basegfx/inc/basegfx/range/b3irange.hxx b/basegfx/inc/basegfx/range/b3irange.hxx
index c3220d03234a..8cc2925f3dfe 100644
--- a/basegfx/inc/basegfx/range/b3irange.hxx
+++ b/basegfx/inc/basegfx/range/b3irange.hxx
@@ -38,7 +38,7 @@
namespace basegfx
{
- class BASEGFX_DLLPUBLIC B3IRange
+ class B3IRange
{
typedef ::basegfx::BasicRange< sal_Int32, Int32Traits > MyBasicRange;
@@ -47,9 +47,7 @@ namespace basegfx
MyBasicRange maRangeZ;
public:
- B3IRange()
- {
- }
+ B3IRange() {}
explicit B3IRange(const B3ITuple& rTuple)
: maRangeX(rTuple.getX()),
@@ -82,13 +80,6 @@ namespace basegfx
expand(rTuple2);
}
- B3IRange(const B3IRange& rRange)
- : maRangeX(rRange.maRangeX),
- maRangeY(rRange.maRangeY),
- maRangeZ(rRange.maRangeZ)
- {
- }
-
bool isEmpty() const
{
return maRangeX.isEmpty() || maRangeY.isEmpty() || maRangeZ.isEmpty();
@@ -115,14 +106,6 @@ namespace basegfx
|| maRangeZ != rRange.maRangeZ);
}
- B3IRange& operator=(const B3IRange& rRange)
- {
- maRangeX = rRange.maRangeX;
- maRangeY = rRange.maRangeY;
- maRangeZ = rRange.maRangeZ;
- return *this;
- }
-
sal_Int32 getMinX() const
{
return maRangeX.getMinimum();
diff --git a/basegfx/inc/basegfx/range/basicbox.hxx b/basegfx/inc/basegfx/range/basicbox.hxx
index a6eae3a628f2..8e2e0efb90b7 100644
--- a/basegfx/inc/basegfx/range/basicbox.hxx
+++ b/basegfx/inc/basegfx/range/basicbox.hxx
@@ -41,14 +41,11 @@ namespace basegfx
This is modelled after how polygon fill algorithms set pixel -
typically excluding rightmost and bottommost ones.
*/
- class BASEGFX_DLLPUBLIC BasicBox : public BasicRange< sal_Int32, Int32Traits >
+ class BasicBox : public BasicRange< sal_Int32, Int32Traits >
{
typedef BasicRange< sal_Int32, Int32Traits > Base;
public:
- BasicBox() :
- Base()
- {
- }
+ BasicBox() {}
BasicBox( sal_Int32 nValue ) :
Base( nValue )
diff --git a/basegfx/inc/basegfx/range/rangeexpander.hxx b/basegfx/inc/basegfx/range/rangeexpander.hxx
deleted file mode 100644
index 509757d79750..000000000000
--- a/basegfx/inc/basegfx/range/rangeexpander.hxx
+++ /dev/null
@@ -1,86 +0,0 @@
-/* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
-/*************************************************************************
- *
- * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
- *
- * Copyright 2000, 2010 Oracle and/or its affiliates.
- *
- * OpenOffice.org - a multi-platform office productivity suite
- *
- * This file is part of OpenOffice.org.
- *
- * OpenOffice.org is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Lesser General Public License version 3
- * only, as published by the Free Software Foundation.
- *
- * OpenOffice.org is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Lesser General Public License version 3 for more details
- * (a copy is included in the LICENSE file that accompanied this code).
- *
- * You should have received a copy of the GNU Lesser General Public License
- * version 3 along with OpenOffice.org. If not, see
- * <http://www.openoffice.org/license.html>
- * for a copy of the LGPLv3 License.
- *
- ************************************************************************/
-
-#ifndef _BGFX_RANGE_RANGEEXPANDER_HXX
-#define _BGFX_RANGE_RANGEEXPANDER_HXX
-
-#include <basegfx/range/b1drange.hxx>
-#include <basegfx/range/b1irange.hxx>
-#include <basegfx/range/b2drange.hxx>
-#include <basegfx/range/b2irange.hxx>
-#include <basegfx/range/b3drange.hxx>
-#include <basegfx/range/b3irange.hxx>
-
-namespace basegfx
-{
- /** Generic functor for expanding a range with a number of other
- ranges.
-
- Since *Range::expand() is overloaded, straight-forward
- application of ::boost::bind and friends fails (because of
- ambiguities). Thus, this functor template can be used, to
- expand the given range with a number of other ranges, passed
- in at the function operator.
-
- @tpl RangeType
- Range type to operate with. Preferrably, one of B1*Range,
- B2*Range, or B3*Range.
- */
- template< typename RangeType > class RangeExpander
- {
- public:
- typedef RangeType ValueType;
- typedef void result_type;
-
- explicit RangeExpander( ValueType& rBounds ) :
- mrBounds( rBounds )
- {
- }
-
- void operator()( const ValueType& rBounds )
- {
- mrBounds.expand( rBounds );
- }
-
- private:
- ValueType& mrBounds;
- };
-
- typedef RangeExpander< B1DRange > B1DRangeExpander;
- typedef RangeExpander< B1IRange > B1IRangeExpander;
- typedef RangeExpander< B2DRange > B2DRangeExpander;
- typedef RangeExpander< B2IRange > B2IRangeExpander;
- typedef RangeExpander< B3DRange > B3DRangeExpander;
- typedef RangeExpander< B3IRange > B3IRangeExpander;
-
-} // end of namespace basegfx
-
-
-#endif /* _BGFX_RANGE_RANGEEXPANDER_HXX */
-
-/* vim:set shiftwidth=4 softtabstop=4 expandtab: */
diff --git a/basegfx/test/basegfx2d.cxx b/basegfx/test/basegfx2d.cxx
index 424133aec10b..18a046ac93c0 100644
--- a/basegfx/test/basegfx2d.cxx
+++ b/basegfx/test/basegfx2d.cxx
@@ -1268,6 +1268,10 @@ public:
Type aRange3(0,2);
CPPUNIT_ASSERT_MESSAGE("box overlapping is fully overlapping now", aRange.overlapsMore(aRange3));
+
+ // just so that this compiles -
+ Type aRange4( aRange );
+ (void)aRange4;
}
void check()