Building Web Apps with Open Source Mapping APIs
Anita Kemp
Open Source Mapping APIs
- Leaflet
- Mapbox GL JS/ MapLibre GL
- OpenLayers
Why?
- Open source
- Simple APIs
- Small footprints
Why not?
- No web map support
- No built in ArcGIS identities
- No extensive support for different service types
- No direct REST API integrations (use ArcGIS REST JS)
Am I making the right choice?
When to use the ArcGIS JS API vs. Open source APIs
JS API
- 100% Web GL rendering
- Integrated UI widgets
- Extensive 3D support
- Tighter ArcGIS integrations (web maps, ArcGIS identity)
Open source
Smaller footprint
Open source licenses and ecosystems
Access location services
- ArcGIS REST JS: routing, geocoding, and demographics
- Basemap layers
- Raster and vector tile layers
- Feature layers
Ask yourself:
- Do I need ArcGIS identity? --> JS API
- Do I need web map support? --> JS API
- Do I just need basic location services? --> Open source!
Mapbox GL JS/MapLibre
Why the split?
- Mapbox GL JS 2.x is not open source.
- Mapbox GL JS 1.x is open source, but no active development
- MapLibre GL JS is an open source fork of Mapbox GL JS 1.x
Demos
Find the code at: https://github.com/ak-kemp/dev-summit-demos
Maps
Esri Leaflet
Display a map
Display a custom style
Resources
Documentation: developers.arcgis.com/esri-leaflet
Github (source code and issues)
github.com/esri/esri-leaflet
Esri community
esriurl.com/community-esri-leaflet
ArcGIS REST JS
Esri's open source library. Modular wrappers to access:
- Geocoding service
- Routing service
- Feature services
- Demographics...
Will be used a lot!
Layers and data hosting
Working with hosted data using OpenLayers:
- Add a feature layer (as GeoJSON)
- Query SQL/Spatial
- Vector tile layer
Feature layers
- Esri Leaflet: Use `featureLayer` class
- Mapbox/OL: Add as GeoJSON
Add a feature layer as GeoJSON
Query features SQL
Query features: spatial
Vector tile layers
Add a vector tile layer
Using Mapbox GL JS
Style a vector tile layer
Resources
Find the code at:
Github
Text
deck
By anita_k
deck
- 488