147 CoordinateType latType);
Defines an angle and provides unit conversions.
virtual double angle(const Units &unit) const
Return angle value in desired units.
Units
The set of usable angle measurement units.
@ Radians
Radians are generally used in mathematical equations, 0-2*PI is one circle, however these are more di...
Distance measurement, usually in meters.
This class is designed to encapsulate the concept of a Latitude.
void setPlanetographic(double latitude, Angle::Units units=Angle::Radians)
Set the latitude given a value in the Planetographic coordinate system.
Distance * m_equatorialRadius
Used for converting to Planetographic, this is the radius of the target on the equatorial plane.
Latitude & operator=(const Latitude &latitudeToCopy)
This assigns another latitude to this one - making this latitude an exact duplicate of the other.
~Latitude()
This cleans up the Latitude class.
Latitude add(Angle angleToAdd, PvlGroup mapping)
Adds an angle to this latitude.
ErrorChecking
Some user-configurable error checking parameters.
@ ThrowAllErrors
Throw an exception if any problems are found.
@ AllowPastPole
Don't throw an exception if a latitude beyond -90/90 is found.
CoordinateType
These are the latitude coordinate systems.
@ Planetocentric
This is the universal (and default) latitude coordinate system.
@ Planetographic
This is a secondary coordinate system for latitudes.
bool inRange(Latitude min, Latitude max) const
Checks if this latitude value is within the given range.
void setErrorChecking(ErrorChecking errors)
Set the error checking status.
Distance * m_polarRadius
Used for converting to Planetographic, this is the radius of the target perpendicular to the equatori...
double planetographic(Angle::Units units=Angle::Radians) const
Get the latitude in the planetographic coordinate system.
Latitude()
Create a blank Latitude object without Planetographic support.
double planetocentric(Angle::Units units=Angle::Radians) const
Get the latitude in the planetocentric (universal) coordinate system.
ErrorChecking m_errors
This contains which exceptions should not be thrown.
void setPlanetocentric(double latitude, Angle::Units units=Angle::Radians)
Set the latitude given a value in the Planetocentric coordinate system.
ErrorChecking errorChecking() const
Get the error checking status.
virtual void setAngle(const double &angle, const Angle::Units &units)
Same as planetocentric.
Contains multiple PvlContainers.
This is free and unencumbered software released into the public domain.