marble
#include <GeoDataLatLonBox.h>

Static Public Member Functions | |
static bool | crossesDateLine (qreal east, qreal west) |
static GeoDataLatLonBox | fromLineString (const GeoDataLineString &lineString) |
static bool | fuzzyCompare (const GeoDataLatLonBox &lhs, const GeoDataLatLonBox &rhs, const qreal factor=0.01) |
static qreal | height (qreal north, qreal south, GeoDataCoordinates::Unit unit=GeoDataCoordinates::Radian) |
static qreal | width (qreal east, qreal west, GeoDataCoordinates::Unit unit=GeoDataCoordinates::Radian) |
Friends | |
bool GEODATA_EXPORT | operator!= (GeoDataLatLonBox const &lhs, GeoDataLatLonBox const &rhs) |
bool GEODATA_EXPORT | operator== (GeoDataLatLonBox const &lhs, GeoDataLatLonBox const &rhs) |
Additional Inherited Members | |
![]() | |
virtual bool | equals (const GeoDataObject &other) const |
Detailed Description
A class that defines a 2D bounding box for geographic data.
GeoDataLatLonBox is a 2D bounding box that describes a geographic area in terms of latitude and longitude.
The bounding box gets described by assigning the northern, southern, eastern and western boundary. So usually the value of the eastern boundary is bigger than the value of the western boundary.
This is also true if the GeoDataLatLonBox covers the whole longitude range from 180 deg West to 180 deg East. Notably in this case the bounding box crosses the date line.
If the GeoDataLatLonBox does not cover the whole longitude range but still crosses the date line then the eastern boundary has got a smaller value than the western one.
Definition at line 51 of file GeoDataLatLonBox.h.
Constructor & Destructor Documentation
Marble::GeoDataLatLonBox::GeoDataLatLonBox | ( | ) |
Definition at line 61 of file GeoDataLatLonBox.cpp.
Marble::GeoDataLatLonBox::GeoDataLatLonBox | ( | qreal | north, |
qreal | south, | ||
qreal | east, | ||
qreal | west, | ||
GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian |
||
) |
Definition at line 67 of file GeoDataLatLonBox.cpp.
Marble::GeoDataLatLonBox::GeoDataLatLonBox | ( | const GeoDataLatLonBox & | other | ) |
Definition at line 74 of file GeoDataLatLonBox.cpp.
|
override |
Definition at line 80 of file GeoDataLatLonBox.cpp.
Member Function Documentation
void Marble::GeoDataLatLonBox::boundaries | ( | qreal & | north, |
qreal & | south, | ||
qreal & | east, | ||
qreal & | west, | ||
GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian |
||
) | const |
Definition at line 195 of file GeoDataLatLonBox.cpp.
|
virtual |
returns the center of this box
- Returns
- a coordinate, face-center of the box
Reimplemented in Marble::GeoDataLatLonAltBox.
Definition at line 307 of file GeoDataLatLonBox.cpp.
|
virtual |
Resets the bounding box to its uninitialised state (and thus contains nothing).
Reimplemented in Marble::GeoDataLatLonAltBox.
Definition at line 844 of file GeoDataLatLonBox.cpp.
|
virtual |
Reimplemented in Marble::GeoDataLatLonAltBox.
Definition at line 352 of file GeoDataLatLonBox.cpp.
bool Marble::GeoDataLatLonBox::contains | ( | const GeoDataLatLonBox & | other | ) | const |
Definition at line 361 of file GeoDataLatLonBox.cpp.
bool Marble::GeoDataLatLonBox::contains | ( | qreal | lon, |
qreal | lat | ||
) | const |
Detect whether the bounding box contains a point of given lon and lat.
- Parameters
-
lon longitude in radians. lat latitude in radians.
- Returns
- true if the box contains given point, false otherwise
Definition at line 337 of file GeoDataLatLonBox.cpp.
Detect whether the bounding box contains one of the poles.
- Returns
true
the bounding box contains one of the poles.false
the bounding box doesn't contain one of the poles.
Definition at line 320 of file GeoDataLatLonBox.cpp.
bool Marble::GeoDataLatLonBox::crossesDateLine | ( | ) | const |
Detect whether the bounding box crosses the IDL.
- Returns
true
the bounding box crosses the +/-180 deg longitude.false
the bounding box doesn't cross the +/-180 deg longitude.
Definition at line 297 of file GeoDataLatLonBox.cpp.
|
static |
Detect whether the bounding box crosses the IDL.
- Parameters
-
east radians east. west radians west.
- Returns
true
the bounding box crosses the +/-180 deg longitude.false
the bounding box doesn't cross the +/-180 deg longitude.
Definition at line 302 of file GeoDataLatLonBox.cpp.
qreal Marble::GeoDataLatLonBox::east | ( | GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian | ) | const |
Get the eastern boundary of the bounding box.
- Returns
- the longitude of the eastern boundary.
Definition at line 132 of file GeoDataLatLonBox.cpp.
|
static |
Create the smallest bounding box from a line string.
- Returns
- the smallest bounding box that contains the linestring.
Definition at line 635 of file GeoDataLatLonBox.cpp.
|
static |
Indicates whether two bounding boxes are roughly equal.
The factor specifies the margin threshold relative to the left handside bounding box within which both bounding boxes are considered equal.
- Returns
- Return value is true if both bounding box are approximately equal.
Definition at line 788 of file GeoDataLatLonBox.cpp.
qreal Marble::GeoDataLatLonBox::height | ( | GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian | ) | const |
Get the height of the latitude interval.
- Returns
- the angle covered by the latitude range.
Definition at line 281 of file GeoDataLatLonBox.cpp.
|
static |
Get the height of the latitude interval.
North and south parameters are in radians.
- Returns
- the angle covered by the latitude range in given unit.
Definition at line 286 of file GeoDataLatLonBox.cpp.
|
virtual |
Definition at line 419 of file GeoDataLatLonBox.cpp.
|
virtual |
Indicates whether the bounding box is not initialised (and contains nothing).
- Returns
- Return value is true if bounding box is not initialised.
Definition at line 783 of file GeoDataLatLonBox.cpp.
|
virtual |
Indicates whether the bounding box only contains a single 2D point ("singularity").
- Returns
- Return value is true if the height and the width of the bounding box equal zero.
Reimplemented in Marble::GeoDataLatLonAltBox.
Definition at line 778 of file GeoDataLatLonBox.cpp.
|
overridevirtual |
Provides type information for downcasting a GeoData.
Implements Marble::GeoNode.
Definition at line 85 of file GeoDataLatLonBox.cpp.
qreal Marble::GeoDataLatLonBox::north | ( | GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian | ) | const |
Get the northern boundary of the bounding box.
- Returns
- the latitude of the northern boundary.
Definition at line 90 of file GeoDataLatLonBox.cpp.
GeoDataLatLonBox & Marble::GeoDataLatLonBox::operator= | ( | const GeoDataLatLonBox & | other | ) |
Definition at line 601 of file GeoDataLatLonBox.cpp.
GeoDataLatLonBox Marble::GeoDataLatLonBox::operator| | ( | const GeoDataLatLonBox & | other | ) | const |
Definition at line 609 of file GeoDataLatLonBox.cpp.
GeoDataLatLonBox & Marble::GeoDataLatLonBox::operator|= | ( | const GeoDataLatLonBox & | other | ) |
Unites this bounding box with the given one.
- Returns
- Returns a reference to self.
Definition at line 614 of file GeoDataLatLonBox.cpp.
|
overridevirtual |
Serialize the contents of the feature to stream
.
Implements Marble::Serializable.
Definition at line 621 of file GeoDataLatLonBox.cpp.
qreal Marble::GeoDataLatLonBox::rotation | ( | GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian | ) | const |
Get the rotation of the bounding box.
- Returns
- the rotation of the bounding box.
Definition at line 187 of file GeoDataLatLonBox.cpp.
void Marble::GeoDataLatLonBox::scale | ( | qreal | verticalFactor, |
qreal | horizontalFactor | ||
) | const |
Changes the differences between the boundaries and the center by the given factor, keeping the center unchanged.
- Parameters
-
verticalFactor Vertical scale factor (affects north and south boundaries) horizontalFactor Horizontal scale factor (affects west and east boundaries)
Definition at line 233 of file GeoDataLatLonBox.cpp.
GeoDataLatLonBox Marble::GeoDataLatLonBox::scaled | ( | qreal | verticalFactor, |
qreal | horizontalFactor | ||
) | const |
Definition at line 250 of file GeoDataLatLonBox.cpp.
void Marble::GeoDataLatLonBox::setBoundaries | ( | qreal | north, |
qreal | south, | ||
qreal | east, | ||
qreal | west, | ||
GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian |
||
) |
Definition at line 214 of file GeoDataLatLonBox.cpp.
void Marble::GeoDataLatLonBox::setEast | ( | const qreal | east, |
GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian |
||
) |
Definition at line 140 of file GeoDataLatLonBox.cpp.
void Marble::GeoDataLatLonBox::setNorth | ( | const qreal | north, |
GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian |
||
) |
Definition at line 98 of file GeoDataLatLonBox.cpp.
void Marble::GeoDataLatLonBox::setRotation | ( | const qreal | rotation, |
GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian |
||
) |
Definition at line 174 of file GeoDataLatLonBox.cpp.
void Marble::GeoDataLatLonBox::setSouth | ( | const qreal | south, |
GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian |
||
) |
Definition at line 119 of file GeoDataLatLonBox.cpp.
void Marble::GeoDataLatLonBox::setWest | ( | const qreal | west, |
GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian |
||
) |
Definition at line 161 of file GeoDataLatLonBox.cpp.
qreal Marble::GeoDataLatLonBox::south | ( | GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian | ) | const |
Get the southern boundary of the bounding box.
- Returns
- the latitude of the southern boundary.
Definition at line 111 of file GeoDataLatLonBox.cpp.
GeoDataLatLonBox Marble::GeoDataLatLonBox::toCircumscribedRectangle | ( | ) | const |
- Returns
- Returns the smallest bounding box that contains this LatLonBox rotated with its given angle.
Definition at line 540 of file GeoDataLatLonBox.cpp.
GeoDataLatLonBox Marble::GeoDataLatLonBox::united | ( | const GeoDataLatLonBox & | other | ) | const |
Returns the bounding LatLonBox of this box with the given one.
Definition at line 480 of file GeoDataLatLonBox.cpp.
|
overridevirtual |
Unserialize the contents of the feature from stream
.
Implements Marble::Serializable.
Definition at line 628 of file GeoDataLatLonBox.cpp.
qreal Marble::GeoDataLatLonBox::west | ( | GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian | ) | const |
Get the western boundary of the bounding box.
- Returns
- the longitude of the western boundary.
Definition at line 153 of file GeoDataLatLonBox.cpp.
qreal Marble::GeoDataLatLonBox::width | ( | GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian | ) | const |
Get the width of the longitude interval.
- Returns
- the angle covered by the longitude range.
Definition at line 257 of file GeoDataLatLonBox.cpp.
|
static |
Get the width of the longitude interval.
East and west parameters are in radians.
- Returns
- the angle covered by the longitude range in given unit.
Definition at line 262 of file GeoDataLatLonBox.cpp.
Friends And Related Function Documentation
|
friend |
Definition at line 56 of file GeoDataLatLonBox.cpp.
|
friend |
Definition at line 47 of file GeoDataLatLonBox.cpp.
The documentation for this class was generated from the following files:
Documentation copyright © 1996-2019 The KDE developers.
Generated on Sat Dec 7 2019 02:42:15 by doxygen 1.8.7 written by Dimitri van Heesch, © 1997-2006
KDE's Doxygen guidelines are available online.