mirror of
https://github.com/protomaps/PMTiles.git
synced 2026-02-04 10:51:07 +00:00
82 lines
3.4 KiB
Markdown
82 lines
3.4 KiB
Markdown
[](https://www.npmjs.com/package/pmtiles)
|
|
[](https://bundlephobia.com/package/pmtiles)
|
|
[](https://pypi.org/project/pmtiles/)
|
|
|
|
# PMTiles
|
|
|
|
PMTiles is a single-file archive format for tiled data. A PMTiles archive can be hosted on a commodity storage platform such as S3, and enables low-cost, zero-maintenance map applications that are "serverless" - free of a custom tile backend or third party provider.
|
|
|
|
* [Protomaps Blog: Dynamic Maps, Static Storage](http://protomaps.com/blog/dynamic-maps-static-storage)
|
|
|
|
* [PMTiles Inspector](https://protomaps.github.io/PMTiles/) - inspect and preview PMTiles local or remote PMTiles archives.
|
|
* Archives on cloud storage may require CORS for the origin `https://protomaps.github.io`
|
|
|
|
* [Vector Tiles Example (US Zip Codes)](https://protomaps.github.io/PMTiles/?url=https%3A%2F%2Fpub-9288c68512ed46eca46ddcade307709b.r2.dev%2Fprotomaps-sample-datasets%2Fcb_2018_us_zcta510_500k.pmtiles)
|
|
|
|
|
|
Demos require MapLibre GL JS v1.14.1-rc.2 or later
|
|
|
|
See also:
|
|
* [Cloud Optimized GeoTIFFs](https://www.cogeo.org)
|
|
|
|
## Creating PMTiles
|
|
|
|
Download the `pmtiles` binary for your system at [go-pmtiles/Releases](https://github.com/protomaps/go-pmtiles/releases).
|
|
|
|
pmtiles convert INPUT.mbtiles OUTPUT.pmtiles
|
|
pmtiles upload OUTPUT.mbtiles s3://my-bucket?region=us-west-2 // requires AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY env vars to be set
|
|
|
|
## Consuming PMTiles
|
|
|
|
### JavaScript
|
|
|
|
See [js/README.md](js/README.md) and [js/examples](js/examples) for usage in Leaflet or MapLibre GL JS.
|
|
|
|
### Go
|
|
|
|
See the [go-pmtiles](https://github.com/protomaps/go-pmtiles) repository.
|
|
|
|
### Python
|
|
|
|
See https://github.com/protomaps/PMTiles/tree/master/python/bin for library usage
|
|
|
|
### Serverless
|
|
|
|
[PMTiles on AWS Lambda](https://github.com/protomaps/PMTiles/tree/master/serverless/aws)
|
|
|
|
[PMTiles on Cloudflare Workers](https://github.com/protomaps/PMTiles/tree/master/serverless/cloudflare)
|
|
|
|
## Specification
|
|
|
|
The current specification version is [Version 3](./spec/v3/spec.md).
|
|
|
|
## Recipes
|
|
|
|
Example of how to create a PMTiles archive from the [Census Bureau Zip Code Tabulation Areas Shapefile](https://www.census.gov/geographies/mapping-files/time-series/geo/carto-boundary-file.html) using [tippecanoe](http://github.com/protomaps/tippecanoe) and the [`pmtiles`](https://github.com/protomaps/go-pmtiles/releases) standalone binary:
|
|
|
|
```sh
|
|
# use GDAL/OGR to convert SHP to GeoJSON
|
|
ogr2ogr -t_srs EPSG:4326 cb_2018_us_zcta510_500k.json cb_2018_us_zcta510_500k.shp
|
|
# Creates a layer in the vector tiles named "zcta"
|
|
tippecanoe -zg --projection=EPSG:4326 -o cb_2018_us_zcta510_500k_nolimit.mbtiles -l zcta cb_2018_us_zcta510_500k.json
|
|
pmtiles convert cb_2018_us_zcta510_500k_nolimit.mbtiles cb_2018_us_zcta510_500k.pmtiles
|
|
```
|
|
|
|
### Uploading to Storage
|
|
|
|
Using the [PMTiles command line tool](http://github.com/protomaps/go-pmtiles):
|
|
|
|
```sh
|
|
pmtiles upload LOCAL.pmtiles "s3://BUCKET_NAME?endpoint=https://example.com®ion=region" REMOTE.pmtiles
|
|
```
|
|
|
|
Using [RClone](https://rclone.org) (do `rclone config` first)
|
|
|
|
```sh
|
|
rclone copyto LOCAL.pmtiles r2:/BUCKET/REMOTE.pmtiles --progress --s3-chunk-size=256M --s3-upload-concurrency=2
|
|
```
|
|
|
|
## License
|
|
|
|
The reference implementations of PMTiles are published under the BSD 3-Clause License. The PMTiles specification itself is public domain, or under a CC0 license where applicable.
|