Marble::GeoDataCoordinates
#include <GeoDataCoordinates.h>
Public Types | |
enum | BearingType { InitialBearing , FinalBearing } |
enum | Notation { Decimal , DMS , DM , UTM , Astro } |
using | PtrVector = QList<GeoDataCoordinates *> |
enum | Unit { Radian , Degree } |
using | Vector = QList<GeoDataCoordinates> |
Properties | |
qreal | latitude |
qreal | longitude |
Public Member Functions | |
GeoDataCoordinates () | |
GeoDataCoordinates (const GeoDataCoordinates &other) | |
GeoDataCoordinates (qreal lon, qreal lat, qreal alt=0, GeoDataCoordinates::Unit unit=GeoDataCoordinates::Radian, int detail=0) | |
qreal | altitude () const |
qreal | bearing (const GeoDataCoordinates &other, Unit unit=Radian, BearingType type=InitialBearing) const |
quint8 | detail () const |
void | geoCoordinates (qreal &lon, qreal &lat) const |
void | geoCoordinates (qreal &lon, qreal &lat, GeoDataCoordinates::Unit unit) const |
void | geoCoordinates (qreal &lon, qreal &lat, qreal &alt) const |
void | geoCoordinates (qreal &lon, qreal &lat, qreal &alt, GeoDataCoordinates::Unit unit) const |
GeoDataCoordinates | interpolate (const GeoDataCoordinates &before, const GeoDataCoordinates &target, const GeoDataCoordinates &after, double t) const |
GeoDataCoordinates | interpolate (const GeoDataCoordinates &target, double t) const |
bool | isPole (Pole=AnyPole) const |
bool | isValid () const |
qreal | latitude () const |
qreal | latitude (GeoDataCoordinates::Unit unit) const |
QString | latToString () const |
qreal | longitude () const |
qreal | longitude (GeoDataCoordinates::Unit unit) const |
QString | lonToString () const |
GeoDataCoordinates | moveByBearing (qreal bearing, qreal distance) const |
GeoDataCoordinates | nlerp (const GeoDataCoordinates &target, double t) const |
bool | operator!= (const GeoDataCoordinates &other) const |
GeoDataCoordinates & | operator= (const GeoDataCoordinates &other) |
bool | operator== (const GeoDataCoordinates &other) const |
void | pack (QDataStream &stream) const |
const Quaternion & | quaternion () const |
GeoDataCoordinates | rotateAround (const GeoDataCoordinates &axis, qreal angle, Unit unit=Radian) const |
GeoDataCoordinates | rotateAround (const Quaternion &rotAxis) const |
void | set (qreal lon, qreal lat, qreal alt=0, GeoDataCoordinates::Unit unit=GeoDataCoordinates::Radian) |
void | setAltitude (const qreal altitude) |
void | setDetail (quint8 detail) |
void | setLatitude (qreal lat, GeoDataCoordinates::Unit unit=GeoDataCoordinates::Radian) |
void | setLongitude (qreal lon, GeoDataCoordinates::Unit unit=GeoDataCoordinates::Radian) |
qreal | sphericalDistanceTo (const GeoDataCoordinates &other) const |
QString | toString () const |
QString | toString (GeoDataCoordinates::Notation notation, int precision=-1) const |
void | unpack (QDataStream &stream) |
qreal | utmEasting () const |
QString | utmLatitudeBand () const |
qreal | utmNorthing () const |
int | utmZone () const |
Static Public Member Functions | |
static GeoDataCoordinates::Notation | defaultNotation () |
static GeoDataCoordinates | fromString (const QString &string, bool &successful) |
static QString | latToString (qreal lat, GeoDataCoordinates::Notation notation, GeoDataCoordinates::Unit unit=Radian, int precision=-1, char format='f') |
static QString | lonToString (qreal lon, GeoDataCoordinates::Notation notation, GeoDataCoordinates::Unit unit=Radian, int precision=-1, char format='f') |
static qreal | normalizeLat (qreal lat, GeoDataCoordinates::Unit=GeoDataCoordinates::Radian) |
static qreal | normalizeLon (qreal lon, GeoDataCoordinates::Unit=GeoDataCoordinates::Radian) |
static void | normalizeLonLat (qreal &lon, qreal &lat, GeoDataCoordinates::Unit=GeoDataCoordinates::Radian) |
static void | setDefaultNotation (GeoDataCoordinates::Notation notation) |
Detailed Description
A 3d point representation.
GeoDataCoordinates is the simple representation of a single three dimensional point. It can be used all through out marble as the data type for three dimensional objects. it comprises of a Quaternion for speed issues. This class was introduced to reflect the difference between a simple 3d point and the GeoDataGeometry object containing such a point. The latter is a GeoDataPoint and is simply derived from GeoDataGeometry.
- See also
- GeoDataPoint
Definition at line 39 of file GeoDataCoordinates.h.
Member Typedef Documentation
◆ PtrVector
Definition at line 94 of file GeoDataCoordinates.h.
◆ Vector
Definition at line 93 of file GeoDataCoordinates.h.
Member Enumeration Documentation
◆ BearingType
The BearingType enum specifies where to measure the bearing along great circle arcs.
When traveling along a great circle arc defined by the two points A and B, the bearing varies along the arc. The "InitialBearing" bearing corresponds to the bearing value at A, the "FinalBearing" bearing to that at B.
Definition at line 87 of file GeoDataCoordinates.h.
◆ Notation
enum used to specify the notation / numerical system
For degrees there exist two notations: "Decimal" (base-10) and the "Sexagesimal DMS" (base-60) which is traditionally used in cartography. Decimal notation uses floating point numbers to specify parts of a degree. The Sexagesimal DMS notation uses integer based Degrees-(Arc)Minutes-(Arc)Seconds to describe parts of a degree.
Enumerator | |
---|---|
Decimal | "Decimal" notation (base-10) |
DMS | "Sexagesimal DMS" notation (base-60) |
DM | "Sexagesimal DM" notation (base-60) |
Astro | < "RA and DEC" notation (used for astronomical sky coordinates) |
Definition at line 70 of file GeoDataCoordinates.h.
◆ Unit
enum used constructor to specify the units used
Internally we always use radian for mathematical convenience. However the Marble's interfaces to the outside should default to degrees.
Definition at line 55 of file GeoDataCoordinates.h.
Property Documentation
◆ latitude
|
read |
Definition at line 43 of file GeoDataCoordinates.h.
◆ longitude
|
read |
Definition at line 42 of file GeoDataCoordinates.h.
Constructor & Destructor Documentation
◆ GeoDataCoordinates() [1/3]
Marble::GeoDataCoordinates::GeoDataCoordinates | ( | const GeoDataCoordinates & | other | ) |
Definition at line 44 of file GeoDataCoordinates.cpp.
◆ GeoDataCoordinates() [2/3]
Marble::GeoDataCoordinates::GeoDataCoordinates | ( | ) |
constructs an invalid instance
Constructs an invalid instance such that calling isValid() on it will return
.
Definition at line 53 of file GeoDataCoordinates.cpp.
◆ GeoDataCoordinates() [3/3]
Marble::GeoDataCoordinates::GeoDataCoordinates | ( | qreal | lon, |
qreal | lat, | ||
qreal | alt = 0, | ||
GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian, | ||
int | detail = 0 ) |
create a geocoordinate from longitude and latitude
- Parameters
-
lon longitude lat latitude alt altitude in meters (default: 0) unit units that lon and lat get measured in (default for Radian: north pole at pi/2, southpole at -pi/2) detail detail (default: 0)
Definition at line 35 of file GeoDataCoordinates.cpp.
◆ ~GeoDataCoordinates()
|
virtual |
Definition at line 63 of file GeoDataCoordinates.cpp.
Member Function Documentation
◆ altitude()
qreal Marble::GeoDataCoordinates::altitude | ( | ) | const |
return the altitude of the Point in meters
Definition at line 688 of file GeoDataCoordinates.cpp.
◆ bearing()
qreal Marble::GeoDataCoordinates::bearing | ( | const GeoDataCoordinates & | other, |
Unit | unit = Radian, | ||
BearingType | type = InitialBearing ) const |
Returns the bearing (true bearing, the angle between the line defined by this point and the other and the prime meridian)
- Parameters
-
other The second point that, together with this point, defines a line unit Unit of the result type Type of the bearing
- Returns
- The true bearing in the requested unit, not range normalized, in clockwise direction, with the value 0 corresponding to north
Definition at line 742 of file GeoDataCoordinates.cpp.
◆ defaultNotation()
|
static |
return Notation of string representation
Definition at line 226 of file GeoDataCoordinates.cpp.
◆ detail()
quint8 Marble::GeoDataCoordinates::detail | ( | ) | const |
return the detail flag detail range: 0 for most important points, 5 for least important
Definition at line 713 of file GeoDataCoordinates.cpp.
◆ fromString()
|
static |
try to parse the string into a coordinate pair
- Parameters
-
string the string successful becomes true if the conversion succeeds
- Returns
- the geodatacoordinates
Definition at line 368 of file GeoDataCoordinates.cpp.
◆ geoCoordinates() [1/4]
void Marble::GeoDataCoordinates::geoCoordinates | ( | qreal & | lon, |
qreal & | lat ) const |
Definition at line 174 of file GeoDataCoordinates.cpp.
◆ geoCoordinates() [2/4]
void Marble::GeoDataCoordinates::geoCoordinates | ( | qreal & | lon, |
qreal & | lat, | ||
GeoDataCoordinates::Unit | unit ) const |
use this function to get the longitude and latitude with one call - use the unit parameter to switch between Radian and DMS
- Parameters
-
lon longitude lat latitude unit units that lon and lat get measured in (default for Radian: north pole at pi/2, southpole at -pi/2)
Definition at line 159 of file GeoDataCoordinates.cpp.
◆ geoCoordinates() [3/4]
void Marble::GeoDataCoordinates::geoCoordinates | ( | qreal & | lon, |
qreal & | lat, | ||
qreal & | alt ) const |
Definition at line 186 of file GeoDataCoordinates.cpp.
◆ geoCoordinates() [4/4]
void Marble::GeoDataCoordinates::geoCoordinates | ( | qreal & | lon, |
qreal & | lat, | ||
qreal & | alt, | ||
GeoDataCoordinates::Unit | unit ) const |
use this function to get the longitude, latitude and altitude with one call - use the unit parameter to switch between Radian and DMS
- Parameters
-
lon longitude lat latitude alt altitude in meters unit units that lon and lat get measured in (default for Radian: north pole at pi/2, southpole at -pi/2)
Definition at line 180 of file GeoDataCoordinates.cpp.
◆ interpolate() [1/2]
GeoDataCoordinates Marble::GeoDataCoordinates::interpolate | ( | const GeoDataCoordinates & | before, |
const GeoDataCoordinates & | target, | ||
const GeoDataCoordinates & | after, | ||
double | t ) const |
squad (spherical and quadrangle) interpolation between b and c
- Parameters
-
before First base point target Third base point (second interpolation point) after Fourth base point t Offset between b (t<=0) and c (t>=1)
Definition at line 794 of file GeoDataCoordinates.cpp.
◆ interpolate() [2/2]
GeoDataCoordinates Marble::GeoDataCoordinates::interpolate | ( | const GeoDataCoordinates & | target, |
double | t ) const |
slerp (spherical linear) interpolation between this coordinate and the given target coordinate
- Parameters
-
target Destination coordinate t Fraction 0..1 to weight between this and target
- Returns
- Interpolated coordinate between this (t<=0.0) and target (t>=1.0)
Definition at line 770 of file GeoDataCoordinates.cpp.
◆ isPole()
return whether our coordinates represent a pole This method can be used to check whether the coordinate equals one of the poles.
Definition at line 809 of file GeoDataCoordinates.cpp.
◆ isValid()
bool Marble::GeoDataCoordinates::isValid | ( | ) | const |
Returns.
if the coordinate is valid,
otherwise.
- Returns
- whether the coordinate is valid
A coordinate is valid, if at least one component has been set and the last assignment was not an invalid GeoDataCoordinates object.
Definition at line 75 of file GeoDataCoordinates.cpp.
◆ latitude() [1/2]
qreal Marble::GeoDataCoordinates::latitude | ( | ) | const |
Definition at line 220 of file GeoDataCoordinates.cpp.
◆ latitude() [2/2]
qreal Marble::GeoDataCoordinates::latitude | ( | GeoDataCoordinates::Unit | unit | ) | const |
retrieves the latitude of the GeoDataCoordinates object use the unit parameter to switch between Radian and DMS
- Parameters
-
unit units that lon and lat get measured in (default for Radian: north pole at pi/2, southpole at -pi/2)
- Returns
- latitude
Definition at line 209 of file GeoDataCoordinates.cpp.
◆ latToString() [1/2]
QString Marble::GeoDataCoordinates::latToString | ( | ) | const |
return a string representation of latitude of the coordinate convenience function that uses the default notation
Definition at line 667 of file GeoDataCoordinates.cpp.
◆ latToString() [2/2]
|
static |
- Fixme
- : UTM needs lon + lat to know latitude band and northing By now, this code returns the band+northing of the point (meridian, lat), but this can differ a lot at different locations See bug 347536 https://bugs.kde.org/show_bug.cgi?id=347536
Definition at line 563 of file GeoDataCoordinates.cpp.
◆ longitude() [1/2]
qreal Marble::GeoDataCoordinates::longitude | ( | ) | const |
Definition at line 204 of file GeoDataCoordinates.cpp.
◆ longitude() [2/2]
qreal Marble::GeoDataCoordinates::longitude | ( | GeoDataCoordinates::Unit | unit | ) | const |
retrieves the longitude of the GeoDataCoordinates object use the unit parameter to switch between Radian and DMS
- Parameters
-
unit units that lon and lat get measured in (default for Radian: north pole at pi/2, southpole at -pi/2)
- Returns
- longitude
Definition at line 193 of file GeoDataCoordinates.cpp.
◆ lonToString() [1/2]
QString Marble::GeoDataCoordinates::lonToString | ( | ) | const |
return a string representation of longitude of the coordinate convenience function that uses the default notation
Definition at line 558 of file GeoDataCoordinates.cpp.
◆ lonToString() [2/2]
|
static |
- Fixme
- : UTM needs lon + lat to know zone number and easting By now, this code returns the zone+easting of the point (lon, equator), but this can differ a lot at different locations See bug 347536 https://bugs.kde.org/show_bug.cgi?id=347536
Definition at line 407 of file GeoDataCoordinates.cpp.
◆ moveByBearing()
GeoDataCoordinates Marble::GeoDataCoordinates::moveByBearing | ( | qreal | bearing, |
qreal | distance ) const |
Returns the coordinates of the resulting point after moving this point according to the distance and bearing parameters.
- Parameters
-
bearing the same as above distance the distance on a unit sphere
Definition at line 754 of file GeoDataCoordinates.cpp.
◆ nlerp()
GeoDataCoordinates Marble::GeoDataCoordinates::nlerp | ( | const GeoDataCoordinates & | target, |
double | t ) const |
nlerp (normalized linear interpolation) between this coordinates and the given target coordinates
- Parameters
-
target Destination coordinates t Fraction 0..1 to weight between this and target
- Returns
- Interpolated coordinate between this (t<=0.0) and target (t>=1.0)
Definition at line 780 of file GeoDataCoordinates.cpp.
◆ normalizeLat()
|
static |
normalize latitude to always be in -M_PI / 2.
<= lat <= +M_PI / 2 (Radian).
- Parameters
-
lat latitude unit unit of the result
Definition at line 260 of file GeoDataCoordinates.cpp.
◆ normalizeLon()
|
static |
normalize the longitude to always be -M_PI <= lon <= +M_PI (Radian).
- Parameters
-
lon longitude unit unit of the result
Definition at line 238 of file GeoDataCoordinates.cpp.
◆ normalizeLonLat()
|
static |
normalize both longitude and latitude at the same time This method normalizes both latitude and longitude, so that the latitude and the longitude stay within the "usual" range.
NOTE: If the latitude exceeds M_PI/2 (+90.0 deg) or -M_PI/2 (-90.0 deg) then this will be interpreted as a pole traversion where the point will end up on the opposite side of the globe. Therefore the longitude will change by M_PI (180 deg). If you don't want this behaviour use both normalizeLat() and normalizeLon() instead.
- Parameters
-
lon the longitude value lat the latitude value unit unit of the result
Definition at line 305 of file GeoDataCoordinates.cpp.
◆ operator!=()
bool Marble::GeoDataCoordinates::operator!= | ( | const GeoDataCoordinates & | other | ) | const |
Definition at line 677 of file GeoDataCoordinates.cpp.
◆ operator=()
GeoDataCoordinates & Marble::GeoDataCoordinates::operator= | ( | const GeoDataCoordinates & | other | ) |
Definition at line 871 of file GeoDataCoordinates.cpp.
◆ operator==()
bool Marble::GeoDataCoordinates::operator== | ( | const GeoDataCoordinates & | other | ) | const |
Definition at line 672 of file GeoDataCoordinates.cpp.
◆ pack()
void Marble::GeoDataCoordinates::pack | ( | QDataStream & | stream | ) | const |
Serialize the contents of the feature to stream
.
Definition at line 877 of file GeoDataCoordinates.cpp.
◆ quaternion()
const Quaternion & Marble::GeoDataCoordinates::quaternion | ( | ) | const |
return a Quaternion with the used coordinates
Definition at line 762 of file GeoDataCoordinates.cpp.
◆ rotateAround() [1/2]
GeoDataCoordinates Marble::GeoDataCoordinates::rotateAround | ( | const GeoDataCoordinates & | axis, |
qreal | angle, | ||
Unit | unit = Radian ) const |
Rotates one coordinate around another.
- Parameters
-
axis The coordinate that serves as a rotation axis angle Rotation angle unit Unit of the result
- Returns
- The coordinate rotated in anticlockwise direction
Definition at line 724 of file GeoDataCoordinates.cpp.
◆ rotateAround() [2/2]
GeoDataCoordinates Marble::GeoDataCoordinates::rotateAround | ( | const Quaternion & | rotAxis | ) | const |
Definition at line 733 of file GeoDataCoordinates.cpp.
◆ set()
void Marble::GeoDataCoordinates::set | ( | qreal | lon, |
qreal | lat, | ||
qreal | alt = 0, | ||
GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian ) |
(re)set the coordinates in a GeoDataCoordinates object
- Parameters
-
lon longitude lat latitude alt altitude in meters (default: 0) unit units that lon and lat get measured in (default for Radian: north pole at pi/2, southpole at -pi/2)
Definition at line 109 of file GeoDataCoordinates.cpp.
◆ setAltitude()
void Marble::GeoDataCoordinates::setAltitude | ( | const qreal | altitude | ) |
set the altitude of the Point in meters
- Parameters
-
altitude altitude
Definition at line 682 of file GeoDataCoordinates.cpp.
◆ setDefaultNotation()
|
static |
set the Notation of the string representation
- Parameters
-
notation Notation
Definition at line 232 of file GeoDataCoordinates.cpp.
◆ setDetail()
void Marble::GeoDataCoordinates::setDetail | ( | quint8 | detail | ) |
◆ setLatitude()
void Marble::GeoDataCoordinates::setLatitude | ( | qreal | lat, |
GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian ) |
set the longitude in a GeoDataCoordinates object
- Parameters
-
lat longitude unit units that lon and lat get measured in (default for Radian: north pole at pi/2, southpole at -pi/2)
Definition at line 146 of file GeoDataCoordinates.cpp.
◆ setLongitude()
void Marble::GeoDataCoordinates::setLongitude | ( | qreal | lon, |
GeoDataCoordinates::Unit | unit = GeoDataCoordinates::Radian ) |
set the longitude in a GeoDataCoordinates object
- Parameters
-
lon longitude unit units that lon and lat get measured in (default for Radian: north pole at pi/2, southpole at -pi/2)
Definition at line 129 of file GeoDataCoordinates.cpp.
◆ sphericalDistanceTo()
qreal Marble::GeoDataCoordinates::sphericalDistanceTo | ( | const GeoDataCoordinates & | other | ) | const |
This method calculates the shortest distance between two points on a sphere.
See: https://en.wikipedia.org/wiki/Great-circle_distance
Definition at line 861 of file GeoDataCoordinates.cpp.
◆ toString() [1/2]
QString Marble::GeoDataCoordinates::toString | ( | ) | const |
return a string representation of the coordinate this is a convenience function which uses the default notation
Definition at line 379 of file GeoDataCoordinates.cpp.
◆ toString() [2/2]
QString Marble::GeoDataCoordinates::toString | ( | GeoDataCoordinates::Notation | notation, |
int | precision = -1 ) const |
return a string with the notation given by notation
- Parameters
-
notation set a notation different from the default one precision set the number of digits below degrees. The precision depends on the current notation: For Decimal representation the precision is the number of digits after the decimal point. In DMS a precision of 1 or 2 shows the arc minutes; a precision of 3 or 4 will show arc seconds. A precision beyond that will increase the number of digits after the arc second decimal point.
Definition at line 384 of file GeoDataCoordinates.cpp.
◆ unpack()
void Marble::GeoDataCoordinates::unpack | ( | QDataStream & | stream | ) |
Unserialize the contents of the feature from stream
.
Definition at line 884 of file GeoDataCoordinates.cpp.
◆ utmEasting()
qreal Marble::GeoDataCoordinates::utmEasting | ( | ) | const |
retrieves the UTM easting of the GeoDataCoordinates object, in meters.
- Returns
- UTM easting
Definition at line 698 of file GeoDataCoordinates.cpp.
◆ utmLatitudeBand()
QString Marble::GeoDataCoordinates::utmLatitudeBand | ( | ) | const |
retrieves the UTM latitude band of the GeoDataCoordinates object
- Returns
- UTM latitude band
Definition at line 703 of file GeoDataCoordinates.cpp.
◆ utmNorthing()
qreal Marble::GeoDataCoordinates::utmNorthing | ( | ) | const |
retrieves the UTM northing of the GeoDataCoordinates object, in meters
- Returns
- UTM northing
Definition at line 708 of file GeoDataCoordinates.cpp.
◆ utmZone()
int Marble::GeoDataCoordinates::utmZone | ( | ) | const |
retrieves the UTM zone of the GeoDataCoordinates object.
If the point is located on one of the poles (latitude < 80S or latitude > 84N) there is no UTM zone associated; in this case, 0 is returned.
- Returns
- UTM zone.
Definition at line 693 of file GeoDataCoordinates.cpp.
The documentation for this class was generated from the following files:
Documentation copyright © 1996-2024 The KDE developers.
Generated on Fri Nov 8 2024 12:02:44 by doxygen 1.12.0 written by Dimitri van Heesch, © 1997-2006
KDE's Doxygen guidelines are available online.