Bevor wir mit den Buslinen weiterarbeiten, müssen wir natürlich den Kommentar beim Aufruf loadLines("https://...")
löschen, damit sie auch angezeigt werden.
Wir erinnen uns an das erste Usage example der L.geoJSON Dokumentation das alles beinhaltet, was wir für unsere Linien benötigen.
L.geoJSON(data, {
style: function (feature) {
return {color: feature.properties.color};
}
}).bindPopup(function (layer) {
return layer.feature.properties.description;
}).addTo(map);
in der style Option des Optionenobjekts wird für jedes geoJSON-Objekt einen Funktion ausgeführt, deren Rückgabeobjekt das Aussehen der Linie bestimmt
mit der .bindPopup Methode wird für jedes geoJSON-Objekt einen Funktion ausgeführt, deren Rückgabeobjekt den Inhalt des Popups bestimmt.
Beginnen wir mit der leichteren Übung, dem Popup
Am Ende unseres L.geoJSON()
Aufrufs in loadLines
kopieren den .bindPopup()
Code der Leafletdokumentation und ändern den Rückgabewert auf layer.feature.properties.LINE_NAME
. In der Zeile davor, lassen wir uns noch das layer.feature.properties
Objekt anzeigen - wir erkennen darin die Attribute unserer Linien sobald wir auf eine Linie klicken.
L.geoJSON(geojson).bindPopup(function (layer) {
console.log(layer.feature.properties);
return layer.feature.properties.LINE_NAME;
}).addTo(overlay);
Mit Template-Syntax und Backticks können wir das Popup verfeinern und die Stationen des Abschnitts mit angeben
return `
<h4>${layer.feature.properties.LINE_NAME}</h4>
von: ${layer.feature.properties.FROM_NAME}
<br>
nach: ${layer.feature.properties.TO_NAME}
`;
Zur Bestimmung der Linienfarbe dient die style-Option des Optionenobjekts beim L.geoJSON()
Aufruf. Wie bei den Popups, wird für jede Linie die angegebene Funktion ausgeführt und über den Rückgabewert festgelegt, wie die Linie aussehen soll. Die Leafletdokumentation zeigt uns bei den Path options, welche Stylingmöglichkeiten zur Verfügung stehen. Wir kopieren den style
-Block der Dokumentation und geben die Linienfarbe green für alle Linien zurück.
L.geoJSON(geojson, {
style: function (feature) {
return {
color: "green"
};
}
})
Wir könnten wieder eine if-Abfrage zur Bestimmung der passenden Liniefarbe machen, eleganter ist es allerdings, wenn wir uns ein Javascript-Objekt mit Key/Value Paaren basteln, bei denen der Key dem Namen der Linie in feature.properties.LINE_NAME
und der Value der gewünschten Farbe entspricht. Wir nennen dieses Objekt colors
, schreiben es direkt vor die return
Anweisung und so sieht es mit passenden Farben von https://clrs.cc/ aus:
let colors = {
"Red Line": "#FF4136",
"Yellow Line": "#FFDC00",
"Blue Line": "#0074D9",
"Green Line": "#2ECC40",
"Grey Line": "#AAAAAA",
"Orange Line": "#FF851B"
};
Jetzt müssen wir nur noch die Farbe je nach Liniennamen bei der Pfad Option color einsetzen. Steht in feature.properties.LINE_NAME
“Red Line”, wird colors["Red Line"]
verwendet, steht dort “Blue Line”, wird colors["Blue Line"]
verwendet usw.
return {
color: `${colors[feature.properties.LINE_NAME]}`
}
Wir könnten mit der Pfad Option weight auch die Strichstärke auf 4 Pixel statt 3 Pixel (dem Defaultwert) ändern, oder die Linien über die Pfad Option dashArray strichliert zeichnen
return {
color: colors[feature.properties.LINE_NAME],
weight: 4,
dashArray: [10, 6]
};
Wir löschen wieder den Kommentar beim loadZones("https://...")
Aufruf und machen dann das Selbe wie bei den Linien
Danach können wir den .bindPopup() Code der Linien einfach kopieren und ans Ende des L.geoJSON() Aufrufs schreiben. Natürlich müssen wir das Popup auch gleich anpassen - wir verwenden die Attribute ADRESSE , ZEITRAUM und AUSN_TEXT . Nachdem bei den Attributen ZEITRAUM und AUSN_TEXT oft null , also keine Angabe steht, verwenden wir den [**Logical OR ( |
)*](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Logical_OR) Operator, um in diesen Fällen eine leere Zeichenkette statt *null anzuzeigen. |
L.geoJSON(geojson).bindPopup(function (layer) {
return `
<h4>Fußgängerzone ${layer.feature.properties.ADRESSE}</h4>
<p>${layer.feature.properties.ZEITRAUM || ""}</p>
<p>${layer.feature.properties.AUSN_TEXT || ""}</p>
`;
}).addTo(overlay);
Bei den Flächen ändern wir die Standardfarbe (color) auf https://clrs.cc/ FUCHSIA (#F012BE), die Strichstärke (weight) der Linie auf 1 und die Transparenz von Randlinie (opacity) und Fläche (fillOpacity) jeweils auf 0.1
L.geoJSON(geojson, {
style: function(feature) {
return {
color: "#F012BE",
weight: 1,
opacity: 0.1,
fillOpacity: 0.1
}
}
})