.NET wrapper for GeographicLib::DMS. More...
#include <DMS.h>
Public Types | |
enum | Component { Component::DEGREE, Component::MINUTE, Component::SECOND } |
enum | Flag { Flag::NONE, Flag::LATITUDE, Flag::LONGITUDE, Flag::AZIMUTH, Flag::NUMBER } |
Static Public Member Functions | |
static double | Decode (double d, double m, double s) |
static double | Decode (System::String^ dms, [System::Runtime::InteropServices::Out] Flag% ind) |
static double | DecodeAngle (System::String^ angstr) |
static double | DecodeAzimuth (System::String^ azistr) |
static void | DecodeLatLon (System::String^ dmsa, System::String^ dmsb, [System::Runtime::InteropServices::Out] double% lat, [System::Runtime::InteropServices::Out] double% lon, bool longfirst) |
static void | Encode (double ang, [System::Runtime::InteropServices::Out] double% d, [System::Runtime::InteropServices::Out] double% m) |
static void | Encode (double ang, [System::Runtime::InteropServices::Out] double% d, [System::Runtime::InteropServices::Out] double% m, [System::Runtime::InteropServices::Out] double% s) |
static System::String | Encode (double angle, Component trailing, unsigned prec, Flag ind, char dmssep) |
static System::String | Encode (double angle, unsigned prec, Flag ind, char dmssep) |
.NET wrapper for GeographicLib::DMS.
Parse a string representing degree, minutes, and seconds and return the angle in degrees and format an angle in degrees as degree, minutes, and seconds. In addition, handle NANs and infinities on input and output.
C# Example:
Managed C++ Example:
Visual Basic Example:
|
strong |
|
strong |
Indicator for presence of hemisphere indicator (N/S/E/W) on latitudes and longitudes.
|
inlinestatic |
Convert DMS to an angle.
[in] | d | degrees. |
[in] | m | arc minutes. |
[in] | s | arc seconds. |
This does not propagate the sign on d to the other components, so -3d20' would need to be represented as - DMS::Decode(3.0, 20.0) or DMS::Decode(-3.0, -20.0).
|
static |
Convert a string in DMS to an angle.
[in] | dms | string input. |
[out] | ind | a DMS::flag value signaling the presence of a hemisphere indicator. |
GeographicErr | if dms is malformed (see below). |
Degrees, minutes, and seconds are indicated by the characters d, ' (single quote), " (double quote), and these components may only be given in this order. Any (but not all) components may be omitted and other symbols (e.g., the ° symbol for degrees and the unicode prime and double prime symbols for minutes and seconds) may be substituted; two single quotes can be used instead of ". The last component indicator may be omitted and is assumed to be the next smallest unit (thus 33d10 is interpreted as 33d10'). The final component may be a decimal fraction but the non-final components must be integers. Instead of using d, ', and " to indicate degrees, minutes, and seconds, : (colon) may be used to separate these components (numbers must appear before and after each colon); thus 50d30'10.3" may be written as 50:30:10.3, 5.5' may be written 0:5.5, and so on. The integer parts of the minutes and seconds components must be less than 60. A single leading sign is permitted. A hemisphere designator (N, E, W, S) may be added to the beginning or end of the string. The result is multiplied by the implied sign of the hemisphere designator (negative for S and W). In addition ind is set to DMS::LATITUDE if N or S is present, to DMS::LONGITUDE if E or W is present, and to DMS::NONE otherwise. Throws an error on a malformed string. No check is performed on the range of the result. Examples of legal and illegal strings are
The decoding operation can also perform addition and subtraction operations. If the string includes internal signs (i.e., not at the beginning nor immediately after an initial hemisphere designator), then the string is split immediately before such signs and each piece is decoded according to the above rules and the results added; thus S3-2.5+4.1N
is parsed as the sum of S3
, -2.5
, +4.1N
. Any piece can include a hemisphere designator; however, if multiple designators are given, they must compatible; e.g., you cannot mix N and E. In addition, the designator can appear at the beginning or end of the first piece, but must be at the end of all subsequent pieces (a hemisphere designator is not allowed after the initial sign). Examples of legal and illegal combinations are
WARNING: "Exponential" notation is not recognized. Thus 7.0E1
is illegal, while 7.0E+1
is parsed as (7.0E) + (+1)
, yielding the same result as 8.0E
.
NOTE: At present, all the string handling in the C++ implementation GeographicLib is with 8-bit characters. The support for unicode symbols for degrees, minutes, and seconds is therefore via the UTF-8 encoding. (The JavaScript implementation of this class uses unicode natively, of course.)
Here is the list of Unicode symbols supported for degrees, minutes, seconds:
The codes with a leading zero byte, e.g., U+00b0, are accepted in their UTF-8 coded form 0xc2 0xb0 and as a single byte 0xb0.
Definition at line 19 of file dotnet/NETGeographicLib/DMS.cpp.
|
static |
Convert a string to an angle in degrees.
[in] | angstr | input string. |
GeographicErr | if angstr is malformed. |
GeographicErr | if angstr includes a hemisphere designator. |
No hemisphere designator is allowed and no check is done on the range of the result.
Definition at line 56 of file dotnet/NETGeographicLib/DMS.cpp.
|
static |
Convert a string to an azimuth in degrees.
[in] | azistr | input string. |
GeographicErr | if azistr is malformed. |
GeographicErr | if azistr includes a N/S designator. |
A hemisphere designator E/W can be used; the result is multiplied by −1 if W is present.
Definition at line 69 of file dotnet/NETGeographicLib/DMS.cpp.
|
static |
Convert a pair of strings to latitude and longitude.
[in] | dmsa | first string. |
[in] | dmsb | second string. |
[out] | lat | latitude (degrees). |
[out] | lon | longitude (degrees). |
[in] | longfirst | if true assume longitude is given before latitude in the absence of hemisphere designators (default false). |
GeographicErr | if dmsa or dmsb is malformed. |
GeographicErr | if dmsa and dmsb are both interpreted as latitudes. |
GeographicErr | if dmsa and dmsb are both interpreted as longitudes. |
GeographicErr | if decoded latitude is not in [−90°, 90°]. |
By default, the lat (resp., lon) is assigned to the results of decoding dmsa (resp., dmsb). However this is overridden if either dmsa or dmsb contain a latitude or longitude hemisphere designator (N, S, E, W). If an exception is thrown, lat and lon are unchanged.
Definition at line 36 of file dotnet/NETGeographicLib/DMS.cpp.
|
inlinestatic |
|
inlinestatic |
|
static |
Convert angle (in degrees) into a DMS string (using d, ', and ").
[in] | angle | input angle (degrees) |
[in] | trailing | DMS::component value indicating the trailing units on the string and this is given as a decimal number if necessary. |
[in] | prec | the number of digits after the decimal point for the trailing component. |
[in] | ind | DMS::flag value indicated additional formatting. |
[in] | dmssep | if non-null, use as the DMS separator character (instead of d, ', " delimiters). |
GeographicErr | if memory for the string can't be allocated. |
The interpretation of ind is as follows:
The integer parts of the minutes and seconds components are always given with 2 digits.
Definition at line 82 of file dotnet/NETGeographicLib/DMS.cpp.
|
static |
Convert angle into a DMS string (using d, ', and ") selecting the trailing component based on the precision.
[in] | angle | input angle (degrees) |
[in] | prec | the precision relative to 1 degree. |
[in] | ind | DMS::flag value indicated additional formatting. |
[in] | dmssep | if non-null, use as the DMS separator character (instead of d, ', " delimiters). |
std::bad_alloc | if memory for the string can't be allocated. |
prec indicates the precision relative to 1 degree, e.g., prec = 3 gives a result accurate to 0.1' and prec = 4 gives a result accurate to 1". ind is interpreted as in DMS::Encode with the additional facility that DMS::NUMBER represents angle as a number in fixed format with precision prec.
Definition at line 101 of file dotnet/NETGeographicLib/DMS.cpp.