openmaptiles/README.md

100 wiersze
3.9 KiB
Markdown
Czysty Zwykły widok Historia

2016-10-05 17:47:00 +00:00
## Vector Data Source
2016-10-06 05:35:10 +00:00
*This is a work in progress towards OSM2VectorTiles v3.0*
2016-10-05 17:47:00 +00:00
This is the data source for the vector tile schema of OSM2VectorTiles.
It contains the *tm2source* project and the required database schema (views, functions).
The vector data sources stands as separate repository to foster collaboration with Wikipedia
and make it easier to fork the style without forking OSM2VectorTiles as well.
2016-10-06 05:35:10 +00:00
## Vision
The vector tile schema will contain the necessary features for creating a basemap.
We will orient ourselves on the cartography used in the [Carto Basemaps](https://carto.com/location-data-services/basemaps/).
Additional layers can be always be mixed in later on but we think OSM2VectorTiles should become less bloated in v3.0.
![Future basemaps based on OSM2VectorTiles v3.0?](./basemap_vision.png)
2016-10-05 17:47:00 +00:00
## Requirements
This vector tile schema depends on a database containing several different data sources
which need to be imported first. You can use your own ETL process or use the Docker containers from
OSM2VectorTiles.
Your PostGIS database needs the following data imported. If you use our Docker based workflow this is very straightforward to setup
but if you don't want to use Docker you can set up your own ETL pipeline to import the required data sources.
2016-10-05 17:47:00 +00:00
- [OpenStreetMap](http://wiki.openstreetmap.org/wiki/Osm2pgsql) data based on the [ClearTables osm2pgsql style](https://github.com/ClearTables/ClearTables)
- [OpenStreetMapData](http://openstreetmapdata.com/) split and simplified water polygons
- [Natural Earth](http://www.naturalearthdata.com/)
- [PostGIS Vector Tile Utils](https://github.com/mapbox/postgis-vt-util) for `LabelGrid` and `z` function
2016-10-05 17:47:00 +00:00
## Database Schema
2016-10-05 17:47:00 +00:00
The vector data source is using views, generalized tables and functions to share code between layers.
The SQL code can be found in `./schema`. The different features from OSM however are determined in the [ClearTables](https://github.com/ClearTables/ClearTables) project.
2016-10-05 17:47:00 +00:00
Each zoom level in a layer has it's own view where the data is *filtered* for the zoom level.
This keeps the filtering logic per zoom level out of the TM2Source `data.yml`.
To work on the database and vector tile schema read the *Develop* section.
2016-10-06 05:35:10 +00:00
## Develop
To work on *osm2vectortiles.tm2source* we recommend using Docker.
- Install [Docker](https://docs.docker.com/engine/installation/)
- Install [Docker Compose](https://docs.docker.com/compose/install/)
### Prepare the Database
Now start up the database container.
```bash
docker-compose up -d postgres`
```
Import water from [OpenStreetMapData](http://openstreetmapdata.com/).
```bash
docker-compose run import-water
```
Import [Natural Earth](http://www.naturalearthdata.com/) data.
```bash
docker-compose run import-natural-earth
```
Import [OpenStreetMap](http://wiki.openstreetmap.org/wiki/Osm2pgsql) data based on the [ClearTables osm2pgsql style](https://github.com/ClearTables/ClearTables).
In order to do this you first need to clone the latest ClearTables.
- [ ] *Should we use a submodule for ClearTables? On the other hand it is quite convenient to able to work directly on ClearTables while working on the style.*
```bash
git clone https://github.com/ClearTables/ClearTables.git
docker-compose run import-osm
```
2016-10-06 05:49:00 +00:00
### Work on Vector Tile Schema
2016-10-06 05:35:10 +00:00
2016-10-06 06:36:00 +00:00
Build and run the `db-schema` container each time you modify SQL code inside `./schema`.
2016-10-06 05:35:10 +00:00
```bash
2016-10-06 06:36:00 +00:00
docker-compose build db-schema
2016-10-06 05:35:10 +00:00
docker-compose run db-schema
```
To work on the *data.yml* you can start up Mapbox Studio Classic in a container
and visit `localhost:3000` and open the vector source project under `projects/osm2vectortiles.tm2source`.
```bash
docker-compose up mapbox-studio
```
2016-10-06 05:49:00 +00:00
![Develop on OSM2VectorTiles with Mapbox Studio Classic](./mapbox_studio_classic.gif)
## License
All code in this repository is under the [MIT license](./LICENSE) and the cartography decisions encoded in the schema and SQL is licensed under [CC0](https://creativecommons.org/publicdomain/zero/1.0/).