A collection of geographic distance related utility functions.
Provides the following methods:
- Determine the bounding rectangle given a point and distance.
- Distance between two points,
- Midpoint of an array of lat/lng
- Center of minimum distance for an array of lat/lng
- point:
{lat: number, lng: number}
in degrees - bounds:
{minLat: number, maxLat: number, minLng: number, maxLng: number}
in degrees
Create a new instance by providing the units you are using:
- "Miles"
- "Kilometers"
Only the first character is used.
const plasticGeo = new PlasticGeoDistance('k');
Based on the technique by Jan Matuschek.
Returns an object:
{minLat: number, maxLat: number, minLng: number, maxLng: number}
Uses the Haversine formula - credit
Returns the distance between two points.
Determining if a point is within a bounding rectangle is slightly more complex than it appears initially - bounds may encompass 0 degrees or 180 degrees longitude. This function handles this slight complexity.
Returns true
if the point is withing the given bounding rectangle ( {minLat, maxLat, minLng, maxLng}), otherwise, false
.
Returns a point that is the geographic center of an array of lat/lng objects (center of gravity).
Adapted from http://www.geomidpoint.com/calculation.html - B. Center of minimum distance
Returns an object:
{ point: { lat: number, lng: number}, avgDist: number, totalDist: number }
point
is the lat/lng with the minimum total distance to each point in the points
array, to within less than 0.1 miles (0.161 kilometers).
Run test suite with npm test
.
Please submit issues through github at mlisook plastic-geo-distance issues.
Contributions are welcome and appreciated.
MIT