Karten mit benutzerdefinierten Stilen

Passen Sie die Darstellung der Google-Standardkarte an, indem Sie in der Maps Static API eigene Stile anwenden. Sie können die visuelle Darstellung von Elementen wie Straßen, Parks, bebauten Flächen und anderen POIs ändern. Ändern Sie die Farbe oder den Stil, um bestimmte Inhalte hervorzuheben, Inhalte in der Umgebung auf der Seite zu ergänzen oder Elemente ganz auszublenden.

Beispiele

Im folgenden Beispiel wird eine Karte von Brooklyn, USA, angezeigt, wobei die lokalen Straßen in Hellgrün und die Wohngebiete in Schwarz eingefärbt werden. Außerdem wird die Helligkeit der Labels umgekehrt, sodass sie sich besser von einem dunklen Hintergrund abheben. Beachten Sie, dass bei diesem Beispiel URL-Codierung verwendet wird:

https://maps.googleapis.com/maps/api/staticmap?size=512x512&zoom=15&center=Brooklyn&style=feature:road.local%7Celement:geometry%7Ccolor:0x00ff00&style=feature:landscape%7Celement:geometry.fill%7Ccolor:0x000000&style=element:labels%7Cinvert_lightness:true&style=feature:road.arterial%7Celement:labels%7Cinvert_lightness:false&key=YOUR_API_KEY&signature=YOUR_SIGNATURE
Stilkarte von Brooklyn.

Im folgenden Beispiel werden Stilvorgänge und Vereinfachungen verwendet, um das Aussehen eines US-Straßenatlas anzunähern:

https://maps.googleapis.com/maps/api/staticmap?size=512x512&zoom=12&center=Chicago&format=png&style=feature:road.highway%7Celement:geometry%7Cvisibility:simplified%7Ccolor:0xc280e9&style=feature:transit.line%7Cvisibility:simplified%7Ccolor:0xbababa&style=feature:road.highway%7Celement:labels.text.stroke%7Cvisibility:on%7Ccolor:0xb06eba&style=feature:road.highway%7Celement:labels.text.fill%7Cvisibility:on%7Ccolor:0xffffff&key=YOUR_API_KEY&signature=DITIGAL_SIGNATURE
Kartenstil „Straßenatlas USA“.

Formatsyntax

Wenn Sie eine benutzerdefinierte Karte mit benutzerdefinierten Stilen erstellen möchten, müssen Sie einen oder mehrere style-Parameter in die Anfrage-URL einfügen.

Jede style-Deklaration kann die folgenden Argumente enthalten, getrennt durch Pipe-Zeichen ("|"):

  • feature (optional) gibt die Elemente an, die für diese Stiländerung ausgewählt werden sollen. Elemente umfassen Elemente auf der Karte wie Straßen, Parks oder andere POIs. Wenn kein feature-Argument vorhanden ist, gilt der angegebene Stil für alle Elemente.
  • element (optional) gibt die Elemente des angegebenen Elements an, die für diese Stiländerung ausgewählt werden sollen. Elemente sind Eigenschaften eines Elements, z. B. Geometrie oder Labels. Wenn kein element-Argument vorhanden ist, wird der Stil auf alle Elemente des angegebenen Elements angewendet.
  • Eine Reihe von Stilregeln (erforderlich), die auf die angegebenen Elemente und Elemente angewendet werden sollen. Die API wendet die Regeln in der Reihenfolge an, in der sie in der style-Deklaration aufgeführt sind. Sie können im Rahmen der normalen Einschränkungen für die URL-Länge der Maps Static API beliebig viele Regeln einfügen.
style=feature:myFeatureArgument|element:myElementArgument|myRule1:myRule1Argument|myRule2:myRule2Argument

Funktionen

Mit der folgenden style-Deklaration werden alle Straßen auf der Karte farbig dargestellt:

style=feature:road|color:0xffffff

Nachfolgend sehen Sie eine allgemeine Merkmalauswahl:

  • feature:all (Standardeinstellung): Zum Auswählen aller Funktionen der Karte.
  • feature:road zum Auswählen aller Straßen auf der Karte
  • feature:road.local zum Auswählen aller Ortsstraßen

Elemente oder Elementtypen sind geografische Charakteristika auf der Karte, etwa Straßen, Parks, Gewässer, Unternehmen und mehr.

Die Elemente bilden einen Kategoriebaum mit all als Stamm. Wenn kein Element angeben ist, werden alle Elemente ausgewählt. Wenn Sie das Element all angeben, hat das denselben Effekt.

Zu einigen Elementen gibt es untergeordnete Elemente, die nach einem Punkt notiert werden. Beispiel: landscape.natural oder road.local. Wenn Sie nur das übergeordnete Element angeben, z. B. road, gelten die für das übergeordnete Element angegebenen Stile auch für alle untergeordneten Elemente, zum Beispiel road.local und road.highway.

Es kann sein, dass einige Elemente von übergeordneten Elementen nicht in allen ihnen untergeordneten Elementen enthalten sind.

Die folgenden Elemente sind verfügbar:

  • all (Standardeinstellung): Zum Auswählen aller Elemente.
  • administrative zum Auswählen aller Bundesländer. Dies betrifft nur die Beschriftungen der Bundesländer, nicht die geografischen Grenzen oder die Füllbereiche.
    • administrative.country zum Auswählen von Ländern
    • administrative.land_parcel zum Auswählen von Flurstücken
    • administrative.locality zum Auswählen von Orten
    • administrative.neighborhood zum Auswählen von Stadtteilen
    • administrative.province zum Auswählen von Provinzen
  • landscape zum Auswählen aller Landschaften
    • landscape.man_made zum Auswählen von Elementen, die von Menschen erschaffen wurden, etwa Gebäuden und anderen Bauwerken
    • landscape.natural zum Auswählen von Landschaftselementen wie Bergen, Seen, Wüsten und Gletschern
    • landscape.natural.landcover zum Auswählen von Bodenbedeckungselementen, also dem physischen Material, mit dem die Erdoberfläche bedeckt wird, etwa Wälder, Grasland, Sumpfgebiete und Nackteboden
    • landscape.natural.terrain zum Auswählen von Geländeelementen einer Landoberfläche, z. B. Höhe, Gefälle und Ausrichtung
  • poi zum Auswählen aller POIs
    • poi.attraction zum Auswählen von Touristenattraktionen
    • poi.business zum Auswählen von Unternehmen
    • poi.government zum Auswählen von staatlichen Gebäuden
    • poi.medical zum Auswählen von Einrichtungen zur Notfallversorgung und -hilfe, etwa Krankenhäuser, Apotheken, Polizei oder Ärzte
    • poi.park zum Auswählen von Parks
    • poi.place_of_worship zum Auswählen von Andachtsstätten wie Kirchen, Tempeln und Moscheen
    • poi.school zum Auswählen von Schulen
    • poi.sports_complex zum Auswählen von Sportanlagen
  • road zum Auswählen aller Straßen
    • road.arterial zum Auswählen von Hauptverkehrsstraßen
    • road.highway zum Auswählen von Bundesstraßen
    • road.highway.controlled_access zum Auswählen von Autobahnen
    • road.local zum Auswählen lokaler Straßen
  • transit zum Auswählen aller Haltestellen und Linien öffentlicher Verkehrsmittel
    • transit.line zum Auswählen von Linien öffentlicher Verkehrsmittel
    • transit.station zum Auswählen aller Haltestellen öffentlicher Verkehrsmittel
    • transit.station.airport zum Auswählen von Flughäfen
    • transit.station.bus zum Auswählen von Bushaltestellen
    • transit.station.rail zum Auswählen von Bahnhöfen
  • water zum Auswählen von Gewässern

Elemente

In der folgenden style-Deklaration werden die Labels für alle Ortsstraßen farblich gekennzeichnet:

style=feature:road.local|element:labels|color:0xffffff

Ein Element besteht aus verschiedenen Unterelementen. Beispielsweise besteht eine Straße aus der Liniengrafik (Geometrie) auf der Karte sowie dem Text, der den Straßennamen angibt (Label).

Die folgenden Unterelemente stehen zur Verfügung, wobei Sie beachten sollten, dass ein bestimmtes Element ein Unterelement oder auch einige oder alle Unterelemente unterstützen kann:

  • all (Standard): Zum Auswählen aller Elemente des angegebenen Elements
  • geometry zum Auswählen aller geometrischen Elemente des angegebenen Elements
    • Mit geometry.fill wird nur die Füllung der Geometrie des Elements ausgewählt.
    • Mit geometry.stroke wird nur der Strich der Geometrie des Elements ausgewählt.
  • labels zum Auswählen der Textlabels, die dem angegebenen Element zugeordnet sind
    • Mit labels.icon wird nur das Symbol ausgewählt, das im Label des Elements angezeigt wird.
    • Mit labels.text wird nur der Text des Labels ausgewählt.
    • Mit labels.text.fill wird nur die Füllung des Labels ausgewählt. Der Füllbereich eines Labels wird in der Regel als farbiger Rahmen um den Labeltext dargestellt.
    • Mit labels.text.stroke wird nur der Strich des Labeltexts ausgewählt.

Formatregeln

Stilregeln sind Formatierungsoptionen, die auf die in den einzelnen style-Deklarationen angegebenen Elemente und Elemente angewendet werden.

Mit der folgenden style-Deklaration werden zwei Stilregeln auf die Straßen auf der Karte angewendet. Durch die erste Regel wird eine Farbe auf die Straßen angewendet. Die zweite Regel vereinfacht die Darstellung der Straßen, sodass sie dünnere Linien ohne Umriss haben:

style=feature:road|color:0xffffff|visibility:simplified

Jede style-Deklaration muss einen oder mehrere Vorgänge enthalten, die durch ein Pipe-Zeichen ("|") voneinander getrennt sind. Bei jedem Vorgang wird der Argumentwert mithilfe des Doppelpunktzeichens („:“) angegeben. Alle Vorgänge werden in der Reihenfolge auf die Auswahl angewendet, in der Sie sie angeben.

Die folgenden Stiloptionen werden unterstützt:

  • hue (ein hexadezimaler RGB-String des Formats #RRGGBB) gibt die Grundfarbe an.

    Hinweis: Mit dieser Option wird der Farbton festgelegt, während die Sättigung und die Helligkeit weiterhin der Festlegung im Standard-Google-Stil entsprechen (oder in anderen Stiloptionen, die Sie für die Karte definieren). Die resultierende Farbe hängt vom Stil der Basiskarte ab. Änderungen, die Google am Basiskartenstil vornimmt, wirken sich auf die mit hue formatierten Elemente Ihrer Karte aus. Verwenden Sie daher wenn möglich den Absolut-Styler color.

  • lightness (ein Gleitkommawert zwischen -100 und 100) gibt die Helligkeitsänderung des Unterelements in Prozent an. Negative Werte führen zu einem dunkleren Ergebnis (wobei -100 Schwarz ergibt), positive Werte sorgen für mehr Helligkeit (wobei +100 Weiß ergibt).

    Mit dieser Option wird die Helligkeit festgelegt, während die Sättigung und der Farbton weiterhin der Festlegung im Standard-Google-Stil entsprechen (oder in anderen Stiloptionen, die Sie für die Karte definieren). Die resultierende Farbe hängt vom Stil der Basiskarte ab. Änderungen, die Google am Basiskartenstil vornimmt, wirken sich auf die mit lightness formatierten Elemente Ihrer Karte aus. Verwenden Sie daher wenn möglich den Absolut-Styler color.

  • saturation (ein Gleitkommawert zwischen -100 und 100) gibt die Intensitätsänderung der Grundfarbe in Prozent an, die auf das Element angewendet wird.

    Hinweis: Mit dieser Option wird die Sättigung festgelegt, während der Farbton und die Helligkeit weiterhin der Festlegung im Standard-Google-Stil entsprechen (oder in anderen Stiloptionen, die Sie für die Karte definieren). Die resultierende Farbe hängt vom Stil der Basiskarte ab. Änderungen, die Google am Basiskartenstil vornimmt, wirken sich auf die mit saturation formatierten Elemente Ihrer Karte aus. Verwenden Sie daher wenn möglich den Absolut-Styler color.

  • gamma (ein Gleitkommawert zwischen 0.01 und 10.0, wobei mit 1.0 keine Korrektur angewendet wird) gibt die Stärke der Gammakorrektur an, die auf das Unterelement angewendet wird. Mit Gammakorrekturen werden nicht lineare Korrekturen von Farbhelligkeiten durchgeführt. Schwarz- und Weißwerte werden nicht beeinflusst. Gammakorrekturen erfolgen in der Regel, um den Kontrast mehrerer Unterelemente zu ändern. Sie können den Gammakorrekturwert beispielsweise ändern, um den Kontrast zwischen den Rändern und dem Innenbereich von Unterelementen zu erhöhen oder zu verringern.

    Mit dieser Option wird die Helligkeit relativ zum Standard-Google-Stil anhand einer Gammakurve variiert. Wenn Google Änderungen am Basiskartenstil vornimmt, wirken sich diese Änderungen auf die mit gamma formatierten Elemente Ihrer Karte aus. Verwenden Sie daher wenn möglich den Absolut-Styler color.

  • invert_lightness (wenn true) invertiert die vorhandene Helligkeit. Das ist z. B. hilfreich, um schnell zu einer dunkleren Karte mit weißem Text zu wechseln.

    Hinweis: Mit dieser Option wird der Standard-Google-Stil invertiert. Wenn Google Änderungen am Basiskartenstil vornimmt, haben diese Änderungen Auswirkungen auf die mit invert_lightness formatierten Elemente Ihrer Karte. Verwenden Sie daher wenn möglich den Absolut-Styler color.

  • visibility (on, off oder simplified) gibt an, ob und wie die Elemente auf der Karte angezeigt werden. Bei der Sichtbarkeit simplified werden einige Stilelemente aus den betroffenen Elementen entfernt. Straßen werden zum Beispiel zu dünneren Linien ohne Konturen vereinfacht, während Parks ihren Labeltext verlieren, aber das Labelsymbol behalten.
  • Mit color (ein hexadezimaler RGB-String des Stils #RRGGBB) wird die Farbe eines Elements festgelegt.
  • Mit weight (eine Ganzzahl größer oder gleich null) wird die Stärke des Elements in Pixeln angegeben. Ein hoher Wert kann dazu führen, dass die Darstellung an den Kachelrändern abgeschnitten wird.

Stilregeln werden in der von Ihnen angegebenen Reihenfolge angewendet. Vermeiden Sie es, mehrere Vorgänge zu einem einzigen Stiländerungs-Vorgang zu kombinieren. Definieren Sie stattdessen jeden Vorgang als separaten Eintrag im Stilarray.

Hinweis: Die Reihenfolge ist hierbei wichtig, weil einige Vorgänge nicht vertauscht werden dürfen. Für Elemente und/oder Unterelemente, die durch Vorgänge geändert werden, sind normalerweise bereits Stile vorhanden. Mit diesen Vorgängen werden diese bestehenden Stile (sofern vorhanden) geändert.

HSL-Farbmodell

Für Karten mit benutzerdefinierten Stilen wird das HSL-Modell (Hue, Saturation, Lightness; Farbton, Sättigung, Helligkeit) zur Darstellung von Farben in Styler-Vorgängen verwendet. Farbton gibt die Grundfarbe an, Sättigung die Intensität der Farbe und Helligkeit den relativen Anteil von Weiß oder Schwarz in der zugehörigen Farbe.

Mit der Gammakorrektur wird die Sättigung über den Farbraum hinweg geändert, in der Regel zum Erhöhen oder Verringern des Kontrasts. Außerdem definiert das HSL-Modell die Farbe in einem Koordinatenbereich, wobei hue die Ausrichtung innerhalb eines Farbrads angibt, während Sättigung und Helligkeit Werte entlang verschiedener Achsen angeben. Farbtöne werden in einem RGB-Farbraum gemessen, der den regulären RGB-Farbräumen entspricht, außer dass Weiß- und Schwarzschattierungen fehlen.

Modell „Farbton, Sättigung und Helligkeit“

Für hue wird ein HTML-Hexadezimalwert zur Farbbestimmung verwendet, jedoch legt dieser Wert ausschließlich die Grundfarbe fest, d. h. die Ausrichtung im Farbrad. Die Werte für Sättigung und Helligkeit werden separat als prozentuale Änderungen angegeben.

Beispielsweise können Sie den Farbton für reines Grün als hue:0x00ff00 oder hue:0x000100 definieren. Die beiden Farbtöne sind identisch. Beide Werte ergeben im HSL-Farbmodell reines Grün.

Ein RGB-Farbrad

RGB-Farbtonwerte (hue), die zu gleichen Teilen aus Rot, Grün und Blau bestehen, geben keinen Farbton an, da keiner dieser Werte eine Ausrichtung im Koordinatensystem für Farbton, Sättigung und Helligkeit angibt. Beispiele sind „#000000“ (Schwarz), „#FFFFFF“ (Weiß) und alle reinen Grauschattierungen. Zum Angeben von Schwarz, Weiß oder Grau muss saturation entfernt werden, indem Sie den Wert auf -100 setzen. Passen Sie dann den lightness-Wert an.

Außerdem werden beim Ändern vorhandener Funktionen, die bereits ein Farbschema haben, durch das Ändern eines Werts wie zum Beispiel hue die vorhandenen saturation- oder lightness-Werte nicht geändert.