OpenStreetMap: Difference between revisions
(+ http://www.mundialis.de/ows-mundialis/) |
(add pbf mport) |
||
Line 24: | Line 24: | ||
Then import with {{cmd|r.in.wms}} | Then import with {{cmd|r.in.wms}} | ||
=== Data as OSM pbf === | |||
Get data from here: | |||
* http://download.geofabrik.de/osm/ , or | |||
* all data at once from https://wiki.openstreetmap.org/wiki/Planet.osm about 40 GB compressed | |||
Read http://gdal.org/drv_osm.html. Create a OSM_CONFIG_FILE file, selecting tags. The options other_tags and all_tags should be disabled to avoid errors when creating attribute tables. | |||
When importing, use the layer and where options of {{cmd|v.in.ogr}} in order to import only the required features and in order to avoid topological problems. | |||
For example, import roads from some pbf file with v.in.ogr layer=lines where="highway <> ''". | |||
Import landuse from some pbf file with v.in.ogr layer=multipolygons where="landuse <> ''" | |||
Import landuse from some pbf file with v.in.ogr layer=multipolygons where="landuse <> ''" | |||
Import administrative boundaries for a particular level with v.in.ogr layer=multipolygons where="boundary = 'administrative' and admin_level = '<desired level'" | |||
=OSM vs. GRASS topology= | =OSM vs. GRASS topology= |
Revision as of 21:34, 15 February 2018
OSM Homepage: http://www.openstreetmap.org/
Import
- GRASS_AddOns#v.in.osm (fairly rough script)
Conversion with Mapnik to raster tiles may work, but be very careful about projection issues, typically online web map tiles are not appropriate for GIS import.
Data as shapefiles
Get data from here:
Then import with v.in.ogr
Data from WMS
- Web Map Service (WMS) for Europe: GetCapabilities to access the WMS
- Free/open world-wide server: http://www.mundialis.de/ows-mundialis/
Then import with r.in.wms
Data as OSM pbf
Get data from here:
- http://download.geofabrik.de/osm/ , or
- all data at once from https://wiki.openstreetmap.org/wiki/Planet.osm about 40 GB compressed
Read http://gdal.org/drv_osm.html. Create a OSM_CONFIG_FILE file, selecting tags. The options other_tags and all_tags should be disabled to avoid errors when creating attribute tables.
When importing, use the layer and where options of v.in.ogr in order to import only the required features and in order to avoid topological problems.
For example, import roads from some pbf file with v.in.ogr layer=lines where="highway <> ".
Import landuse from some pbf file with v.in.ogr layer=multipolygons where="landuse <> "
Import landuse from some pbf file with v.in.ogr layer=multipolygons where="landuse <> "
Import administrative boundaries for a particular level with v.in.ogr layer=multipolygons where="boundary = 'administrative' and admin_level = '<desired level'"
OSM vs. GRASS topology
OSM topological model is different to GRASS topological model. OSM topologically correct connections of the lines can be on all nodes of the line. Unlike OSM, GRASS allows to connect lines only on their starting/end nodes.Therefore after the import it is needed to split lines into the smallest segments by "v.split vertices=2". However after application of the v.split, there are too many lines and some of them are not necessary. Module v.build.polylines cats=same merges the extra lines into single polyline.
Correct topological model is necessary e.g. to perform Vector network analysis.
Example
The following image represents roundabout after the import of the OSM shapefile from geofabrik. You can see that there is only one category number 917. It means that the roundabout circle is just one line and grass does not see all connections to the other lines, because they are not on the starting/end node of the circle.
After the application of v.split it gives too many one segment lines. It is clear form the following image:
v.build.polylines merges unnecessary segments. All lines starts/ends on the intersections with other lines as can be seen on the following image:
There is another possibility to use v.clean tool=break but if there is e.g. a bridge then v.clean connects it to the roads going below it which is incorrect. The above described approach does not split the bridge there. See the difference on the following images: