npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

geocoordinate

v2.0.31

Published

Classes to work with geo coordinates and bounding boxes

Downloads

62

Readme

GeoCoordinate

NPM version Actions Status Actions Status

a utility Library to create and work with GeoCoordinates

Description

A tiny library to help you gettting things done with geospatial coordinates.

Installation

npm install geocoordinate

Usage

const {
    GeoCoordinate,
    BoundingBox
} = require('geocoordinate');

const brandenburgerTor = new GeoCoordinate([52.51626877497768, 13.377935641833488]);
const coord200mToNorth = brandenburgerTor.pointAtDistance(200, 0); // instance of GeoCoordinate: { coordinate: [ 52.518067418189524, 13.377935641833488 ] }

const potsdamerPlatz = new GeoCoordinate({
    latitude: 52.50947253231671,
    longitude: 13.37661188095808
});
brandenburgerTor.distanceTo(potsdamerPlatz); // 761.6555386291442
                                             // Distance in meters

const westminsterAbbay = new GeoCoordinate(51.499382976649365, -0.12724540716209276);

brandenburgerTor.quickDistanceTo(westminsterAbbay); // 932075.8108608712
brandenburgerTor.preciseDistanceTo(westminsterAbbay); // 930681.893582993


const oldBbox = new BoundingBox(); // Old way to instantiate BoundingBox, see below for more convenient method
bbox.pushCoordinate(52.51626877497768, 13.377935641833488);
bbox.pushCoordinate(51.499382976649365, -0.12724540716209276);

const newBbox = BoundingBox.fromCoordinates([52.51, 13.37], [51.49, -0.12])

newBbox.box();
/* {
    topLeftLatitude: 52.51,
    topLeftLongitude: -0.12,
    bottomRightLatitude: 51.49,
    bottomRightLongitude: 13.37
} */

newBbox.contains(52.50947253231671, 13.37661188095808); // true

oldBbox.centerLatitude();
// 52.00782587581352
oldBbox.centerLongitude();
// 6.625345117335698

API

GeoCoordinate

constructor

Usage:


new GeoCoordinate([1,1]);
new GeoCoordinate(32, 17.4);
new GeoCoordinate(62.1, 24.3, 70); // Altitude = 70m
new GeoCoordinate({
    latitude: 6,
    longitude: 18
});

.asArray()

Returns array [latitude, longitude[, altitude]].

.sortArrayByReferencePoint(arr)

Sorts arr in place by distance to reference point.


const potsdamerPlatz = new GeoCoordinate({
    latitude: 52.50947253231671,
    longitude: 13.37661188095808
});

const arr = [
    [51, 23],
    {latitude: 54, longitude: 16},
    new GeoCoordinate(64, 32)
];
potsdamerPlatz.sortArrayByReferencePoint(arr);
// arr is sorted now

.quickDistanceTo(point)

Calculates quickly distance from this to point. Not recommended for long distances. Returns meters.

.preciseDistanceTo(point)

Calculates precise distance from this to point. Returns meters.

.distance3DTo(point)

Calculates a distance between two points, assuming they are on a plain area, correcting by actual latitude distortion. Will produce bad results for long distances (>>500km) and points very close to the poles.

.pointAtDistance(distance, angle)

Calculates the coordinate that is a given number of meters from this coordinate at the given angle

  • @param {number} distance the distance in meters the new coordinate is way from this coordinate.
  • @param {number} bearing the angle in degrees at which the new point will be from the old point. In radians, clockwise from north.
  • @returns {GeoCoordinate} a new instance of this class with only the latitude and longitude set.

.bearingRadTo(distance, angleInRadians)

The same as .pointAtDistance but angle is given in radians.

.latitude()

Returns latitude of current point

.longitude()

Returns longitude of current point

.altitude()

Return altitude of the point or 0.

BoundingBox

constructor

Constructor doesn't take arguments.

const bb = new BoundingBox();
bb.pushCoordinate(52.51626877497768, 13.377935641833488);
bb.pushCoordinate({latitude: 44, longitude: 6});

fromCoordinates

const bbox = BoundingBox.fromCoordinates([32, 53], [33, 54]);

.contains(point)

Checks if point is contained in bounding box.

const bbox = BoundingBox.fromCoordinates([32, 53], [33, 54]);
bbox.contains(new GeoCoordinate(23, 44));
bbox.contains([32.5, 54.5]);