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]
mercator.tileToBBox(tile)
Features
Function | Description |
---|
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 |
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 |
lngLatToMeters
Converts LngLat coordinates to Meters coordinates.
Parameters
lnglat
LngLat Longitude (Meridians) & Latitude (Parallels) in decimal degrees
Examples
const meters = mercator.lngLatToMeters([126, 37])
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])
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)
Returns Pixels Pixels coordinates
lngLatToTile
Converts LngLat coordinates to TMS Tile.
Parameters
lnglat
LngLat Longitude (Meridians) & Latitude (Parallels) in decimal degreeszoom
number Zoom level
Examples
const tile = mercator.lngLatToTile([126, 37], 13)
Returns Tile TMS Tile
lngLatToGoogle
Converts LngLat coordinates to Google (XYZ) Tile.
Parameters
lnglat
LngLat Longitude (Meridians) & Latitude (Parallels) in decimal degreeszoom
number Zoom level
Examples
const google = mercator.lngLatToGoogle([126, 37], 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)
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])
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])
Returns Tile TMS Tile
tileToBBoxMeters
Converts TMS Tile to bbox in Meters coordinates.
Parameters
Examples
const bbox = mercator.tileToBBoxMeters([6963, 5003, 13])
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])
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])
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])
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])
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])
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])
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])
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')
Returns Tile TMS Tile
quadkeyToGoogle
Converts Quadkey to Google (XYZ) Tile.
Parameters
quadkey
string Microsoft's Quadkey schema
Examples
const google = mercator.quadkeyToGoogle('1321102330211')
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 ])
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] orderminZoom
number Minimum ZoommaxZoom
number Maximum Zoom
Examples
const iterable = mercator.grid([-180.0, -90.0, 180, 90], 3, 8)
const {value, done} = grid.next()
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] orderminZoom
number Minimum ZoommaxZoom
number Maximum Zoomsize
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()
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] orderminZoom
number Minimum ZoommaxZoom
number Maximum Zoom
Examples
const levels = mercator.gridLevels([-180.0, -90.0, 180, 90], 3, 8)
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] orderminZoom
number Minimum ZoommaxZoom
number Maximum Zoom
Examples
const count = mercator.gridCount([-180.0, -90.0, 180, 90], 3, 8)
Returns number Total tiles from BBox
validateTile
Validates TMS Tile.
Parameters
tile
Tile Tile [x, y, zoom]
Examples
mercator.validateTile([60, 80, 12])
mercator.validateTile([60, -43, 5])
mercator.validateTile([25, 60, 3])
- 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)
mercator.validateZoom(-4)
validateZoom(32)
- 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])
mercator.validateMeters([-230, 999000000])
- 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])
mercator.validateLngLat([-225, 44])
- 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])
lngLatToMeters([lng, lat])
metersToLngLat([x, y, zoom])
metersToLngLat([x, y])
1.2.0 - 2016-10-13
Added new features:
grid
- Creates an Iterator of Tiles from a given BBoxgridBulk
- Creates a bulk Iterator of Tiles from a given BBoxgridLevels
- Creates a grid level pattern of arraysgridCount
- 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