Extracting OpenStreetMap data for region highlights compatible with OpenMapTiles
data:image/s3,"s3://crabby-images/7414c/7414cc5dcb06ae05136a8ce4c3fdb7b85fbf73d4" alt=""
Roman Karavia, 2020-06-17
GitHub / Twitter: @rkaravia
Neue Zürcher Zeitung (NZZ)
- German-language daily newspaper
- Online + print
- Based in Zürich, Switzerland
data:image/s3,"s3://crabby-images/4d266/4d26627e8faa4d9fea28e0b0cf53701e62d36f40" alt=""
- Visual and data-driven storytelling
- News can be more than just text
- Data! Charts! Maps!
- Tailor-made
- Reusable: Q Tools
(Open Source)
data:image/s3,"s3://crabby-images/82c9c/82c9caa87cc5ea9c31a39d4adacd309ed0a02066" alt=""
data:image/s3,"s3://crabby-images/f5336/f5336cc6314e58d2e6f3ff968d50e8cb80e8ea07" alt=""
Q Tools: Locator Maps
Online
data:image/s3,"s3://crabby-images/bc071/bc0713cd423d1a7ddc9f986b25afdb1164b3f4ca" alt=""
Article: Wuhan steht wegen des Coronavirus unter Quarantäne
Published on 2020-01-23 (online) / 2020-01-24 (print, page 22)
data:image/s3,"s3://crabby-images/f9cae/f9caed3aa9d3d071a9ad871218cb4f03bcff4434" alt=""
Problem: It should be easy to make this map
data:image/s3,"s3://crabby-images/bc071/bc0713cd423d1a7ddc9f986b25afdb1164b3f4ca" alt=""
- Users are not GIS experts
- OpenStreetMap + OpenMapTiles
already get you very far - Tiles contain boundaries but not
polygons of regions - How do we highlight regions?
Agenda
- State requirements
- Prior Art
- Overview of choices and technologies used in implementation
⚡ Demo ⚡
- Links, Questions
Requirements
-
Include enough regions to cover common use cases (countries and subdivisions)
-
Polygon or Multipolygon for each region
-
Highlight only land part
-
Compatible with base map
-
Stable identifier for every region
Prior Art
-
-
Extract OSM countries and clip to land
-
Does not have subdivisions
-
No recent updates
-
-
-
Comprehensive datasets with countries, states, provinces
-
Not matching everywhere with OpenStreetMap
-
- Not Open Data: Mapbox Boundaries, GADM
Getting Data from OpenStreetMap
1 region
data:image/s3,"s3://crabby-images/74609/7460932404caa2542a0d18495b0ec5c0e158faf7" alt=""
data:image/s3,"s3://crabby-images/0651a/0651a326ed71a62c01d1dd291dd35b3f89bc7e62" alt=""
Getting Data from OpenStreetMap
All the regions
- Which ones?
- ISO 3166 countries and subdivisions
- Query them in bulk through Overpass API
- "Database over the web"
- Documentation on OSM Wiki
- Experiment on Overpass Turbo
- Convert to GeoJSON by using query-overpass
which includes osmtogeojson
Overpass: Get 1 country + subdivisions
[out:json];
(
relation
[boundary=administrative]
["ISO3166-1"="CH"]; // country equals CH
relation
[boundary=administrative]
["ISO3166-2"~"^CH"]; // subdivision starts with CH
);
out; >; out skel;
Overpass: List all countries
[out:csv(::"id", "ISO3166-1")];
relation
[boundary=administrative]
[admin_level=2]
["ISO3166-1"];
out;
Batteries included!
- Overpass API delivers whatever OpenStreetMap contains
- Wikidata ID provides a stable identifier
- Stored in OpenStreetMap under wikidata key
- Region name in different languages
Clip to land
- Extract land areas from OpenStreetMap
- Already done by the Osmdata project
- Use mapshaper CLI: -clip
data:image/s3,"s3://crabby-images/80029/8002900d466c980f0106c565c161a52b7bd3a4b6" alt=""
Cut into tiles: Tippecanoe
- Powerful tool with many options
- But well documented and command fits on slide
tippecanoe \
--minimum-zoom=0 \
--maximum-zoom=10 \
--named-layer="{
\"file\": \"countries-clipped.json\",
\"layer\": \"countries\"
}" \
--named-layer="{
\"file\": \"subdivisions-clipped.json\",
\"layer\": \"subdivisions\"
}" \
--include=wikidata \
--simplification=4 \
--simplify-only-low-zooms \
--output regions.mbtiles
Summary
-
Dataset of countries and commonly used subdivisions
-
Available as GeoJSON + vector tiles
-
Built with lots of Open Source and Open Data
data:image/s3,"s3://crabby-images/73a6c/73a6ca1676f74aee82fe0ab808668c3de4eea6be" alt=""
⚡ Demo ⚡
The End
Slides
Code
Demo
Extracting OpenStreetMap data for region highlights compatible with OpenMapTiles
By rkaravia
Extracting OpenStreetMap data for region highlights compatible with OpenMapTiles
- 780