Schlagwort-Archive: QGIS

Immer aktuelle POI-Karten mit Leaflet und Overpass

uulm-map

Wir hatten neulich das Gebaeudemanagement der Uni um eine Uebersicht der von ihr aufgestellten Radparkanlagen gebeten – mit dem Hintergedanken, das schoen aufbereitet zu veroeffentlichen, um moegliche Bedarfe zu erkennen und potenziellen Radler*innen eine schoene Uebersicht an die Hand zu geben.

Die Uebersicht kam dann in Form eines PDF-Plans mit blauen Bobbeln je Abstellanlage – und der PDF-Plan war nicht etwa irgendein Geospatial PDF, nein, das war einfach „nur“ ein Umgebungsplan ohne auch nur den Ansatz eines Koordinatensystems oder sonstiger Hinweise, wo man sich denn befaende. Leider benutzt man in der Univerwaltung kein GIS, so dass es kein Repository fuer relevante Geodaten (z.B. auch Hoersaele, Eisautomaten,…) an der uulm gibt.

Passt genau!

Passt genau!

Als Fingeruebung habe ich deswegen erst einmal die Karte (bzw. einen Export davon) in QGIS georeferenziert. Anstatt (wie geplant) daraus eine Onlinekarte mit qgis2leaf zu exportieren, habe ich dabei erst einmal Dinge gelernt, von denen ich nicht dachte, dass ich sie einmal lernen wuerde. Zum Beispiel, dass WGS84 nicht gleich WGS84 ist, sondern einmal WGS84 als Koordinatensystem auf dem Referenzellipsoiden (EPSG:4326) und einmal als sphaerische Merkatorprojektion (EPSG:3857). Waehrend die OSM-Ursprungsdaten in EPSG:4326 sind, werden die Kacheln (wie auch bei Google Maps) als Projektion in EPSG:3857 referenziert; Koordinateneingaben werden aber als EPSG:4326 angenommen und dann in EPSG:3857 umprojiziert…

Das interessiert natuerlich keine Sau, die ihr Fahrrad abstellen will.

Nach einigem Ueberlegen kam ich daher zum Schluss, die Punkte auf der Karte mit der OpenStreetMap abzugleichen. Dort wird naemlich nicht nur der Ort abgelegt, sondern auch Metainformation wie die Zahl der Abstellplaetze, ob eine Ueberdachung besteht, etc. Die habe ich also bei den fehlenden Anlagen noch nachgetragen, und so ist seit dem Wochenende die OSM an der Uni Ulm mit der Realitaet der Abstellplaetze wieder weitgehend in Einklang 😉

Blieb die Frage, wie diese Daten dann den Weg in eine interaktive Karte finden, die ein wenig moderner ist als ein 2,5 MB grosses PDF.

Ich hatte mich neulich schon einmal mit der Overpass API fuer die Openstreetmap beschaeftigt, um komplette OSM-Dumps fuer Ulm zu ziehen. Eher wenig Beachtung hatte ich dabei dem Detail geschenkt, dass das ja 1.) eine API ist und 2.) damit auch Selektionen auf bestimmte Tags moeglich sind.

Mit Overpass Turbo ist das leicht auszuprobieren: Einfach mal im Wizard oben links eine beliebige Abfrage eingeben (Beispiele stehen schon darunter) und Ausfuehren – voila, da kommen die Daten als GeoJSON und werden auch auf der Karte angezeigt. Und von einer Aenderung eines solchen Punkts im OSM-Originaldatensatz dauert es nur wenige Sekunden, bis eine neuerliche Overpass-Abfrage die aktualisierten Daten anzeigt. Wohoo!

Mit leaflet-layer-overpass existiert derweil eine JS-Bibliothek, die Overpass mit Leaflet verknuepft, und so dauerte es nicht lange, bis die erste fertige Fahrradabstellanlagenkarte fertig war. Das einzige, was noch verbleibt, sind kleine Tweaks wie bessere Infopopups und eine Unterscheidung zwischen offenen und ueberdachten Abstellmoeglichkeiten.


Größere Karte anzeigen

Ich faende es cool, wenn moeglichst viele Geodaten der uulm nach und nach den Weg in die OSM finden wuerden. So blieben die Daten zentral in der Karte schlechthin, anstelle in verschiedenen dezentralen Repositories zu versauern – und nach und nach koennten Dinge wie Hoersaalfinder oder Uebersichtskarten von Eisautomaten allesamt mit Leaflet und Overpass realisiert werden 😉