Qt Location Open Street Map Plugin
Overview
This geo services plugin allows applications to access Open Street Map location based services using the Qt Location API.
Data, imagery and map information provided by ThunderForest, OpenStreetMap and contributors. The data is available under the Open Database License.
The Open Street Map geo services plugin can be loaded by using the plugin key "osm".
Note: The standard map types rely on (partially) free data providers. We try to keep the selection useful for evaluation and development purposes, but it is your responsibility to select a data provider that fits your needs in production. It is highly recommended to carefully read and adhere to the terms of service of the respective providers. A list of alternative data providers is available in the OpenStreetMap wiki. The available map types offered by this plugin may change (or be removed) without notice depending on the actual availability of a viable openly accessible provider for each type. This also implies that providers serving tiles over HTTPS may be used. This becomes relevant when using the OSM plugin on platforms, such as Android, for which SSL support is not built into Qt by default. To prevent these changes, either a different geo service plugin should be used, or the plugin parameter osm.mapping.providersrepository.address should be set to a user-specified repository, in order to take full control over selecting the provider that is used for each map type. Since Qt 5.9.6, the default nominatim endpoint, used for geocoding and places, has also changed to HTTPS-only.
Parameters
Optional parameters
The following table lists optional parameters that can be passed to the Open Street Map plugin.
Note: Since Qt 5.5 all parameters below must be prefixed with osm
. Previous versions did not require a prefix.
Parameter | Description |
---|---|
osm.geocoding.host | Url string set when making network requests to the geocoding server. This parameter should be set to a valid server url with the correct OSM API. If not specified the default url will be used. Note: The API documentation is available at Project OSM Nominatim. |
osm.geocoding.debug_query | Instructs the plugin to inject the query url to nominatim into the geocode reply, for debugging purposes. |
osm.geocoding.include_extended_data | Instructs the plugin to include Nominatim-specific information (such as geometry and class) into the returned Location objects, exposed as extendedAttributes. |
osm.mapping.cache.directory | Absolute path to map tile cache directory used as network disk cache. The default place for the cache is the |
osm.mapping.cache.disk.cost_strategy | The cost strategy to use to cache map tiles on disk. Valid values are bytesize and unitary. Using bytesize, the related size parameter (osm.mapping.cache.disk.size) will be interpreted as bytes. Using unitary, they will be interpreted as number of tiles. The default value for this parameter is bytesize. |
osm.mapping.cache.disk.size | Disk cache size for map tiles. The default size of the cache is 50 MiB when bytesize is the cost strategy for this cache, or 1000 tiles, when unitary is the cost strategy. |
osm.mapping.cache.memory.cost_strategy | The cost strategy to use to cache map tiles in memory. Valid values are bytesize and unitary. Using bytesize, the related size parameter (osm.mapping.cache.memory.size) will be interpreted as bytes. Using unitary, they will be interpreted as number of tiles. The default value for this parameter is bytesize. |
osm.mapping.cache.memory.size | Memory cache size for map tiles. The default size of the cache is 3 MiB when bytesize is the cost strategy for this cache, or 100 tiles, when unitary is the cost strategy. |
osm.mapping.cache.texture.cost_strategy | The cost strategy to use to cache decompressed map tiles in memory. Valid values are bytesize and unitary. Using bytesize, the related size parameter (osm.mapping.cache.texture.size) will be interpreted as bytes. Using unitary, they will be interpreted as number of tiles. The default value for this parameter is bytesize. |
osm.mapping.cache.texture.size | Texture cache size for map tiles. The default size of the cache is 6 MiB when bytesize is the cost strategy for this cache, or 30 tiles, when unitary is the cost strategy. Note that the texture cache has a hard minimum size which depends on the size of the map viewport (it must contain enough data to display the tiles currently visible on the display). This value is the amount of cache to be used in addition to the bare minimum. |
osm.mapping.custom.datacopyright | Custom data copryright string is used when setting the Map::activeMapType to MapType.CustomMap via urlprefix parameter. This copyright will only be used when using the CustomMap from above. If empty no data copyright will be displayed for the custom map. |
osm.mapping.custom.host | The url string of a custom tile server. This parameter should be set to a valid server url offering the correct OSM API. The postfix "%z/%x/%y.png" will be added to the url. Since 6.5 the postfix will not be added if the url ends with ".png". If the server requires an apikey, it has to be added to the url string. To use this server, the Map::activeMapType parameter of the Map should be set to the supported map type whose type is MapType.CustomMap. This map type is only be available if this plugin parameter is set, in which case it is always Map::supportedMapTypes[supportedMapTypes.length - 1]. Note: Setting the mapping.custom.host parameter to a new server renders the map tile cache useless for the old custommap style. |
osm.mapping.custom.mapcopyright | Custom map copryright string is used when setting the Map::activeMapType to MapType.CustomMap via urlprefix parameter. This copyright will only be used when using the CustomMap from above. If empty no map copyright will be displayed for the custom map. |
osm.mapping.highdpi_tiles | Whether or not to request high dpi tiles. Valid values are true and false. The default value is false. Please note that not all map types are available in high dpi. Setting this parameter to true might even have no effect if no map type is available in high dpi at the moment. Provider information files for high dpi tiles are named street-hires , satellite-hires , cycle-hires , transit-hires , night-transit-hires , terrain-hires and hiking-hires . These are fetched from the same location used for the low dpi counterparts. |
osm.mapping.offline.directory | Absolute path to a directory containing map tiles used as an offline storage. If specified, it will work together with the network disk cache, but tiles won't get automatically inserted, removed or updated. The format of the tiles is the same used by the network disk cache. There is no default value, and if this property is not set, no directory will be indexed and only the network disk cache will be used to reduce network usage or to act as an offline storage for the currently cached tiles. |
osm.mapping.prefetching_style | This parameter allows to provide a hint how tile prefetching is to be performed by the engine. The default value, TwoNeighbourLayers , makes the engine prefetch tiles for the layer above and the one below the current tile layer, providing ready tiles when zooming in or out from the current zoom level. OneNeighbourLayer only prefetches the one layer closest to the current zoom level. Finally, NoPrefetching allows to disable the prefetching, so only tiles that are visible will be fetched. Note that, depending on the active map type, this hint might be ignored. |
osm.mapping.providersrepository.address | The OpenStreetMap plugin retrieves the provider's information from a remote repository. This is done to prevent using hardcoded servers by default, which may become unavailable. By default this information is fetched from maps-redirect.qt.io. Setting this parameter changes the provider repository address to a user-specified one, which must contain the files street , satellite , cycle , transit , night-transit , terrain and hiking , each of which must contain valid provider information. |
osm.mapping.providersrepository.disabled | By default, the OpenStreetMap plugin retrieves the provider's information from a remote repository to avoid a loss of service due to unavailability of hardcoded services. The plugin, however, still contains fallback hardcoded provider data, in case the provider repository becomes unreachable. Setting this parameter to true makes the plugin use the hardcoded urls only and therefore prevents the plugin from fetching provider data from the remote repository. |
osm.places.debug_query | Set this parameter to true to have an extended attribute in each result named "requestUrl", and containing the url used for the query. Default is false. |
osm.places.host | Url string set when making network requests to the places server. This parameter should be set to a valid server url with the correct OSM API. If not specified the default url will be used. Note: The API documentation is available at Project OSM Nominatim. |
osm.places.page_size | The amount of results in a page. Note that this value might be clamped server side. The typical maximum in standard nominatim instances is 50. |
osm.routing.apiversion | String defining the api version of the (custom) OSRM server. Valid values are v4 and v5. The default is v5. This parameter should be set only if osm.routing.host is set, and is an OSRM v4 server. |
osm.routing.host | Url string set when making network requests to the routing server. This parameter should be set to a valid server url with the correct OSRM API. If not specified the default url will be used. Note: The API documentation and sources are available at Project OSRM. |
osm.useragent | User agent string set when making network requests. This parameter should be set to a value that uniquely identifies the application. Note that providers might block applications not setting this parameter, leaving it to the stock plugin user agent (e.g., Nominatim for geocoding) |
Parameter Usage Example
The following example shows how to create an OSM plugin instance with parameters supplied for an useragent, and if necessary, a custom server url plus the corresponding copyright information for the tile provider. Additionally, it is possible to choose another routing server than the public osrm one.
QML
Plugin { name: "osm" PluginParameter { name: "osm.useragent"; value: "My great Qt OSM application" } PluginParameter { name: "osm.mapping.host"; value: "http://osm.tile.server.address/" } PluginParameter { name: "osm.mapping.copyright"; value: "All mine" } PluginParameter { name: "osm.routing.host"; value: "http://osrm.server.address/viaroute" } PluginParameter { name: "osm.geocoding.host"; value: "http://geocoding.server.address" } }
Other Plugin-specific Information
Tile cache
The tiles are cached in a QtLocation/osm
directory in QStandardPaths::writableLocation (QStandardPaths::GenericCacheLocation). On systems that have no concept of a shared cache, the application-specific QStandardPaths::CacheLocation is used instead.