mirror of https://github.com/pelias/api.git
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
50 lines
932 B
50 lines
932 B
|
|
/** |
|
normalize co-ordinates that lie outside of the normal ranges. |
|
|
|
longitude wrapping simply requires adding +- 360 to the value until it comes |
|
in to range. |
|
|
|
for the latitude values we need to flip the longitude whenever the latitude |
|
crosses a pole. |
|
**/ |
|
|
|
|
|
function wrap( lat, lon ){ |
|
|
|
var point = { lat: lat, lon: lon }; |
|
var quadrant = Math.floor( Math.abs(lat) / 90) % 4; |
|
var pole = ( lat > 0 ) ? 90 : -90; |
|
var offset = lat % 90; |
|
|
|
switch( quadrant ){ |
|
case 0: |
|
point.lat = offset; |
|
break; |
|
case 1: |
|
point.lat = pole - offset; |
|
point.lon += 180; |
|
break; |
|
case 2: |
|
point.lat = -offset; |
|
point.lon += 180; |
|
break; |
|
case 3: |
|
point.lat = -pole + offset; |
|
break; |
|
} |
|
|
|
// reduce lon |
|
while( point.lon > 180 ){ |
|
point.lon -= 360; |
|
} |
|
|
|
// increase lon |
|
while( point.lon < -180 ){ |
|
point.lon += 360; |
|
} |
|
|
|
return point; |
|
} |
|
|
|
module.exports = wrap;
|
|
|