Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

global-mercator

Package Overview
Dependencies
Maintainers
1
Versions
71
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

global-mercator

Tools to help with TMS, Quadkey & Google (XYZ) Tiles

  • 1.3.0
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

Build Status Coverage Status npm version MIT licensed

Global Mercator

A set of tools geospatial tools to help with TMS, Google (XYZ) Tiles.

This library is insipered by GDAL2Tiles, Google Summer of Code 2007 & 2008

Another great simplistic tile library is tilebelt.

Install

$ npm install --save global-mercator

Quickstart

import * as mercator from 'global-mercator'

const tile = [10, 15, 8] // x, y, zoom

mercator.tileToBBox(tile)
// [ -165.937, -82.853, -164.531, -82.676 ]

Features

FunctionDescription
lngLatToMeters(lnglat)Converts LngLat coordinates to Meters coordinates.
metersToLngLat(meters)Converts Meters coordinates to LngLat coordinates.
metersToPixels(meters)Converts Meters coordinates to Pixels coordinates.
lngLatToTile(lnglat)Converts LngLat coordinates to TMS Tile.
lngLatToGoogle(lnglat)Converts LngLat coordinates to Google (XYZ) Tile.
metersToTile(meters)Converts Meters coordinates to TMS Tile.
pixelsToMeters(pixels)Converts Pixels coordinates to Meters coordinates.
pixelsToTile(pixels)Converts Pixels coordinates to TMS Tile.
tileToBBoxMeters(tile)Converts TMS Tile to bbox in Meters coordinates.
tileToBBox(tile)Converts TMS Tile to bbox in LngLat coordinates.
googleToBBoxMeters(google)Converts Google (XYZ) Tile to bbox in Meters coordinates.
googleToBBox(google)Converts Google (XYZ) Tile to bbox in LngLat coordinates.
tileToGoogle(tile)Converts TMS Tile to Google (XYZ) Tile.
googleToTile(google)Converts Google (XYZ) Tile to TMS Tile.
googleToQuadkey(google)Converts Google (XYZ) Tile to Quadkey.
tileToQuadkey(tile)Converts TMS Tile to QuadKey.
quadkeyToTile(quadkey)Converts Quadkey to TMS Tile.
quadkeyToGoogle(quadkey)Converts Quadkey to Google (XYZ) Tile.
bboxToMeters(bbox)Converts BBox from LngLat coordinates to Meters coordinates
gridCreates an Iterator of Tiles from a given BBox
gridBulkCreates a bulk Iterator of Tiles from a given BBox
gridLevelsCreates a grid level pattern of arrays
gridCountCounts the total amount of tiles from a given BBox

lngLatToMeters

Converts LngLat coordinates to Meters coordinates.

Parameters

  • lnglat LngLat Longitude (Meridians) & Latitude (Parallels) in decimal degrees

Examples

const meters = mercator.lngLatToMeters([126, 37])
//=[ 14026255.8, 4439106.7 ]

Returns Meters Meters coordinates

metersToLngLat

Converts Meters coordinates to LngLat coordinates.

Parameters

  • meters Meters Meters in Mercator [x, y]

Examples

const lnglat = mercator.metersToLngLat([14026255, 4439106])
//=[ 126, 37 ]

Returns LngLat LngLat coordinates

metersToPixels

Converts Meters coordinates to Pixels coordinates.

Parameters

  • meters Meters Meters in Mercator [x, y]
  • zoom number Zoom level

Examples

const pixels = mercator.metersToPixels([14026255, 4439106], 13)
//=[ 1782579.1, 1280877.3, 13 ]

Returns Pixels Pixels coordinates

lngLatToTile

Converts LngLat coordinates to TMS Tile.

Parameters

  • lnglat LngLat Longitude (Meridians) & Latitude (Parallels) in decimal degrees
  • zoom number Zoom level

Examples

const tile = mercator.lngLatToTile([126, 37], 13)
//=[ 6963, 5003, 13 ]

Returns Tile TMS Tile

lngLatToGoogle

Converts LngLat coordinates to Google (XYZ) Tile.

Parameters

  • lnglat LngLat Longitude (Meridians) & Latitude (Parallels) in decimal degrees
  • zoom number Zoom level

Examples

const google = mercator.lngLatToGoogle([126, 37], 13)
//=[ 6963, 3188, 13 ]

Returns Google Google (XYZ) Tile

metersToTile

Converts Meters coordinates to TMS Tile.

Parameters

  • meters Meters Meters in Mercator [x, y]
  • zoom number Zoom level

Examples

const tile = mercator.metersToTile([14026255, 4439106], 13)
//=[ 6963, 5003, 13 ]

Returns Tile TMS Tile

pixelsToMeters

Converts Pixels coordinates to Meters coordinates.

Parameters

  • pixels Pixels Pixels [x, y, zoom]

Examples

const meters = mercator.pixelsToMeters([1782579, 1280877, 13])
//=[ 14026252.0, 4439099.5 ]

Returns Meters Meters coordinates

pixelsToTile

Converts Pixels coordinates to TMS Tile.

Parameters

  • pixels Pixels Pixels [x, y, zoom]

Examples

const tile = mercator.pixelsToTile([1782579, 1280877, 13])
//=[ 6963, 5003, 13 ]

Returns Tile TMS Tile

tileToBBoxMeters

Converts TMS Tile to bbox in Meters coordinates.

Parameters

Examples

const bbox = mercator.tileToBBoxMeters([6963, 5003, 13])
//=[ 14025277.4, 4437016.6, 14030169.4, 4441908.5 ]

Returns BBox bbox extent in [minX, minY, maxX, maxY] order

tileToBBox

Converts TMS Tile to bbox in LngLat coordinates.

Parameters

Examples

const bbox = mercator.tileToBBox([6963, 5003, 13])
//=[ 125.991, 36.985, 126.035, 37.020 ]

Returns BBox bbox extent in [minX, minY, maxX, maxY] order

googleToBBoxMeters

Converts Google (XYZ) Tile to bbox in Meters coordinates.

Parameters

  • google Google Google [x, y, zoom]

Examples

const bbox = mercator.googleToBBoxMeters([6963, 3188, 13])
//=[ 14025277.4, 4437016.6, 14030169.4, 4441908.5 ]

Returns BBox bbox extent in [minX, minY, maxX, maxY] order

googleToBBox

Converts Google (XYZ) Tile to bbox in LngLat coordinates.

Parameters

  • google Google Google [x, y, zoom]

Examples

const bbox = mercator.googleToBBox([6963, 3188, 13])
//=[ 125.991, 36.985, 126.035, 37.020 ]

Returns BBox bbox extent in [minX, minY, maxX, maxY] order

tileToGoogle

Converts TMS Tile to Google (XYZ) Tile.

Parameters

  • tile Tile Tile [x, y, zoom]

Examples

const google = mercator.tileToGoogle([6963, 5003, 13])
//=[ 6963, 3188, 13 ]

Returns Google Google (XYZ) Tile

googleToTile

Converts Google (XYZ) Tile to TMS Tile.

Parameters

  • google Google Google [x, y, zoom]

Examples

const tile = mercator.googleToTile([6963, 3188, 13])
//=[ 6963, 5003, 13 ]

Returns Tile TMS Tile

googleToQuadkey

Converts Google (XYZ) Tile to Quadkey.

Parameters

  • google Google Google [x, y, zoom]

Examples

const quadkey = mercator.googleToQuadkey([6963, 3188, 13])
//='1321102330211'

Returns string Microsoft's Quadkey schema

tileToQuadkey

Converts TMS Tile to QuadKey.

Parameters

  • tile Tile Tile [x, y, zoom]

Examples

const quadkey = mercator.tileToQuadkey([6963, 5003, 13])
//='1321102330211'

Returns string Microsoft's Quadkey schema

quadkeyToTile

Converts Quadkey to TMS Tile.

Parameters

  • quadkey string Microsoft's Quadkey schema

Examples

const tile = mercator.quadkeyToTile('1321102330211')
//=[ 6963, 5003, 13 ]

Returns Tile TMS Tile

quadkeyToGoogle

Converts Quadkey to Google (XYZ) Tile.

Parameters

  • quadkey string Microsoft's Quadkey schema

Examples

const google = mercator.quadkeyToGoogle('1321102330211')
//=[ 6963, 3188, 13 ]

Returns Google Google (XYZ) Tile

bboxToMeters

Converts BBox from LngLat coordinates to Meters coordinates

Parameters

  • bbox BBox extent in [minX, minY, maxX, maxY] order

Examples

const meters = mercator.bboxToMeters([ 125, 35, 127, 37 ])
//=[ 13914936.3, 4163881.1, 14137575.3, 4439106.7 ]

Returns BBox bbox extent in [minX, minY, maxX, maxY] order

grid

Creates an Iterator of Tiles from a given BBox

Parameters

  • bbox BBox extent in [minX, minY, maxX, maxY] order
  • minZoom number Minimum Zoom
  • maxZoom number Maximum Zoom

Examples

const iterable = mercator.grid([-180.0, -90.0, 180, 90], 3, 8)
const {value, done} = grid.next()
//=value
//=done

Returns IterableIterator<Tile> Iterable Tiles from BBox

gridBulk

Creates a bulk Iterator of Tiles from a given BBox

Parameters

  • bbox BBox extent in [minX, minY, maxX, maxY] order
  • minZoom number Minimum Zoom
  • maxZoom number Maximum Zoom
  • size number Maximum size for bulk Tiles

Examples

const grid = mercator.gridBulk([-180.0, -90.0, 180, 90], 3, 8, 5000)
const {value, done} = grid.next()
//=value
//=done

Returns IterableIterator<Array<Tile>> Bulk iterable Tiles from BBox

gridLevels

Creates a grid level pattern of arrays

Parameters

  • bbox BBox extent in [minX, minY, maxX, maxY] order
  • minZoom number Minimum Zoom
  • maxZoom number Maximum Zoom

Examples

const levels = mercator.gridLevels([-180.0, -90.0, 180, 90], 3, 8)
//=levels

Returns Array<GridLevel> Grid Level

gridCount

Counts the total amount of tiles from a given BBox

Parameters

  • bbox BBox extent in [minX, minY, maxX, maxY] order
  • minZoom number Minimum Zoom
  • maxZoom number Maximum Zoom

Examples

const count = mercator.gridCount([-180.0, -90.0, 180, 90], 3, 8)
//=563136

Returns number Total tiles from BBox

validateTile

Validates TMS Tile.

Parameters

  • tile Tile Tile [x, y, zoom]

Examples

mercator.validateTile([60, 80, 12])
//=[60, 80, 12]
mercator.validateTile([60, -43, 5])
//= Error: Tile <y> must not be less than 0
mercator.validateTile([25, 60, 3])
//= Error: Illegal parameters for tile
  • Throws Error Will throw an error if TMS Tile is not valid.

Returns Tile TMS Tile

validateZoom

Validates Zoom level.

Parameters

Examples

mercator.validateZoom(12)
//=12
mercator.validateZoom(-4)
//= Error: <zoom> cannot be less than 0
validateZoom(32)
//= Error: <zoom> cannot be greater than 30
  • Throws Error Will throw an error if zoom is not valid.

Returns number zoom Zoom level

validateMeters

Validates Meters coordinates.

Parameters

  • meters Meters Meters in Mercator [x, y]

Examples

mercator.validateMeters([-115, 44])
//= [ -115, 44 ]
mercator.validateMeters([-230, 999000000])
//= Error: Meters [y] cannot be greater than 20037508.342789244
  • Throws Error Will throw an error if Meters is not valid.

Returns Array<number> Meters coordinates

validateLngLat

Validates LngLat coordinates.

Parameters

  • lnglat LngLat Longitude (Meridians) & Latitude (Parallels) in decimal degrees

Examples

mercator.validateLngLat([-115, 44])
//= [ -115, 44 ]
mercator.validateLngLat([-225, 44])
//= Error: LngLat [lng] must be within -180 to 180 degrees
  • Throws Error Will throw an error if LngLat is not valid.

Returns LngLat LngLat coordinates

validatePixels

Validates Pixels coordinates.

Parameters

Examples

validatePixels([-115, 44])
  • Throws Error Will throw an error if Pixels is not valid.

Returns Pixels Pixels coordinates

Changelog

1.3.0 - 2016-10-14

  • Enforcing validation with validateLngLat, validateMeters & validateTile
  • Reviewed entire documentation
  • Dropped zoom @param from functions with only LatLng & Meters.
lngLatToMeters([lng, lat, zoom])
// Changed to
lngLatToMeters([lng, lat])

metersToLngLat([x, y, zoom])
// Changed to
metersToLngLat([x, y])

1.2.0 - 2016-10-13

Added new features:

  • grid - Creates an Iterator of Tiles from a given BBox
  • gridBulk - Creates a bulk Iterator of Tiles from a given BBox
  • gridLevels - Creates a grid level pattern of arrays
  • gridCount - Counts the total amount of tiles from a given BBox

1.1.0 - 2016-10-03

  • Remove Default export
  • Modules compiles only to ES6

1.0.0 - 2016-10-01

First Stable release was created

Keywords

FAQs

Package last updated on 14 Oct 2016

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc