Difference between revisions of "OpenStreetMap"

From Navit's Wiki
Jump to: navigation, search
(JFF-Webhosting OSM)
m (Removed links to services that don't work anymore)
 
(31 intermediate revisions by 16 users not shown)
Line 1: Line 1:
OpenStreetMap is a free editable map of the whole world. It is made by people like you. OpenStreetMap allows you to view, edit and use geographical data in a collaborative way from anywhere on Earth. Maps from OpenStreetMap can be used in Navit.
+
[http://www.openstreetmap.org OpenStreetMap] is a free editable map of the whole world. It is made by people like you. OpenStreetMap allows you to view, edit and use geographical data in a collaborative way from anywhere on Earth. Maps from OpenStreetMap can be used in Navit.
  
 
==Quick Start==
 
==Quick Start==
 
# Go to [http://maps.navit-project.org/ Navit Planet Extractor] (http://maps.navit-project.org/)
 
# Go to [http://maps.navit-project.org/ Navit Planet Extractor] (http://maps.navit-project.org/)
# Zoom in and select the area that you are interested in (ATTENTION: Select the upper left corner first, otherwise the map will not be accepted by navit). Use the 'Map Controls' on the right to switch between 'Navigation' and 'Select' modes.
+
# Zoom in and select the area that you are interested in. Use the 'Map Controls' on the right to switch between 'Navigation' and 'Select' modes. or use preselected areas:
# Hit '''Get Map!'''
 
# Move the downloaded map to the directory of your choice, and add it to the active [[Configuring_Navit#The_mapset|mapset]] in navit.xml with a line similar to the following:
 
 
 
<mapset>
 
  <map type="binfile" enabled="yes" data="/path/to/your/map/osm_bbox.bin" />
 
</mapset>
 
 
 
==Pre-Processed Maps==
 
A variety of sources provide pre-processed OSM maps for Navit.
 
 
 
===Maintained by the Navit Team===
 
=====[http://maps.navit-project.org/ Navit Planet Extractor]=====
 
The [http://maps.navit-project.org/ Navit Planet Extractor] allows you to select and download a custom region on the map. Some pre-defined areas are linked below:
 
* [http://maps.navit-project.org/planet.bin Entire planet]
 
 
* [http://maps.navit-project.org/api/map/?bbox=5.185546875,46.845703125,15.46875,55.634765625 Germany]
 
* [http://maps.navit-project.org/api/map/?bbox=5.185546875,46.845703125,15.46875,55.634765625 Germany]
 
* [http://maps.navit-project.org/api/map/?bbox=-5.44921875,42.01171875,8.437500000000002,51.6796875 France]
 
* [http://maps.navit-project.org/api/map/?bbox=-5.44921875,42.01171875,8.437500000000002,51.6796875 France]
Line 23: Line 9:
 
* [http://maps.navit-project.org/api/map/?bbox=-11.0302734375,34.87060546875,4.614257812500003,44.40673828125 Spain/Portugal]
 
* [http://maps.navit-project.org/api/map/?bbox=-11.0302734375,34.87060546875,4.614257812500003,44.40673828125 Spain/Portugal]
 
* [http://maps.navit-project.org/api/map/?bbox=6.52587890625,36.38671875,18.96240234375,47.197265625 Italy]
 
* [http://maps.navit-project.org/api/map/?bbox=6.52587890625,36.38671875,18.96240234375,47.197265625 Italy]
 +
* [http://maps.navit-project.org/planet.bin Entire planet] (curr. 10GB!)
 +
# Hit '''Get Map!'''
 +
# Move the downloaded map to the directory of your choice, and add it to the active the mapset (see [[Configuration]]) in navit.xml with a line similar to the following:
  
===Maintained by Others===
+
<mapset>
As these maps sources are not maintained by the Navit team, they may be using an old or incompatible version of maptool to convert the OSM data to Navit binfiles. If you have an issue with theses maps, please try using a map from our [http://maps.navit-project.org/| Planet Extractor] before reporting a bug.
+
  <map type="binfile" enabled="yes" data="/path/to/your/map/osm_bbox.bin" />
 
+
</mapset>
=====[http://downloads.cloudmade.com/ Cloudmade]=====
 
<strike>Cloudmade process the OSM planet and provide Navit-compatible binfiles for each country.</strike> '''Recent reports suggest that cloudmade maps are not compatible with the latest svn builds of Navit. Please use another source for maps. [http://developers.cloudmade.com/issues/show/857 A ticket has been raised at cloudmade]. 09:01, 15 January 2011 (UTC)'''
 
 
 
=====[http://jff-webhosting.net/osm/navit/world/ JFF-Webhosting OSM]=====
 
Navit-compatible OSM binfiles of Austria, Belgium, Germany, Luxembourg and The Netherlands. The German extracts are divided by state. Extracts of complete continents also available. Extracts are updated frequently.
 
 
 
=====[http://dev.openstreetmap.org/~deelkar/maps/ Deelkar]=====
 
Navit-compatible OSM binfiles of Austria, France, Germany, Great Britain, The Netherlands, Poland, Slovakia, Sweden and Switzerland. '''Note that all countries except Germany have not been updated since 19/10/2010.'''
 
 
 
=====[http://dl.artpc.ch/navit/maps/ ArtPC]=====
 
Navit-compatible OSM binfiles of Austria, Germany, Liechtenstein, Switzerland, DACH and Benelux '''(Note: since January 2012 all maps are created with a patch for multipolygon-lakes. So, the lakes are all visible in these maps)'''.
 
  
 
===Add OSM map to your mapset===
 
===Add OSM map to your mapset===
Move the downloaded map to the directory of your choice, and add it to the active [[Configuring_Navit#The_mapset|mapset]] in navit.xml with a line similar to the following:
+
Move the downloaded map to the directory of your choice, and add it to the active mapset (see [[Configuration]]) in navit.xml with a line similar to the following:
  
 
  <mapset>
 
  <mapset>
 
   <map type="binfile" enabled="yes" data="/path/to/your/map/my_downloaded_map.bin" />
 
   <map type="binfile" enabled="yes" data="/path/to/your/map/my_downloaded_map.bin" />
 
  </mapset>
 
  </mapset>
 +
 +
==Topographic Maps==
 +
Navit will display elevation/height lines but the required data is not included in most OSM derived maps.
 +
 +
Navit compatible maps with height lines can be created by feeding the output of Phyghtmap (http://wiki.openstreetmap.org/wiki/Phyghtmap, http://katze.tfiu.de/projects/phyghtmap/) to Navit's maptool. Alternatively the SRTM data can be downloaded in osm.xml format http://geoweb.hft-stuttgart.de/SRTM/srtm_as_osm/, avoiding the Phygtmap step. The information can be either merged with OSM derived maps or used in a separate layer.
 +
 +
Many Garmin type maps such as http://www.wanderreitkarte.de/garmin_de.php also have the height lines information but routing will not work with them.
  
 
==Processing OSM Maps Yourself==
 
==Processing OSM Maps Yourself==
You can create your own Navit binfiles from OSM data very easily using ''maptool'', the conversion program which installs alongside Navit. ''maptool'' can process both OpenStreetMap XML Data files (*.osm files) and OpenStreetMap Protobuf Data files (*.pbf files) Follow these steps to process your own maps.
+
You can create your own Navit binfiles from OSM data very easily using [[maptool]], the conversion program which installs alongside Navit. ''maptool'' can process both OpenStreetMap XML Data files (*.osm files) and OpenStreetMap Protobuf Data files (*.pbf files) Follow these steps to process your own maps.
  
 
===Download your own OSM data===
 
===Download your own OSM data===
 +
{{note
 +
|Navit 0.2.0 cannot process OpenStreetMap Protobuf Data files - for this functionality, please upgrade to one of the [[Download_Navit| latest SVN builds or build from SVN source]]. Functionality was added in {{revision|3871}}.
 +
}}
 +
 
OSM data can be downloaded from a variety of sources. OpenStreetMap XML Data files are regular textfiles, easily editable in any text editor. OpenStreetMap Protobuf Data files are binary files, which take up less space (so are quicker to download and process) but are not editable.
 
OSM data can be downloaded from a variety of sources. OpenStreetMap XML Data files are regular textfiles, easily editable in any text editor. OpenStreetMap Protobuf Data files are binary files, which take up less space (so are quicker to download and process) but are not editable.
  
''Note: Navit 0.2.0 cannot process OpenStreetMap Protobuf Data files - for this functionality, please upgrade to one of the [[Download_Navit| latest SVN builds or build from SVN source]]. Functionality was added in {{revision|3871}}.''
 
 
* '''OpenStreetMap XML Data'''
 
* '''OpenStreetMap XML Data'''
** [http://www.openstreetmap.org/export OpenStreetMap (visual)] allows you to select a rectangular area and download the selection as OpenStreetMap XML Data. Note that OpenStreetMap only allows you to export small areas for performance reasons (i.e. it is unlikely that you'll be able to download an entire country using this export facility).
+
** [http://download.geofabrik.de/osm/ Geofabrik] provides pre-processed OpenStreetMap XML Data files of almost all countries, and all continents. This method is probably the easiest way of downloading OpenStreetMap XML Data for an entire country or continent. Note that the OSM files are bzipped
** [http://download.geofabrik.de/osm/ Geofabrik] provides pre-processed OpenStreetMap XML Data files of almost all countries, and all continents. This method is probably the easiest way of downloading OpenStreetMap XML Data for an entire country or continent. Note that the OSM files are bzipped for download performance - there is no need to unzip after download, as you'll see.
 
 
** [http://planet.openstreetmap.org planet.openstreetmap.org] hosts the complete data set (the whole world). You can use [http://wiki.openstreetmap.org/index.php/Osmosis Osmosis] to cut it into smaller chunks.
 
** [http://planet.openstreetmap.org planet.openstreetmap.org] hosts the complete data set (the whole world). You can use [http://wiki.openstreetmap.org/index.php/Osmosis Osmosis] to cut it into smaller chunks.
** [http://wiki.openstreetmap.org/wiki/API_v0.6#Retrieving_map_data_by_bounding_box:_GET_.2Fapi.2F0.6.2Fmap OpenStreetMap (API)] The API allows to get the data of a specific bounding box, so that download managers can be used. For example:
+
** [http://wiki.openstreetmap.org/wiki/Xapi OpenStreetMap ReadOnly (XAPI)] The API allows to get the data of a specific bounding box, so that download managers can be used. For example:
 
  wget -O map.osm "http://xapi.openstreetmap.org/api/0.6/map?bbox=11.4,48.7,11.6,48.9"
 
  wget -O map.osm "http://xapi.openstreetmap.org/api/0.6/map?bbox=11.4,48.7,11.6,48.9"
 +
** [http://www.openstreetmap.org/export OpenStreetMap (visual)] allows you to select a small rectangular area and download the selection as OpenStreetMap XML Data.
 
*'''OpenStreetMap Protobuf Data'''
 
*'''OpenStreetMap Protobuf Data'''
 
** [http://download.geofabrik.de/osm/ Geofabrik] provides pre-processed OpenStreetMap Protobuf Data files of almost all countries, and all continents.
 
** [http://download.geofabrik.de/osm/ Geofabrik] provides pre-processed OpenStreetMap Protobuf Data files of almost all countries, and all continents.
Line 64: Line 52:
 
===Convert OSM data to Navit binfile===
 
===Convert OSM data to Navit binfile===
 
The following examples assume that you have installed Navit system-wide. If this is not the case, you will need to provide an absolute path to the ''maptool'' executable, which is in the navit/maptool folder.
 
The following examples assume that you have installed Navit system-wide. If this is not the case, you will need to provide an absolute path to the ''maptool'' executable, which is in the navit/maptool folder.
 +
 +
Please also note, that maptool uses country multipolygon relations. So it's a good idea to include the whole country boundary to your dataset. You can use the josm editor to download the country boundary relation and save it as osm file. Then this file can be concatenated with your sub-country level excerpt.
 +
 
=====From .osm=====
 
=====From .osm=====
 
  cat my_OSM_map.osm | maptool my_Navit_map.bin
 
  cat my_OSM_map.osm | maptool my_Navit_map.bin
Line 70: Line 61:
 
Or for multiple OSM data files use the <tt>--dedupe-ways</tt> option to avoid duplication of way data if a way occurs multiple times in the OSM maps.
 
Or for multiple OSM data files use the <tt>--dedupe-ways</tt> option to avoid duplication of way data if a way occurs multiple times in the OSM maps.
 
  cat my_OSM_map1.osm my_OSM_map2.osm my_OSM_map3.osm | maptool --dedupe-ways my_Navit_map.bin
 
  cat my_OSM_map1.osm my_OSM_map2.osm my_OSM_map3.osm | maptool --dedupe-ways my_Navit_map.bin
 +
 
=====From .bz2=====
 
=====From .bz2=====
 
  bzcat my_OSM_map.osm.bz2 | maptool my_Navit_map.bin
 
  bzcat my_OSM_map.osm.bz2 | maptool my_Navit_map.bin
 +
 
=====From .pbf=====
 
=====From .pbf=====
 
''Functionality only available in SVN versions of Navit later than {{revision|3871}}, which does not include the official Navit release 0.2.0''
 
''Functionality only available in SVN versions of Navit later than {{revision|3871}}, which does not include the official Navit release 0.2.0''
 
  maptool --protobuf -i my_OSM_map.osm.pbf my_Navit_map.bin
 
  maptool --protobuf -i my_OSM_map.osm.pbf my_Navit_map.bin
  
===Add OSM map to your mapset===
+
===Processing the whole Planet===
Move the processed map to the directory of your choice, and add it to the active [[Configuring_Navit#The_mapset|mapset]] in navit.xml with a line similar to the following:
+
The OpenStreetMap wiki [http://wiki.openstreetmap.org/index.php/Planet.osm Planet.osm] page lists mirrors where Planet.osm can be downloaded. There are also downloads of smaller areas such as the UK and parts of Europe. These smaller excerpts are a lot quicker to download and process.
  
<mapset>
+
In case you want the whole planet.osm (24GB in December 2012), it is even possible to process planet.osm. It will take about 7 hours , requires > 1GB of main memory and about 30 GB disk space for result and temp files - planet.bin is currently (as of December 2012) 9.6GB:
  <map type="binfile" enabled="yes" data="/path/to/your/map/my_Navit_map.bin" />
 
</mapset>
 
  
===Special Case: Processing the Planet===
+
bzcat planet.osm.bz2 | maptool -6 my_Navit_map.bin
In case you want the whole planet.osm (11GB in September 2010), and you can't or don't want to fetch it from the [http://maps.navit-project.org/planet.bin previous link], it is even possible to process planet.osm. It will take about 7 hours , requires > 1GB of main memory and about 30 GB disk space for result and temp files - planet.bin is currently (as of September 2010) 3.0GB:
 
  
bzcat planet.osm.bz2 | maptool my_Navit_map.bin
+
Please note -6 option (long name --64bit) used above. It should be used always if output bin file grows above 4GB, or generated file will not work at all. Using that option on smaller files slightly increases their size and makes them unreadable by some unzip versions.
 
 
The OpenStreetMap wiki [http://wiki.openstreetmap.org/index.php/Planet.osm Planet.osm] page lists mirrors where Planet.osm can be downloaded. There are also downloads of smaller areas such as the UK and parts of Europe. These smaller excerpts are a lot quicker to download and process.
 
  
 
==Tips==
 
==Tips==
 +
{{note
 +
|To increase performance of Navit use maps for only the country or state you are interested in.
 +
}}
 
* To enable a map you have downloaded refer [[OpenStreetMap#Adding_an_OSM_map_to_your_mapset| adding OSM map to navit.xml]]
 
* To enable a map you have downloaded refer [[OpenStreetMap#Adding_an_OSM_map_to_your_mapset| adding OSM map to navit.xml]]
 
* If you don't see any map data in Navit (assuming your map is properly specified in navit.xml) using the Internal GUI click anywhere on the screen to bring up the menu. Click on "Actions" and then "Town". Type in the name of a town that should be within your map data. Select your town from the list that appears. This will bring up a sub-menu where you can click "View On Map". Note that if you have a GPS receiver you can also just wait till you get a satellite lock.  
 
* If you don't see any map data in Navit (assuming your map is properly specified in navit.xml) using the Internal GUI click anywhere on the screen to bring up the menu. Click on "Actions" and then "Town". Type in the name of a town that should be within your map data. Select your town from the list that appears. This will bring up a sub-menu where you can click "View On Map". Note that if you have a GPS receiver you can also just wait till you get a satellite lock.  
* To increase performance of Navit use maps for only the country or state you are interested in.
 
 
* To avoid changing navit.xml if you update your maps and the maps have different file names use the wildcard (*.bin) in your navit.xml file. For example:
 
* To avoid changing navit.xml if you update your maps and the maps have different file names use the wildcard (*.bin) in your navit.xml file. For example:
 
  <map type="binfile" enabled="yes" data="/media/mmc2/maps/*.bin"/>
 
  <map type="binfile" enabled="yes" data="/media/mmc2/maps/*.bin"/>
* If you want to learn more about the format used in conversion, for example to write a tool to extract a specific area, please have a look at [[Navit's binary map driver]].
 
  
==Problems with OSM and navit or navigation in general==
 
  
=== Search doesn't work in most countries ===
+
==See also==
This is because maptool only knows about a few is_in tags. To fix this, look for a reliable is_in tag in the towns in your country. If there is none, contact us, we have some scripts which can help adding one in this case. Then add the tag (at most 3 per country) to this page. Unfortunately using the country border for detecting the membership of a town also isn't an option, because the boundaries are usually not closed or wrong.
+
* [[binfile]]
  
 +
 +
==Problems with OSM==
 +
 +
=== Search doesn't work ===
 +
Now maptool uses country boundary multipolygon relations for detecting town membership. Sometimes this isn't an option, because the boundaries are not closed or wrong.
 +
 +
When there's no multipolygon around the town, maptool will attempt to use is_in tags. It only knows about a few OSM [http://wiki.openstreetmap.org/wiki/Key:is_in is_in tags]. Please help the osm community to fix the country boundary.
 
=== Search is totally b0rkz0r3d! Or, behaves very strangely vs other navigation software. ===
 
=== Search is totally b0rkz0r3d! Or, behaves very strangely vs other navigation software. ===
 
OK, so the country you're searching '''is''' [[OpenStreetMap/countries |listed in the table]]. Search probably will work. But be aware there are some quirks.
 
OK, so the country you're searching '''is''' [[OpenStreetMap/countries |listed in the table]]. Search probably will work. But be aware there are some quirks.
  
First, there is no "Search" button--searches will begin automatically as you fill in the gtk dialogue. Note there are minimum string length requirements. For instance the Town search only "activates" after 3 characters are typed, to prevent a huge number of results (which would take a lot of CPU time to find and display). If you really need to search for two character towns, you'll have to modify the navit source code.
+
First, there is no "Search" button--searches will '''begin automatically''' as you fill in the gtk dialogue. Note there are minimum string length requirements. For instance the Town search only "activates" after 3 characters are typed, to prevent a huge number of results (which would take a lot of CPU time to find and display). If you really need to search for two character towns, you'll have to modify the navit source code.
  
Also, Navit's search process is hierarchical. Meaning you must search for and select a valid Country, then select a Town, then select a Street. Right now, zipcode, district, and street number (?) searches are unimplemented; only Country, Town, and Street actually work (as of {{revision|1175}}). Furthermore, there is no US State or County information; when searching for a US town, you may get hits from all over the US with planet.bin, and unfortunately, the states that each hit is in are not displayed. You basically have to use the Map button to examine them one-by-one, until you find the one you want (or, only travel to towns with unique names).
+
Also, Navit's search process '''is hierarchical'''. Meaning you must search for and select a valid Country, then select a Town, then select a Street. Right now, zipcode and district searches are unimplemented; only Country, Town, Street and Housenumber actually work. Furthermore, there is no US State or County information; when searching for a US town, you may get hits from all over the US with planet.bin, and unfortunately, the states that each hit is in are not displayed. You basically have to use the Map button to examine them one-by-one, until you find the one you want (or, only travel to towns with unique names).
  
 
The dialogue sometimes moves the cursor between text boxes automatically. This can be pretty annoying.
 
The dialogue sometimes moves the cursor between text boxes automatically. This can be pretty annoying.
Line 115: Line 110:
  
 
The developers are aware of these issues and plan to improve behaviour (this will happen faster if you send a patch!)
 
The developers are aware of these issues and plan to improve behaviour (this will happen faster if you send a patch!)
 +
 +
=== Search for my town works, but I can't find my street ===
 +
 +
Maptool since April, 2013 uses polygones and multipolygon relations tagged with place=town/city/village etc to find place border.
 +
 +
Please note, there anyway should be a node tagged with the same name as surrounding [multi]polygon for town to be findable. If town boundary is found, it will be used as a limit for the street search.
 +
 +
Otherwise, city limit will be guessed by the place rank (city/town/village). This will often lead to streets not being found or found in neighboring places.
 +
 +
With the code improvements [http://navit.svn.sourceforge.net/viewvc/navit?view=revision&revision=5424] of April 2013, maptool attempts to use admin_level=8 boundary relations in Germany to find town borders, as these are not tagged with place=* tags in Germany. If your country doesn't use place=* tags on place boundaries, please report to trac which admin_level relations can be used to get town boundaries.
 +
 +
For some countries, we have established a correspondence of navit internal "State, county, district" terms to osm admin_level values. It makes it easier to find your town if there are many duplicate names without zip code. Report to trac if you have ideas how to extend this mapping to your country.
 +
 +
The following countries have a mapping to OSM admin_level for boundaries :
 +
Belgium, France, Germany, Poland, Russian federation, Switzerland, the Netherlands
  
 
=== Routes go through a city instead around of it ===
 
=== Routes go through a city instead around of it ===
This is because OSM doesn't provide any information whether a street is rural (can be driven with higher speeds) or not. In that case all roads are considered as in a city, which leads to using shorter routes through a city. The issue is in the OSM data, not Navit routing. You may want to fix the OSM data, in particular the speed limits (tag e.g. maxspeed=50) for inner-city roads, which are e.g. 50 km/h even when they are roads of higher order.
+
This is because OSM doesn't provide any information whether a street is rural (can be driven with higher speeds) or not. In that case all roads are considered as in a city, which leads to using shorter routes through a city. The '''issue is in the OSM data''', not Navit routing. You may want to fix the OSM data, in particular the speed limits (tag e.g. maxspeed=50) for inner-city roads, which are e.g. 50 km/h even when they are roads of higher order.
 
 
=== Search for my town works, but I can't find my street ===
 
This is because OSM doesn't provide reliable information which town a street belongs to. We are currently estimating the area of a town (depending on the town type) and are using all streets which fall in this area. This works well most of the time, but of course is no 100% match. But the official OSM approach "A street belongs to its nearest town/village etc." doesn't provide always correct results also and is harder to code.
 
  
 
=== There are strange purple objects on the navit map ===
 
=== There are strange purple objects on the navit map ===
Line 126: Line 133:
  
 
[[Category:Maps]]
 
[[Category:Maps]]
 +
[[Category:OpenStreetMap]]

Latest revision as of 16:57, 3 November 2017

OpenStreetMap is a free editable map of the whole world. It is made by people like you. OpenStreetMap allows you to view, edit and use geographical data in a collaborative way from anywhere on Earth. Maps from OpenStreetMap can be used in Navit.

Quick Start

  1. Go to Navit Planet Extractor (http://maps.navit-project.org/)
  2. Zoom in and select the area that you are interested in. Use the 'Map Controls' on the right to switch between 'Navigation' and 'Select' modes. or use preselected areas:
  1. Hit Get Map!
  2. Move the downloaded map to the directory of your choice, and add it to the active the mapset (see Configuration) in navit.xml with a line similar to the following:
<mapset>
 <map type="binfile" enabled="yes" data="/path/to/your/map/osm_bbox.bin" />
</mapset>

Add OSM map to your mapset

Move the downloaded map to the directory of your choice, and add it to the active mapset (see Configuration) in navit.xml with a line similar to the following:

<mapset>
 <map type="binfile" enabled="yes" data="/path/to/your/map/my_downloaded_map.bin" />
</mapset>

Topographic Maps

Navit will display elevation/height lines but the required data is not included in most OSM derived maps.

Navit compatible maps with height lines can be created by feeding the output of Phyghtmap (http://wiki.openstreetmap.org/wiki/Phyghtmap, http://katze.tfiu.de/projects/phyghtmap/) to Navit's maptool. Alternatively the SRTM data can be downloaded in osm.xml format http://geoweb.hft-stuttgart.de/SRTM/srtm_as_osm/, avoiding the Phygtmap step. The information can be either merged with OSM derived maps or used in a separate layer.

Many Garmin type maps such as http://www.wanderreitkarte.de/garmin_de.php also have the height lines information but routing will not work with them.

Processing OSM Maps Yourself

You can create your own Navit binfiles from OSM data very easily using maptool, the conversion program which installs alongside Navit. maptool can process both OpenStreetMap XML Data files (*.osm files) and OpenStreetMap Protobuf Data files (*.pbf files) Follow these steps to process your own maps.

Download your own OSM data

OSM data can be downloaded from a variety of sources. OpenStreetMap XML Data files are regular textfiles, easily editable in any text editor. OpenStreetMap Protobuf Data files are binary files, which take up less space (so are quicker to download and process) but are not editable.

  • OpenStreetMap XML Data
    • Geofabrik provides pre-processed OpenStreetMap XML Data files of almost all countries, and all continents. This method is probably the easiest way of downloading OpenStreetMap XML Data for an entire country or continent. Note that the OSM files are bzipped
    • planet.openstreetmap.org hosts the complete data set (the whole world). You can use Osmosis to cut it into smaller chunks.
    • OpenStreetMap ReadOnly (XAPI) The API allows to get the data of a specific bounding box, so that download managers can be used. For example:
wget -O map.osm "http://xapi.openstreetmap.org/api/0.6/map?bbox=11.4,48.7,11.6,48.9"
    • OpenStreetMap (visual) allows you to select a small rectangular area and download the selection as OpenStreetMap XML Data.
  • OpenStreetMap Protobuf Data
    • Geofabrik provides pre-processed OpenStreetMap Protobuf Data files of almost all countries, and all continents.

Convert OSM data to Navit binfile

The following examples assume that you have installed Navit system-wide. If this is not the case, you will need to provide an absolute path to the maptool executable, which is in the navit/maptool folder.

Please also note, that maptool uses country multipolygon relations. So it's a good idea to include the whole country boundary to your dataset. You can use the josm editor to download the country boundary relation and save it as osm file. Then this file can be concatenated with your sub-country level excerpt.

From .osm
cat my_OSM_map.osm | maptool my_Navit_map.bin

Or

maptool -i my_OSM_map.osm my_Navit_map.bin

Or for multiple OSM data files use the --dedupe-ways option to avoid duplication of way data if a way occurs multiple times in the OSM maps.

cat my_OSM_map1.osm my_OSM_map2.osm my_OSM_map3.osm | maptool --dedupe-ways my_Navit_map.bin
From .bz2
bzcat my_OSM_map.osm.bz2 | maptool my_Navit_map.bin
From .pbf

Functionality only available in SVN versions of Navit later than r3871, which does not include the official Navit release 0.2.0

maptool --protobuf -i my_OSM_map.osm.pbf my_Navit_map.bin

Processing the whole Planet

The OpenStreetMap wiki Planet.osm page lists mirrors where Planet.osm can be downloaded. There are also downloads of smaller areas such as the UK and parts of Europe. These smaller excerpts are a lot quicker to download and process.

In case you want the whole planet.osm (24GB in December 2012), it is even possible to process planet.osm. It will take about 7 hours , requires > 1GB of main memory and about 30 GB disk space for result and temp files - planet.bin is currently (as of December 2012) 9.6GB:

bzcat planet.osm.bz2 | maptool -6 my_Navit_map.bin

Please note -6 option (long name --64bit) used above. It should be used always if output bin file grows above 4GB, or generated file will not work at all. Using that option on smaller files slightly increases their size and makes them unreadable by some unzip versions.

Tips

  • To enable a map you have downloaded refer adding OSM map to navit.xml
  • If you don't see any map data in Navit (assuming your map is properly specified in navit.xml) using the Internal GUI click anywhere on the screen to bring up the menu. Click on "Actions" and then "Town". Type in the name of a town that should be within your map data. Select your town from the list that appears. This will bring up a sub-menu where you can click "View On Map". Note that if you have a GPS receiver you can also just wait till you get a satellite lock.
  • To avoid changing navit.xml if you update your maps and the maps have different file names use the wildcard (*.bin) in your navit.xml file. For example:
<map type="binfile" enabled="yes" data="/media/mmc2/maps/*.bin"/>


See also


Problems with OSM

Search doesn't work

Now maptool uses country boundary multipolygon relations for detecting town membership. Sometimes this isn't an option, because the boundaries are not closed or wrong.

When there's no multipolygon around the town, maptool will attempt to use is_in tags. It only knows about a few OSM is_in tags. Please help the osm community to fix the country boundary.

Search is totally b0rkz0r3d! Or, behaves very strangely vs other navigation software.

OK, so the country you're searching is listed in the table. Search probably will work. But be aware there are some quirks.

First, there is no "Search" button--searches will begin automatically as you fill in the gtk dialogue. Note there are minimum string length requirements. For instance the Town search only "activates" after 3 characters are typed, to prevent a huge number of results (which would take a lot of CPU time to find and display). If you really need to search for two character towns, you'll have to modify the navit source code.

Also, Navit's search process is hierarchical. Meaning you must search for and select a valid Country, then select a Town, then select a Street. Right now, zipcode and district searches are unimplemented; only Country, Town, Street and Housenumber actually work. Furthermore, there is no US State or County information; when searching for a US town, you may get hits from all over the US with planet.bin, and unfortunately, the states that each hit is in are not displayed. You basically have to use the Map button to examine them one-by-one, until you find the one you want (or, only travel to towns with unique names).

The dialogue sometimes moves the cursor between text boxes automatically. This can be pretty annoying.

Finally, there are a couple ways to crash (segfault) navit inside the search dialogue.

The developers are aware of these issues and plan to improve behaviour (this will happen faster if you send a patch!)

Search for my town works, but I can't find my street

Maptool since April, 2013 uses polygones and multipolygon relations tagged with place=town/city/village etc to find place border.

Please note, there anyway should be a node tagged with the same name as surrounding [multi]polygon for town to be findable. If town boundary is found, it will be used as a limit for the street search.

Otherwise, city limit will be guessed by the place rank (city/town/village). This will often lead to streets not being found or found in neighboring places.

With the code improvements [1] of April 2013, maptool attempts to use admin_level=8 boundary relations in Germany to find town borders, as these are not tagged with place=* tags in Germany. If your country doesn't use place=* tags on place boundaries, please report to trac which admin_level relations can be used to get town boundaries.

For some countries, we have established a correspondence of navit internal "State, county, district" terms to osm admin_level values. It makes it easier to find your town if there are many duplicate names without zip code. Report to trac if you have ideas how to extend this mapping to your country.

The following countries have a mapping to OSM admin_level for boundaries : Belgium, France, Germany, Poland, Russian federation, Switzerland, the Netherlands

Routes go through a city instead around of it

This is because OSM doesn't provide any information whether a street is rural (can be driven with higher speeds) or not. In that case all roads are considered as in a city, which leads to using shorter routes through a city. The issue is in the OSM data, not Navit routing. You may want to fix the OSM data, in particular the speed limits (tag e.g. maxspeed=50) for inner-city roads, which are e.g. 50 km/h even when they are roads of higher order.

There are strange purple objects on the navit map

These are objects in OSM which have no representation in navit. This includes ways which have no tag and therefore are not visible in osmarender/mapnik maps. If you want to have tagged objects included in navit add an entry to the discussion what tags are used for this object and what item from Item_def.h should be used (suggest a new one together with how it should be rendered if no appropriate one exists).