1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
3 * This file is part of the LibreOffice project.
5 * This Source Code Form is subject to the terms of the Mozilla Public
6 * License, v. 2.0. If a copy of the MPL was not distributed with this
7 * file, You can obtain one at http://mozilla.org/MPL/2.0/.
9 * This file incorporates work covered by the following license notice:
11 * Licensed to the Apache Software Foundation (ASF) under one or more
12 * contributor license agreements. See the NOTICE file distributed
13 * with this work for additional information regarding copyright
14 * ownership. The ASF licenses this file to you under the Apache
15 * License, Version 2.0 (the "License"); you may not use this file
16 * except in compliance with the License. You may obtain a copy of
17 * the License at http://www.apache.org/licenses/LICENSE-2.0 .
20 #ifndef _BGFX_RANGE_B2DRANGE_HXX
21 #define _BGFX_RANGE_B2DRANGE_HXX
23 #include <basegfx/vector/b2dvector.hxx>
24 #include <basegfx/point/b2dpoint.hxx>
25 #include <basegfx/tuple/b2dtuple.hxx>
26 #include <basegfx/range/basicrange.hxx>
28 #include <basegfx/basegfxdllapi.h>
37 /** A two-dimensional interval over doubles
39 This is a set of real numbers, bounded by a lower and an upper
40 pair. All inbetween values are included in the set (see also
41 http://en.wikipedia.org/wiki/Interval_%28mathematics%29).
43 The set is closed, i.e. the upper and the lower bound are
44 included (if you're used to the notation - we're talking about
45 [a,b] here, compared to half-open [a,b) or open intervals
48 That means, isInside(val) will return true also for values of
56 typedef double ValueType
;
57 typedef DoubleTraits TraitsType
;
61 /// Create degenerate interval consisting of a single point
62 explicit B2DRange(const B2DTuple
& rTuple
)
63 : maRangeX(rTuple
.getX()),
64 maRangeY(rTuple
.getY())
68 /// Create proper interval between the two given double pairs
80 /// Create proper interval between the two given points
81 B2DRange(const B2DTuple
& rTuple1
,
82 const B2DTuple
& rTuple2
)
83 : maRangeX(rTuple1
.getX()),
84 maRangeY(rTuple1
.getY())
89 BASEGFX_DLLPUBLIC
explicit B2DRange(const B2IRange
& rRange
);
91 /** Check if the interval set is empty
93 @return false, if no value is in this set - having a
94 single point included will already return true.
100 || maRangeY
.isEmpty()
104 /// reset the object to empty state again, clearing all values
111 bool operator==( const B2DRange
& rRange
) const
113 return (maRangeX
== rRange
.maRangeX
114 && maRangeY
== rRange
.maRangeY
);
117 bool operator!=( const B2DRange
& rRange
) const
119 return (maRangeX
!= rRange
.maRangeX
120 || maRangeY
!= rRange
.maRangeY
);
123 bool equal(const B2DRange
& rRange
) const
125 return (maRangeX
.equal(rRange
.maRangeX
)
126 && maRangeY
.equal(rRange
.maRangeY
));
129 /// get lower bound of the set. returns arbitrary values for empty sets.
130 double getMinX() const
132 return maRangeX
.getMinimum();
135 /// get lower bound of the set. returns arbitrary values for empty sets.
136 double getMinY() const
138 return maRangeY
.getMinimum();
141 /// get upper bound of the set. returns arbitrary values for empty sets.
142 double getMaxX() const
144 return maRangeX
.getMaximum();
147 /// get upper bound of the set. returns arbitrary values for empty sets.
148 double getMaxY() const
150 return maRangeY
.getMaximum();
153 /// return difference between upper and lower X value. returns 0 for empty sets.
154 double getWidth() const
156 return maRangeX
.getRange();
159 /// return difference between upper and lower Y value. returns 0 for empty sets.
160 double getHeight() const
162 return maRangeY
.getRange();
165 /// get lower bound of the set. returns arbitrary values for empty sets.
166 B2DPoint
getMinimum() const
169 maRangeX
.getMinimum(),
170 maRangeY
.getMinimum()
174 /// get upper bound of the set. returns arbitrary values for empty sets.
175 B2DPoint
getMaximum() const
178 maRangeX
.getMaximum(),
179 maRangeY
.getMaximum()
183 /// return difference between upper and lower point. returns (0,0) for empty sets.
184 B2DVector
getRange() const
192 /// return center point of set. returns (0,0) for empty sets.
193 B2DPoint
getCenter() const
196 maRangeX
.getCenter(),
201 /// return center X value of set. returns 0 for empty sets.
202 double getCenterX() const
204 return maRangeX
.getCenter();
207 /// return center Y value of set. returns 0 for empty sets.
208 double getCenterY() const
210 return maRangeY
.getCenter();
213 /// yields true if given point is contained in set
214 bool isInside(const B2DTuple
& rTuple
) const
217 maRangeX
.isInside(rTuple
.getX())
218 && maRangeY
.isInside(rTuple
.getY())
222 /// yields true if rRange is inside, or equal to set
223 bool isInside(const B2DRange
& rRange
) const
226 maRangeX
.isInside(rRange
.maRangeX
)
227 && maRangeY
.isInside(rRange
.maRangeY
)
231 /// yields true if rRange at least partly inside set
232 bool overlaps(const B2DRange
& rRange
) const
235 maRangeX
.overlaps(rRange
.maRangeX
)
236 && maRangeY
.overlaps(rRange
.maRangeY
)
240 /// yields true if overlaps(rRange) does, and the overlap is larger than infinitesimal
241 bool overlapsMore(const B2DRange
& rRange
) const
244 maRangeX
.overlapsMore(rRange
.maRangeX
)
245 && maRangeY
.overlapsMore(rRange
.maRangeY
)
249 /// add point to the set, expanding as necessary
250 void expand(const B2DTuple
& rTuple
)
252 maRangeX
.expand(rTuple
.getX());
253 maRangeY
.expand(rTuple
.getY());
256 /// add rRange to the set, expanding as necessary
257 void expand(const B2DRange
& rRange
)
259 maRangeX
.expand(rRange
.maRangeX
);
260 maRangeY
.expand(rRange
.maRangeY
);
263 /// calc set intersection
264 void intersect(const B2DRange
& rRange
)
266 maRangeX
.intersect(rRange
.maRangeX
);
267 maRangeY
.intersect(rRange
.maRangeY
);
270 /// grow set by fValue on all sides
271 void grow(double fValue
)
273 maRangeX
.grow(fValue
);
274 maRangeY
.grow(fValue
);
277 BASEGFX_DLLPUBLIC
void transform(const B2DHomMatrix
& rMatrix
);
280 typedef ::basegfx::BasicRange
< ValueType
, TraitsType
> MyBasicRange
;
282 MyBasicRange maRangeX
;
283 MyBasicRange maRangeY
;
286 /** Round double to nearest integer for 2D range
288 @return the nearest integer for this range
290 BASEGFX_DLLPUBLIC B2IRange
fround(const B2DRange
& rRange
);
292 /** Compute the set difference of the two given ranges
294 This method calculates the symmetric difference (aka XOR)
295 between the two given ranges, and returning the resulting
296 ranges. Thus, the result will contain all areas where one, but
300 Result vector. The up to four difference ranges are returned
309 @return the input vector
311 BASEGFX_DLLPUBLIC ::std::vector
< B2DRange
>& computeSetDifference( ::std::vector
< B2DRange
>& o_rResult
,
312 const B2DRange
& rFirst
,
313 const B2DRange
& rSecond
);
315 } // end of namespace basegfx
318 #endif /* _BGFX_RANGE_B2DRANGE_HXX */
320 /* vim:set shiftwidth=4 softtabstop=4 expandtab: */