Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Geovation/tiler
A no nonsense Vector Tile pipeline
https://github.com/Geovation/tiler
converter docker-container dockerfile geojson mbtiles ogr2ogr python shapefile tile vector-tiles
Last synced: 2 months ago
JSON representation
A no nonsense Vector Tile pipeline
- Host: GitHub
- URL: https://github.com/Geovation/tiler
- Owner: Geovation
- License: mit
- Created: 2017-02-28T10:18:05.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2017-09-21T20:56:41.000Z (over 7 years ago)
- Last Synced: 2024-11-12T11:46:14.145Z (2 months ago)
- Topics: converter, docker-container, dockerfile, geojson, mbtiles, ogr2ogr, python, shapefile, tile, vector-tiles
- Language: Python
- Homepage:
- Size: 3.07 MB
- Stars: 151
- Watchers: 14
- Forks: 16
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Contributing: docs/CONTRIBUTING.md
- License: LICENSE.txt
Awesome Lists containing this project
- awesome-vector-tiles - tiler @GeoVation - Command line tool for converting GeoJSON, Shapefiles or PostGIS layer to raw Vector Tiles (or MBTiles) (CLI Utilities)
README
A no nonsense Vector Tile pipelineThe purpose of Tiler is to create an easy to use, command line orientied pipeline for taking vector data in formats such as Shapefiles, and transforming them into raw [Vector Tiles](https://www.mapbox.com/vector-tiles/) and [MBTiles](https://www.mapbox.com/help/an-open-platform/#mbtiles) files (if required).
Tiler exists as a Docker container that unifies several technologies to streamline the creation of vector tiles.
![CircleCI Badge](https://circleci.com/gh/Geovation/tiler.png?circle-token=89b1ab9fc960f4b88f85668bdd20183015740243)
**Blog Posts**
* [Introducing Tiler](https://geovation.github.io/tiler)
* [Building Your Own Vector Tile Pipeline](https://geovation.github.io/build-your-own-static-vector-tile-pipeline)
* [Introducing Tippecanoe Directory Support](https://geovation.github.io/tippecanoe-directory-support)#### Setup
Setup requires installation of Docker and a few Docker commands to get started. We've provided a nice little set of instructions in the [SETUP](https://github.com/Geovation/tiler/blob/master/docs/SETUP.md) file.
#### Using Tiler
Tiler provides a selection of scripts for converting between various formats and validating them (see the tiler-scripts folder). The primary and simplest way to use Tiler however is to use a config file placed in `tiler/tiler-data/configs`. Here is an example config file which references a shapefile and a table in a PostGIS database:
```javascript
{"outdir" : "/tiler-data/tiles/",
"tileset" : "states",
"simplification" : 5,
"validate" : false,
"data" : {"states" : {
"type" : "shapefile",
"databaseInsert" : true,
"paths" : ["/tiler-data/test-data/states/states.shp"],
"minzoom" : 0,
"maxzoom" : 5
},"capitals" : {
"type" : "postgis",
"query" : "select * from capitals"
"minzoom" : 2,
"maxzoom" : 10
}}
}
```This would be saved as `tiler-data/configs/states.tiler.json`. For full documentation of the tiler config, consult the [CONFIG](https://github.com/Geovation/tiler/blob/master/docs/CONFIG.md) file in this repo. The file provides the location of the files you wish to translate, along with the output directory and if you want any simplification to occur. "data" is an object full of layers you wish to be ingested into the tiles. In this case the layer has multiple files that they use to generate that layer ("paths"). You can also provide a minimum zoom ("minzoom") and a maximum zoom ("maxzoom") for each layer.
At the moment "type" can be `shapefile` or `geojson`, `postgis` and `gml`.
Once your config file is setup, and you have followed the setup instructions you can run:
`./run.sh states`
To generate the set of uncompressed vector tiles and an .mbtiles file.
### Tests
#### Running Tests
A set of tests are provided that can be run using [nosetest](http://nose.readthedocs.io/en/latest/).
`./run.sh --test`
#### Vector Tile Demo
A worked example; we could run the states config file as such:
`./run.sh states`
After having ran this, there would be a set of states tiles in the `tiler/tiler-data/tiles/states` directory. You can then run a web server (i.e. python -m SimpleHTTPServer or [live-server](https://www.npmjs.com/package/live-server)) **from the host, with the tiler directory as the root**. You can then navigate to the demos folder to try out those demo pages.
Demos are provided using [Leaflet.VectorGrid](http://leaflet.github.io/Leaflet.VectorGrid/vectorgrid-api-docs.html) and also [Mapbox GL](https://www.mapbox.com/mapbox-gl-js/api/) for you to display your tiles when you're done. You will need to specify your own styling in these examples.
## Roadmap
See our contribution guide [here](https://github.com/Geovation/tiler/blob/master/docs/CONFIG.md)
Check out the roadmap [here](https://github.com/Geovation/tiler/projects/1)## Credits
This project was made possible thanks to building on a fantastic set of previous previous software:
* [tippecanoe](https://github.com/mapbox/tippecanoe) - Mapbox
* [ogr2ogr](http://www.gdal.org/ogr2ogr.html) - OSGeo
* [PostGIS Docker Container](https://github.com/kartoza/docker-postgis) - Tim Sutton## License
[MIT License](https://github.com/Geovation/tiler/blob/master/LICENSE.txt)