Software libraries
Libraries, also known as frameworks, components, modules, or software development kits (SDKs), contain reusable code that helps developers integrate OpenStreetMap into their websites or software applications without reinventing the wheel. Developers have written libraries for accessing and analyzing data, rendering maps, geocoding, and routing. These libraries are compatible with the Web and a wide variety of desktop and mobile platforms.
A library is primarily included in a larger application, rather than being run as a standalone tool. However, some of the libraries listed here also provide command-line tools to facilitate development. A standalone tool may be just as convenient as a library in some environments, particularly on the command line; see Software for a full listing.
The libraries listed here are actively maintained or are considered to be mature and complete. Libraries of historical interest can be found at Category:Discontinued software.
Language bindings for the OpenStreetMap 0.6 API
- Main article: Databases and data access APIs
The OpenStreetMap API is primarily for use by OpenStreetMap editors and similar applications. If you’re developing a website or end-user application, most likely you’ll want to use a higher-level framework, such as an interactive map library.
Library | Platforms | Target languages | API | Overpass | License | Notes |
---|---|---|---|---|---|---|
osm-common | Android, Java | Java | yes | yes | Apache 2 | Overpass, changeset servers |
osmapi | Android, Java | Java | yes | yes | LGPLv3 | Complete implementation of the API 0.6, including map data, traces, notes, changesets, user infos, overpass etc. |
osmapi | Cross-platform | Python | yes | no | GPLv3 | |
OsmApiClient | Cross-platform | C# .Net Standard 2.0 | yes | no | MIT | Complete supprt for all documented features of Osm's API v0.6 |
osmapiR | Cross-platform | R | yes | no | GPLv3 | |
osmaR | Cross-platform | R | yes | no | GPLv2 | |
osmdata | Cross-platform | R | no | yes | GPLv3 | |
Rosemary | Cross-platform | Ruby | yes | no | MIT | |
Services_OpenStreetMap | Cross-platform | PHP | yes | no | BSD | Also allows access to user details. Went through PEAR PePr process |
overpy | Cross-platform | Python | no | yes | MIT | |
osm_easy_api | Cross-platform | Python | yes | no | GPLv3 | Support for api and diff files |
osm-api-js | Cross-platform | JavaScript/Typescript | yes | no | MIT | Created when osm-request wasn't maintained, this is a smaller and simpler wrapper around the API that includes full Typescript types. |
osm-request | Cross-platform | JavaScript | yes | no | MIT | A bit more powerful than osm-api-js but also more complicated and lacking Typescript. |
Processing OpenStreetMap data
- Main article: Converting map data between formats
- Main article: :Category:File Converters
These libraries parse or convert raw OpenStreetMap data into other file formats or import the data into databases.
Library | Platforms | Target languages | License | Notes |
---|---|---|---|---|
Atlas | Cross-platform | Java, Python | BSD 3-Clause | A tool to represent network-navigable OSM data in memory and to run data integrity checks at scale using Spark |
BasicOSMParser | Cross-platform | Java | GPLv3 | A XML data parser to manipulate OSM objects in Java, also able to do CSV exports |
GeoDesk | Cross-platform | Java, Python, C++ | Apache 2, LGPL 3.0 | Fast and storage-efficient database engine for OSM data. Able to export in various formats (GeoJSON, CSV, WKT, etc.) |
Geow | Cross-platform | Scala | Apache 2 | Lightweight framework for processing OSM data |
gOSMonaut | Cross-platform | Go | MIT | PBF file parser that delivers nested entities |
Gosmparse | Cross-platform | Go | MIT | Parsing OpenStreetMap PBF files at speed |
LibOsm | Cross-platform | C++ | GPLv3 | Store/update OSM data in an SQLite database |
LibOSM | Cross-platform | Java | GPL | |
libosmscout | Cross-platform | C++, Java | LGPL | Raw data parsing and preprocessing, database functionality |
osm-common | Android, Java | Java | Apache 2 | osm.xml and osc.xml parsing and processing |
Osm.ml | Cross-platform | OCaml | WTFPL | Parses the basic objects of a .osm file |
osm-read | Node.js, Web | JavaScript | LGPLv3 | OpenStreetMap XML and PBF data parser for Node.js and the browser |
OSM2Hive | Cross-platform | Hive | Apache 2 | OSM data importer for Hive / Hadoop clusters |
osm4j | Cross-platform | Java | LGPLv3 | |
osm4scala | Cross-platform | Scala | MIT | Lightweight and high performance Scala library focus in parse PBF2 OSM files as iterators. |
OSMemory | Cross-platform | Java | LGPLv3 | Library for validators with o5m fast reader. It loads data to memory that allow to use osm data without PostgreSQL |
libosmium | Cross-platform | C++ | BSL-1.0 | Toolkit and framework for working with OSM data |
osm-io | Cross-platform | Rust | MIT OR Apache-2.0 | Fast PBF read/write library |
osm-admin | Cross-platform | Rust, Docker | MIT OR Apache-2.0 | Fast import and export of PBF into and from apidb databases |
OSMJSON.Net | Cross-platform | C# .Net | Apache 2 | OSMJSON.Net is a library containing the necessary types for serializing and de-serializing of OSM JSON |
OSMKit | iOS, macOS | Objective-C | MIT | Parses and stores OSM data in a spatialite database. |
OSMLib | Cross-platform | Ruby | Public domain | osm to shapefile conversion |
OSMonaut | Cross-platform | Java | MIT | Parser for binary OSM files that always returns complete entities |
Osmosis | Java, Android | Java | Public domain | Inactive since 2018 |
Openstreetmap h3 | Cross-platform | Java | Apache 2 | High performance tool for importing PBF into PostGIS databases or to Apache Parquet, Arrow(BigData: Spark,Hadoop) |
Osm-parquetizer | Cross-platform | Java | Apache 2 | Converts PBF files to Parquet, making the OSM data BigData friendly (Hadoop/Spark) |
osmpbf | Cross-platform | C++ | LGPLv3 | Based on iterator concept |
osmpbf | Cross-platform | Go | MIT | PBF file format parser |
Osmread | Cross-platform | Python | MIT | Simple library for reading XML and PBF data files |
osmtogeojson | Cross-platform | JavaScript | MIT | OSM XML to GeoJSON converter |
OsmTagsTranslator | Windows | C# .Net | MIT | Use SQLite queries to translate element tags (string manipulation or joining with look-up tables) |
osm2geojson | Cross-platform | Python | MIT | OSM XML (and Overpass XML/JSON) to GeoJSON converter |
parallelpbf | Cross-platform | Java | GPLv3 | PBF format multithreaded reader written in Java |
pbf2osm | Cross-platform | C | GPLv3 | Converts pbf files back to osm based XML files |
PyOsmium | Cross-platform | Python | BSD 2-Clause | Process PBF and OSM XML files. Toolkit and framework for working with OSM data. |
Smrender | Cross-platform | C | GPLv3 | Modular OSM data processing |
spark-osm-datasource | Cross-platform | Scala | GPLv3 | PBF format datasource for Apache Spark |
Generating map images
- Main article: Rendering
Most client-side static and interactive map libraries display static map images or raster tiles generated on the server side. These server-side libraries are used by tile servers that need to generate those raster tiles:
Library | Platforms | Target languages | License | Notes |
---|---|---|---|---|
Kartograph | Cross-platform | Python | LGPL | Kartograph is a simple and lightweight framework for building interactive map applications without any other mapping service. It was created with the needs of designers and data journalists in mind. |
Mapnik | Windows, macOS, Linux | Python, JavaScript, C++ | LGPL | The most popular server-side 2D map renderer. Requires PostgreSQL and various C++ libraries. Designed to be fast and is suitable for tile generation on high-end servers, but it isn't particularly easy to set up. |
node-mapbox-gl-native | Node.js | JavaScript | BSD | Renders Mapbox Vector Tiles using OpenGL; supports overlays, GeoJSON, and Mapbox GL styles |
pgmapcss | Cross-platform | PostgreSQL | AGPLv3 | A library for PostgreSQL/PostGIS which works between an osm2pgsql-based database and Mapnik (and maybe other renderers) |
Smrender | Cross-platform | C | GPLv3 | Offline paper chart rendering |
TileMan | Linux | Lua | GPLv3 | Framework for serving OSM based tiles |
Displaying static map images
- Main article: Rendering
These client-side libraries fetch individual static map images from a tile server without adding an interactive UI around the images. In websites and applications, static map images are sometimes more appropriate than full map widgets, either due to performance concerns or because the map simply doesn’t need to be interactive.
Library | Platforms | Target languages | License | Notes |
---|---|---|---|---|
Mapbox Android Services | Android, Java | Java | MIT | Connects to Mapbox’s Static API |
Mapbox Python SDK | Cross-platform | Python | MIT | Connects to Mapbox’s classic Static API |
MapboxStatic.swift | iOS, macOS, tvOS, watchOS | Swift, Objective-C | BSD | Connects to Mapbox’s Static API |
A-Frame | WebBrowser | JavaScript | MIT | Places Maps (Bit/Vector) into a 3D environment |
Displaying interactive maps
- Main article: Rendering
- Main article: Deploying your own Slippy Map
Interactive maps, also known as slippy maps on the Web, are the most common way of integrating OpenStreetMap into a website or application. These client-side libraries can display OpenStreetMap-based maps directly. Most of them display raster or vector tiles generated by a tile server, while some render raw OpenStreetMap data fetched directly from an API. A number of server-side libraries make it easier to insert client-side map widgets in webpages.
Web maps
Actively maintained libraries are listed at Deploying your own Slippy Map#JavaScript libraries.
Unmaintained web map libraries include Cartagen, Kartograph, Kothic JS, Modest Maps and Polymaps.
Native widgets
Library | Platforms | Target languages | Raster | Vector | License | Notes |
---|---|---|---|---|---|---|
BruTile | Cross-platform | Silverlight, C# | yes | no | LGPL | |
Carto Mobile SDK | Android, iOS, Windows | Java, Objective-C++, Swift, C# | yes | yes | BSD | |
CartoType | iOS, Android, Windows, Mac OS, Unix, Qt | C++, .NET, Java, Objective C, Swift, C# | no | yes | Proprietary | Offline or online map rendering using Open GL ES or CPU rendering; can use OSM and other data sources including ESRI shapefiles; provides routing, turn by turn navigation, geocoding, address search and full-text search. |
COSMCtrl | Windows | C++ | yes | no | Freeware | MFC control |
GLMap | iOS, Android | Objective-C, Swift, Java | yes | yes | Proprietary | Offline or online vector map rendered on device using OpenGL ES |
flutter_map (fleaflet) | iOS, Android, Windows, Mac, Linux, Web | Dart (with the Flutter framework) | yes | 3rd party plugin | BSD 3-Clause | A versatile mapping package for Flutter that supports showing raster tiles from any source with a wide variety of plugins to add functionality. |
Halcyon | Flash | ActionScript | yes | yes | WTFPL | Rendering library developed by Richard Fairhurst and used within Potlatch 2 |
JMapViewer | Java SE | Java | yes | no | GPLv2 | |
JXMapViewer2 | Java SE | Java | yes | no | LGPLv3 | Swing control |
libchamplain | Linux/GNOME | C, Perl, Python | yes | no | LGPL-2.1-or-later | GNOME/GTK3 widget. Superseded by libshumate. |
libosmscout | Cross-platform | C++, Java | yes | yes | LGPL | Offline vector map drawing (based on preprocessed data) |
libshumate | Linux/GNOME | C, Rust, | yes | yes | LGPL-2.1-or-later | GNOME/GTK4 widget |
LocationMapViewer | Android | Java | yes | no | GPLv3+ | Android-Intent; "geo:"-Uri; gpx and kml file/URL |
map::slippy | Cross-platform | Tcl | yes | no | BSD-style | Tcl/Tk widget |
Mapbox Android SDK | Android | Java, Kotlin | yes | yes | BSD | Displays Mapbox Vector Tiles in an interactive map using OpenGL ES |
Mapbox Cordova Plugin | iOS, Android | JavaScript | yes | yes | MIT | Cordova plugin wrapping the Mapbox iOS SDK and Mapbox Android SDK |
Mapbox iOS SDK | iOS | Objective-C, Swift, Interface Builder | yes | yes | BSD | Displays Mapbox Vector Tiles in an interactive map using OpenGL ES |
Mapbox macOS SDK | macOS | Objective-C, Swift, Interface Builder, AppleScript | yes | yes | BSD | Displays Mapbox Vector Tiles in an interactive map using OpenGL |
Mapbox Qt SDK | Cross-platform | C++, QML | yes | yes | BSD | Displays Mapbox Vector Tiles in an interactive map using OpenGL and Qt |
Mapbox SceneKit SDK | iOS | Objective-C, Swift | yes | yes | ISC | Provides data for generating custom 3D scenes in SceneKit |
Mapbox SDK for Xamarin | Android, iOS | C# | yes | yes | BSD | Xamarin component wrapping the Mapbox Android SDK and Mapbox iOS SDK |
Mapbox Unity SDK | Cross-platform | C# | yes | yes | Apache | Provides data for generating custom 3D scenes in Unity |
mapsforge | Android, Java | Java | ? | yes | LGPLv3 | OSM based replacement for Android's MapView class for offline tile sources and overlays. Java ME and Java SE. |
mapsui | desktop, mobile, server | C# | yes | no | MIT | Uses BruTile |
Marble | Windows, macOS, Linux | C++, Python, QML | yes | yes | LGPL | Qt widget |
NativeScript Mapbox[1] | iOS, Android | XML, JavaScript | yes | yes | MIT | NativeScript plugin wrapping the Mapbox iOS SDK and Mapbox Android SDK |
Navmii Mobile SDK | iOS, Android | ? | ? | yes | Proprietary | Unclear what is offered; documentation is unavailable without an account |
osm-gps-map | Cross-platform | C, Python, JavaScript | yes | no | GPLv2 | GTK mapping widget drawing a GPS track, and points of interest on a moving map |
OSMBonusPack | Android | Java | yes | no | LGPL with exceptions | Addon for osmdroid: Markers, Bubbles, Routes, Directions, KML and more... |
osmdroid | Android | Java | yes | no | Apache 2 | OSM based replacement for Android's MapView (v1 API) class. Supports online and offline tile sources and overlays for plotting icons, tracking location, drawing shapes. |
OsmSharp | iOS, Android, Windows Phone | C# | no | yes | GPLv2 or commercial | Offline vector map rendering |
QMapControl | Cross-platform | C++ | yes | no | LGPL | Qt control |
QtLocation | Cross-platform | C++, QML | yes | yes | LGPLv3 or commercial | Qt module for mapping, navigation, geocoding and places of interest with pluggable architecture to provide geoservices. Supersedes QtMobility.Location. OSM services for mapping, geocoding, routing and places now included by default. |
Qt Mobility Geoservices Extras | Cross-platform | C++, QML | yes | no | LGPLv2.1 | |
QuartzMaps | iOS | Objective-C | yes | yes | Proprietary | Slippy Map and Vector Map rendering engine for iOS |
React Native Mapbox GL | iOS, Android | JSX | yes | yes | BSD | React Native component wrapping the Mapbox iOS SDK and Mapbox Android SDK |
Tangram ES | Android, iOS, Linux, macOS | C++ | no | yes | MIT | 2D and 3D map renderer using OpenGL ES |
ti.osm | Android (Appcelerator Titanium) | JavaScript | yes | no | MIT | Appcelerator Titanium wrapper for osmdroid |
WhirlyGlobe-Maply | iOS, Android | Objective-C, Swift, Java | yes | yes | Apache 2 | Geospatial display kit for iOS and Android based on OpenGL ES. Implements a 2D map and a 3D globe and can handle image base maps and tiled vector maps based on OSM data. |
MapLibre Native (wiki) | Cross-platform | Objective-C, Swift, Java, Kotlin, C++ | yes | yes | BSD | Interactive raster and vector tiles on mobile and desktop; tile and static map rendering on the server. |
Additionally, some client-side libraries can be used with OpenStreetMap tiles, even if they’re primarily intended for other uses:
Forward and reverse geocoding
- Main article: Geocoding
This table includes both server-side libraries and client-side libraries:
Library | Platforms | Target languages | Forward | Reverse | License | Notes |
---|---|---|---|---|---|---|
Gisgraphy | Cross-platform | Java | yes | yes | LGPLv3 | Geocoding/reverse geocoding, fulltextsearch, find nearby |
mapsforge | Android, Java | Java | yes | yes | LGPLv3 | POI indexing and search. Java ME and Java SE. |
osm-common | Android, Java | Java | yes | yes | Apache 2 | Nominatim |
Pelias Android SDK | Android | Java | yes | yes | Apache | Connects to Mapzen’s Pelias Geocoder instance |
Pelias iOS SDK | iOS, macOS | Swift | yes | yes | Apache 2 | Connects to Mapzen’s Pelias Geocoder instance |
Services_OpenStreetMap | Cross-platform | PHP | yes | yes | BSD | Includes partial support for querying Nominatim servers. Went through PEAR PePr process |
osm-reverse-geocoder | Cross-platform | PL/pgSQL | no | yes | MIT | Simple address reverse geocoding |
Nominatim.API | Windows,Cross-platform | C# | yes | yes | MIT | Library for utilizing geocoding (forward and reverse), in addition to address lookups, with the Nominatim HTTP API. Targets .NET Standard 2.0. Available on NuGet: Nominatim.API |
- Main article: Routing
This table includes both server-side libraries and client-side libraries:
Library | Platforms | Target languages | License | Notes |
---|---|---|---|---|
openrouteservice | Cross-plattform, Web | Java, R, Python, Javascript .. | LPGL | routing/directions, isochrones, geocoding, maps, time-distance matrix, accessibility etc. many traffic profiles |
CartoType | Windows, iOS, Android, macOS, Unix | C++, .NET, Java, Objective-C, Swift, C# | Proprietary | offline routing for drivers, cyclists, walkers; configurable routing profiles; can export routes and instructions |
GraphHopper | Cross-platform | Java, Objective-C, Swift | Apache 2 | Routing engine for car, bike and more. Can be used as web service, android library, iOS library or Java library. |
libosmscout | Cross-platform | C++, Java | LGPL | offline routing (based on preprocessed data) |
Mapbox Android Services | Android, Java | Java | MIT | Connects to Mapbox’s Directions API for route data |
Mapbox Directions for Swift | iOS, macOS, tvOS, watchOS | Swift | ISC | Connects to Mapbox’s Directions API for route data |
Mapbox GL Directions | Web | JavaScript | MIT | Plugin for Mapbox GL JS that connects to Mapbox’s Directions API for route data |
Mapbox JavaScript SDK | Web, Node.js | JavaScript | MIT | Connects to Mapbox’s Directions API for route data |
Mapbox Navigation SDK for Android | Android | Java, Kotlin | Proprietary | Embeds a turn-by-turn navigation UI with voice guidance into an Android application |
Mapbox Navigation SDK for iOS | iOS | Swift | Proprietary | Embeds a turn-by-turn navigation UI with voice guidance into an iOS application |
Mapbox Python SDK | Cross-platform | Python | MIT | Connects to version 4 of Mapbox’s Directions API for route data |
Mapbox Ruby SDK | Cross-platform | Ruby | MIT | Connects to Mapbox’s Directions API for route data |
Mapbox Unity SDK | Cross-platform | C# | Apache | Connects to Mapbox’s Directions API for route data |
mapsforge | Android, Java | Java | LGPLv3 | Route planning and navigation. Java ME and Java SE. |
Mapzen iOS SDK | iOS | Swift, Objective-C | Apache | Connects to Mapzen Turn-by-Turn (powered by Valhalla) via OnTheRoad for iOS |
Navmii Mobile SDK | iOS, Android | style="background: #ececec; color: #2C2C2C; font-size: smaller; vertical-align: middle; text-align: center; " class="unknown table-unknown"|? | Proprietary | |
On The Road | Android | Java | Apache | Connects to Mapzen Turn-by-Turn (powered by Valhalla) |
Open Source Routing Machine | Linux, macOS, FreeBSD, Node.js | C++, JavaScript | BSD | Routing |
OpenTripPlanner | Web | Java | GPL | Multimodal routing for public transit, bicycle, pedestrian, and car. |
OSMNavigation | Cross-platform | Java | GPL | |
OsmSharp | iOS, Android, Windows Phone | C# | GPLv2 or commercial | Offline routing |
pyroutelib2 | Cross-platform | Python | GPLv3+ | Routing with custom vehicles and displaying the result |
Routino | Linux, macOS, Windows | C | AGPLv3 | Flexible router with web interface and routing data analyser |
Ferrostar | Cross-platform (iOS, Android, and Web officially supported) | Rust, Swift, Kotlin, and TypeScript | BSD | Navigation SDK with modern composable UI and a consistent API across all platforms. Ships with a request generator for Valhalla, and response parser for "OSRM-like" JSON. |
Code snippets
The following links provide source code that’s too small for a library but nevertheless useful:
- Batch Upload - Scripted GPX upload to OSM
- Slippy map tilenames - getting the right Tiles for a geoposition
- Java Access Example - a simple java example how to access either the OpenStreetMap API or the overpass API from within Java
See also:
Other developer tools
- Main article: GIS software
General-purpose GIS libraries are often used in conjunction with OpenStreetMap-specific libraries to work with geographic data:
- PROJ.4 - Geo Projection Conversion lib with multiple bindings
- GDAL - Geo Raster image formats lib
- OGR - Geo Vector data formats lib
- PostGIS - The leading Geo enabled Database
- spatialite - sqlite extension, fully fledged spatial db
- Mapbender - Another more GIS focused web map lib
- Geotools -Java GIS Toolkit
- GIS-Python lab - Python GIS Toolkit
- k3b-geoHelper - java lib to parse gpx and kml files and en/decode geo-uris. Works with Android, too
- Pic4Carto.js - JavaScript library for open-licensed street pictures retrieval (which can be used for photo mapping, tutorial)
By Language
External links
- Tutorial for building a own Navi
- Tutorial for extending OpenLayers for touch gestures of mobile browsers
- How to work on OSM data using Haskell
- OSGeo.org - Home of popular OSS GIS tools
- GIS software catalogue at GISWiki
- FreeGIS - GIS Software catalogue