Coordinates (v2.1.x – 2.2.x)
Map coordinates
Geo locations in Navmii SDK is represented as NMMapCoordinates class instances. As expected, it has two properties: latitude (takes values from -90 to 90) and longitude (takes values from -180 to 180) . You can create NMMapCoordinates instances in two ways: via instance or class methods.
//creates an NMMapCoordinates object representing London coordinates
NMMapCoordinates *mapCoordinates = [[NMMapCoordinates alloc] initWithLatitude:51.50833
longitude:-0.12574];
//or, alternatively
NMMapCoordinates *mapCoordinates = [NMMapCoordinates mapCoordinatesWithLatitude:51.50833
longitude:-0.12574];
Calculating distance
An instance of NMMapCoordinates class can be used to calculate the distance between two pairs of coordinates using distanceTo: method.
NMMapCoordinates *mapCoordinates1 = [[NMMapCoordinates alloc] initWithLatitude:51.50833
longitude:-0.12574];
NMMapCoordinates *mapCoordinates2 = [[NMMapCoordinates alloc] initWithLatitude:53.15785
longitude:1.68682];
double distance = [mapCoordinates1 distanceTo:mapCoordinates2];
Rectangular area
Navmii SDK also has NMMapRectangle class representing a rectangle area on the map. It can be created using initWithMinLongitude:minLatitude:maxLongitude:maxLatitude: and initWithTopLeft:bottomRight: instance methods and mapRectangleFromCoordinates: class method. The later creates an NMMapRectangle surrounding all the coordinates passed as the argument.
//creates an NMMapRectangle with four double values
NMMapRectangle *mapRectangle = [[NMMapRectangle alloc] initWithMinLongitude:minLongitude
minLatitude:minLatitude
maxLongitude:maxLongitude
maxLatitude:maxLatitude];
//or, alternatively
NMMapCoordinates *leftTop = [NMMapCoordinates mapCoordinatesWithLatitude:maxLatitude
longitude:minLongitude];
NMMapCoordinates *rightBottom = [NMMapCoordinates mapCoordinatesWithLatitude:minLatitude
longitude:maxLongitude];
NMMapRectangle *mapRectangle = [[NMMapRectangle alloc] initWithTopLeft:leftTop
bottomRight:rightBottom];Calculating bounding rectangle
//creates an NMMapRectangle bounding all the coordinates in coordinatesArray
NMMapRectangle *mapRectangle = [NMMapRectangle mapRectangleFromCoordinates:coordinatesArray];