Webmapping OER Kurs Lern-Session Hintergrundkarten mit Web Map Tile Services (WMTS) von Klaus Förster unter der Lizenz CC-BY 4.0. Kartendaten der Verwaltungsgrundkarte Raster Österreich von basemap.at unter der Lizenz CC-BY 4.0.
Willkommen zur Webmapping OER Lern-Session Hintergrundkarten mit Web Map Tile Services (WMTS). Nimm dir einenhalb Stunden Zeit und entdecke am Beispiel der Verwaltungsgrundkarte Österreich, wie du mit einem freien WMTS-Dienst und Leaflet Hintergrundkarten für dein Webmapping Projekt in einer wählbaren Layer-Control implementieren kannst.
[!NOTE] Zum Arbeiten benötigst du einen Standard konformen Browser (z.B. Firefox), Visual Studio Code zum Editieren der HTML und Javascript Dateien und LibreOffice für die Aufgabe sowie die Übung im Anschluss an die Einheit. Die komplette Einheit kannst du unter Releases als ZIP-Datei downloaden, lokal auf deinem Computer entpacken und in Visual Studio Code über “Ordner Öffnen” verfügbar machen. Beim Ansehen der Markdown-Dateien (.md) hilft dir die Tastenkombination
Ctrl + Shift + V
und mit dem Visual Studio Code Plugin Live Server Plugin von Ritwick Dey kannst du dir HTML-Seiten wie im Web anzeigen lassen. Klicke dazu einfach auf “Go Live” im rechten, unteren Eck des Editors.
Zeit: 10 Minuten
Die folgende Präsentation gibt einen kurzen Überblick, wie man sich Web Map Tile Services (WMTS) vorstellen kann. Beschäftige dich mit den wenigen Folien und recherchiere eigenständig im Internet, wenn dir etwas nicht klar ist, oder du mehr Information möchtest.
Präsentation Einführung Web Map Tile Services (WMTS) von Klaus Förster unter der Lizenz CC-BY-4.0. Kartendaten für Grafiken von basemap.at unter der Lizenz CC-BY-4.0 via data.gv.at.
Zeit: 20 Minuten
Wie du aus der Präsentation weißt, werden WMTS-Dienste in einer GetCapabilities.xml
Datei definiert. Sieh dir die entsprechende XML-Datei der Verwaltungsgrundkarte Raster Österreich an:
Download GetCapabilities-basemap.xml
WMTS GetCapabilities XML Datei für die Verwaltungsgrundkarte Raster Österreich von basemap.at unter der Lizenz CC-BY-4.0 via data.gv.at
Finde alle Layer, die vom basemap.at WMTS-Dienst angeboten werden und trage für jeden Layer die Attribute URL zur XML-Datei
, Titel
, Abstract
, Extent mit Min-XY, Max-XY
, Style
, TileMatrixSet
, ResourceURL
und maximaler Zoom-Level
in diesem LibreOffice-Template ein:
Download GetCapabilities_analyse_template.ods
LibreOffice Mustertabelle GetCapabilities_analyse_template.ods von Klaus Förster unter der Lizenz CC0
[!TIP] Die meisten Attribute sind leicht zu finden, nur beim maximalen Zoom-Level musst du “etwas ums Eck denken”, denn der steht nicht direkt in der Layer-Definition sondern muss aus dieser abgeleitet werden …
Zeit: 10 Minuten
In der Leaflet-Dokumentation unter L.tileLayer()
(https://leafletjs.com/reference.html#tilelayer) siehst du, wie WMTS-Dienste in Leaflet implementiert werden können. Sieh dir das Usage example für die OpenStreetMap an und versuche, die ResourceURL
der Layer der Verwaltungsgrundkarte in gültige URLs für Leaflet umzuwandeln. Denke dabei nicht zu kompliziert, sondern versuche, die ResourceURL
so umzuformen, dass am Ende nur noch {x}
, {y}
und {z}
als Platzhalter in der Leaflet-URL übrig bleiben. Alle anderen {xxx}
-Einträge sollten aufgelöst sein. Ergänze die umgeformten URLs in der Analysetabelle in einer neuen Spalte LeafletURL
Zusätzlich benötigen wir aus rechtlichen Gründen auch die Attribution für die basemap.at Daten. Sie wird später von Leaflet in der rechten, unteren Ecke der Karte als attribution
(https://leafletjs.com/reference.html#tilelayer-attribution) angezeigt werden. Was dort stehen soll, findest du bei der Datensatzbeschreibung der basemap.at Verwaltungsgrundkarte Raster Österreich beim Open Data Portal Österreichs (data.gv.at) unter https://www.data.gv.at/katalog/de/dataset/basemap-at. Halte Ausschau nach einem “Lizenzzitat” und ergänze den HTML-Code für dieses Zitat mit Link zur Lizenz in der Analysetabelle in einer neuen Spalte Attribution HTML
.
Damit ist unsere Analysetabelle mit den Attributen der basemap.at WMTS-Layer vollständig. Zur Kontrolle kannst du dir diese ausgefüllte Tabelle ansehen und vergleichen, ob du zum selben Ergebnis gekommen bist:
Download GetCapabilities_analyse.ods
LibreOffice Analysetabelle GetCapabilities_analyse.ods von Klaus Förster unter der Lizenz CC-BY-4.0
Zeit: 10 Minuten
Damit ist es Zeit, sich der Visualisierung mit Leaflet zuzuwenden. Damit du dich auf das Implementieren der Karte konzentrieren kannst, ist ein Template mit HTML-, CSS- und Javascript-Dateien bereits vorbereitet (siehe Webvorschau):
Download HTML/CSS/Javascript template-wmts.zip
HTML/CSS/Javascript Template WMTS Hintergrundkarten (basemap.at) von Klaus Förster unter der Lizenz CC-BY-4.0
Entpacke template-wmts.zip
bei dir lokal am Rechner und öffne das Verzeichnis, in dem du es entpackt hast, mit “Ordner öffnen” in Visual Studio Code. Damit kannst du mit dem Live Server Plugin von Ritwick Dey die Webseite ansehen, als ob sie im Netz wäre. Klicke dazu einfach auf “Go Live” im rechten, unteren Eck des Editors.
In der index.html
und main.js
Datei stehen Kommentare, die du im ersten Schritt mit HTML-Elementen und Leaflet-Aufrufen ersetzen musst. Führe folgende Schritte aus:
binde in index.html
die Leaflet-Bibliothek über https://cdnjs.com/libraries/leaflet ein
<script src="https://cdnjs.cloudflare.com/ajax/libs/leaflet/1.9.4/leaflet.js" integrity="sha512-BwHfrr4c9kmRkLw6iXFdzcdWV/PGkVgiIyIWLLlTSXzWQzxuSg4DiQUCpauz/EWjgk5TYQqX/kvn9pG1NpYfqg==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/leaflet/1.9.4/leaflet.css" integrity="sha512-Zcn6bjR/8RZbLEpLIeOwNtzREBAJnUKESxces60Mpoj+2okopSAcSUIUOseddDm0cxnGQzxIR7vJgsLZbdLE3w==" crossorigin="anonymous" referrerpolicy="no-referrer" />
initialisiere in main.js
mit L.map()
(https://leafletjs.com/reference.html#map) die Karte. Die Optionen center
und zoom
kannst du weglassen - wir werden stattdessen den Kartenausschnitt auf den ermittelten Extent der basemap.at Layer setzen.
let map = L.map('map');
setze mit map.fitBounds()
(https://leafletjs.com/reference.html#map-fitbounds) den Ausschnitt auf den Extent der basemap.at Layer, den wir in der Analysetabelle in der Spalte Extent mit Min-XY, Max-XY
als 8.782379 46.358770 17.5 49.037872
festgehalten haben. Die Methode map.fitBounds()
erwartet beim Aufruf als Argument einen Array bestehende aus zwei weiteren Arrays für Min Lat/Lng
und Max Lat/Lng
- die Koordinaten-Werte des Extents unserer Analysetabelle müssen also vertauscht werden, denn x
entspricht der geographischen Länge und y
der geographischen Breite.
map.fitBounds([
[46.358770, 8.782379 ],
[49.037872, 17.5]
]);
füge mit L.control.scale()
(https://leafletjs.com/reference.html#control-scale) einen metrischen Maßstab hinzu. Über die Option imperial
: false
kannst du die Skala in Meilen, die sonst zusätzlich angezeigt würde, ausblenden.
L.control.scale({
imperial: false
}).addTo(map);
Damit ist die Karte initialisiert. Ob wir auch auf den richtigen Ausschnitt blicken, werden wir erst später sehen, denn noch ist die Kartenfläche grau, mit einer Maßstabsleiste in der linken unteren Ecke und einer Zoom-Kontrolle in der linken oberen Ecke.
Zeit: 20 Minuten
Die Layer-Control für die verfügbaren basemap.at Layer erstellst du in zwei Schritten
füge zuerst mit L.control.layers()
(https://leafletjs.com/reference.html#control-layers) eine leere Layer-Control hinzu - du wirst sie als Layer-Icon im rechten oberen Eck erkennen:
L.control.layers().addTo(map);
dann kannst du mit L.tileLayer()
(https://leafletjs.com/reference.html#tilelayer) die einzelnen basemap.at Layer definieren. Verwende die Werte der Analysetabelle für die einzelnen Komponenten des Aufrufs: das URL template steht in LeafletURL
, die Option attribution
in Attribution HTML
und die Option maxZoom
in maximaler Zoom-Level
. Am Beispiel der Geoland Basemap sieht der L.tileLayer()
Aufruf dann so aus:
L.tileLayer(
"https://mapsneu.wien.gv.at/basemap/geolandbasemap/normal/google3857/{z}/{y}/{x}.png", {
attribution: `Datenquelle: <a href="https://basemap.at/#lizenz">basemap.at</a>`,
maxZoom: 20
}
)
[!TIP] Verwende für die Attribution sogenannte Javascript Template literals (Template strings) mit Backticks (` `), dann musst du dich nicht um Anführungszeichen bei den Links kümmern und könntest über string interpolation auch Variablen in der Attribution direkt auflösen
im letzten Schritt, kannst du alle L.tileLayer()
Aufrufe mit einem Label in das Base layers Objekt der Layer-Control einfügen. Verwende als Label die (bei High-DPI, Gelände und Oberfläche leicht gekürzte) Spalte Titel
der Analysetabelle. Vergiss nicht, den ersten Layer auch mit .addTo(map)
an die Karte zu hängen, denn nur so wird dieser Layer beim Laden der Seite auch gleich angezeigt. Der fertige Code für die Layer-Control sieht damit so aus:
L.control.layers({
"Geoland Basemap": L.tileLayer(
"https://mapsneu.wien.gv.at/basemap/geolandbasemap/normal/google3857/{z}/{y}/{x}.png", {
attribution: `Datenquelle: <a href="https://basemap.at/#lizenz">basemap.at</a>`,
maxZoom: 20
}
).addTo(map),
"Geoland Basemap Overlay": L.tileLayer(
"https://mapsneu.wien.gv.at/basemap/bmapoverlay/normal/google3857/{z}/{y}/{x}.png", {
attribution: `Datenquelle: <a href="https://basemap.at/#lizenz">basemap.at</a>`,
maxZoom: 20
}
),
"Basemap von Österreich in Grau": L.tileLayer(
"https://mapsneu.wien.gv.at/basemap/bmapgrau/normal/google3857/{z}/{y}/{x}.png", {
attribution: `Datenquelle: <a href="https://basemap.at/#lizenz">basemap.at</a>`,
maxZoom: 20
}
),
"Basemap für high dpi Displays": L.tileLayer(
"https://mapsneu.wien.gv.at/basemap/bmaphidpi/normal/google3857/{z}/{y}/{x}.jpeg", {
attribution: `Datenquelle: <a href="https://basemap.at/#lizenz">basemap.at</a>`,
maxZoom: 20
}
),
"Basemap als farbiges Orthofoto": L.tileLayer(
"https://mapsneu.wien.gv.at/basemap/bmaporthofoto30cm/normal/google3857/{z}/{y}/{x}.jpeg", {
attribution: `Datenquelle: <a href="https://basemap.at/#lizenz">basemap.at</a>`,
maxZoom: 20
}
),
"Basemap Geländedarstellung in Grau": L.tileLayer(
"https://mapsneu.wien.gv.at/basemap/bmapgelaende/grau/google3857/{z}/{y}/{x}.jpeg", {
attribution: `Datenquelle: <a href="https://basemap.at/#lizenz">basemap.at</a>`,
maxZoom: 17
}
),
"Basemap Oberflächendarstellung in Grau": L.tileLayer(
"https://mapsneu.wien.gv.at/basemap/bmapoberflaeche/grau/google3857/{z}/{y}/{x}.jpeg", {
attribution: `Datenquelle: <a href="https://basemap.at/#lizenz">basemap.at</a>`,
maxZoom: 17
}
),
}).addTo(map);
Zeit: 5 Minuten
Die Layer der basemap.at umfassen auch drei Layer, die keine Beschriftung aufweisen: Orthofoto, Gelände und Oberfläche. Sie können mit dem Overlay für Beschriftungen ganz einfach kombiniert werden. Versuche es am Beispiel des Orthofotos:
verwende L.layerGroup()
(https://leafletjs.com/reference.html#layergroup) um das Orthofoto mit dem Overlay zu kombinieren. Du musst nur die beiden L.tileLayer()
Definitionen als Array übergeben, wobei der zweite Layer, den ersten überlagert. Verwende den niedrigeren Zoom-Level des Orthofotos auch bei der Beschriftung um zu verhindern, dass ab Zoom-Level 18 die Beschriftung alleine übrig bleibt.
dann musst du die LayerGroup noch mit einem Label an die Layer-Control hängen. Der komplette Code sieht damit so aus:
L.control.layers({
// bestehende tileLayer
"Basemap als farbiges Orthofoto beschriftet": L.layerGroup([
L.tileLayer(
"https://mapsneu.wien.gv.at/basemap/bmaporthofoto30cm/normal/google3857/{z}/{y}/{x}.jpeg", {
attribution: `Datenquelle: <a href="https://basemap.at/#lizenz">basemap.at</a>`,
maxZoom: 17
}
),
L.tileLayer(
"https://mapsneu.wien.gv.at/basemap/bmapoverlay/normal/google3857/{z}/{y}/{x}.png", {
attribution: `Datenquelle: <a href="https://basemap.at/#lizenz">basemap.at</a>`,
maxZoom: 17
}
)
])
}).addTo(map);
Zeit: 5 Minuten
Ganz zum Schluss kannst du noch die Quelle für die Kartendaten der Verwaltungsgrundkarte Raster Österreich im Footer ergänzen
Kartendaten der <a href="https://www.data.gv.at/katalog/de/dataset/basemap-at">Verwaltungsgrundkarte Raster Österreich</a> von <a href="https://basemap.at/#lizenz">basemap.at</a> unter der Lizenz <a href="https://creativecommons.org/licenses/by/4.0/deed.de">CC-BY 4.0</a>.
</footer>
Damit ist die Karte fertig. Das Ergebnis kannst du dir auch auf der Kurshomepage unter https://webmapping-oer.github.io/wmts/solution ansehen.
Visualisierung WMTS Hintergrundkarten (basemap.at) von Klaus Förster unter der Lizenz CC-BY-4.0. Kartendaten von basemap.at unter der Lizenz CC-BY-4.0 via data.gv.at. Kartenbibliothek Leaflet zur Visualisierung von Volodymyr Agafonkin unter der BSD 2-Clause Lizenz via cdnjs.com
Zeit: 90-120 Minuten
Als Übung für zu Hause sollst du dich mit zwei weiteren WMTS-Diensten Österreichs beschäftigen: der eGrundkarte von Tirol und dem Web Map Tile Service der Stadt Wien.
ergänze die Attribute für alle verfügbaren Layer der beiden WMTS-Dienste in der Analysetabelle
visualisiere alle verfügbaren Layer der beiden WMTS-Dienste in zwei HTML-Seiten (tirol.html
, wien.html
) mit zwei eingebundenen Scripts (tirol.js
, wien.js
). Das CSS Stylesheet main.js
kannst du für beide Karten verwenden.
Die GetCapabilities.xml
- Dateien zur Analyse kannst du hier downloaden:
Download GetCapabilities-tirol.xml
WMTS GetCapabilities XML Datei für die eGrundkarte Tirol von Land Tirol unter der Lizenz CC-BY-4.0 via data.gv.at
Download GetCapabilities-wien.xml
WMTS GetCapabilities XML Datei für den Web Map Tile Service (WMTS) Wien von Stadt Wien unter der Lizenz CC-BY-4.0 via data.gv.at
Die Analysetabelle mit allen Einträgen kannst du dir natürlich auch ansehen - am Besten erst nach dem Üben ;-)
Download GetCapabilities_analyse_alles.ods
LibreOffice Analysetabelle (alle Dienste) GetCapabilities_analyse_alles.ods von Klaus Förster unter der Lizenz CC-BY-4.0
Hier noch die Liste der verwendeten Materialien mit Lizenz-Zitaten.
Präsentation Einführung Web Map Tile Services (WMTS) von Klaus Förster unter der Lizenz CC-BY-4.0. Kartendaten für Grafiken von basemap.at unter der Lizenz CC-BY-4.0 via data.gv.at
Symbol-Icon für die WMTS-Präsentation von Klaus Förster unter der Lizenz CC0
Grafik WMTS Kartenkacheln der Verwaltungsgrundkarte Raster Österreich (grau) von Klaus Förster unter der Lizenz CC-BY-4.0 via concept_wmts_wien.html. Kartendaten von basemap.at unter der Lizenz CC-BY-4.0 via data.gv.at.
HTML-Seite WMTS Kartenkacheln der Verwaltungsgrundkarte Raster Österreich (grau) von Klaus Förster unter der Lizenz CC-BY-4.0. Kartendaten von basemap.at unter der Lizenz CC-BY-4.0 via data.gv.at.
WMTS GetCapabilities XML Datei für die Verwaltungsgrundkarte Raster Österreich von basemap.at unter der Lizenz CC-BY-4.0 via data.gv.at
WMTS GetCapabilities XML Datei für den Web Map Tile Service (WMTS) Wien von Stadt Wien unter der Lizenz CC-BY-4.0 via data.gv.at
WMTS GetCapabilities XML Datei für die eGrundkarte Tirol von Land Tirol unter der Lizenz CC-BY-4.0 via data.gv.at
HTML/CSS/Javascript Template WMTS Hintergrundkarten (basemap.at) von Klaus Förster unter der Lizenz CC-BY-4.0 via template-wmts.zip
Visualisierung WMTS Hintergrundkarten (basemap.at) von Klaus Förster unter der Lizenz CC-BY-4.0. Kartendaten von basemap.at unter der Lizenz CC-BY-4.0 via data.gv.at. Kartenbibliothek Leaflet zur Visualisierung von Volodymyr Agafonkin unter der BSD 2-Clause Lizenz via cdnjs.com
LibreOffice Template GetCapabilities_analyse_template.ods von Klaus Förster unter der Lizenz CC0
LibreOffice Analysetabelle GetCapabilities_analyse.ods von Klaus Förster unter der Lizenz CC-BY-4.0
LibreOffice Analysetabelle (alle Dienste) GetCapabilities_analyse_alles.ods von Klaus Förster unter der Lizenz CC-BY-4.0