Karten mit benutzerdefinierten Stilen

Wenn Sie die Maps Static API verwenden, können Sie die Darstellung der Standard-Google-Karte anpassen, indem Sie eigene Stile anwenden. Sie können die visuelle Darstellung von Elementen wie Straßen, Parks, bebauten Gebieten und anderen POIs ändern. Sie können ihre Farbe oder ihren Stil ändern, um bestimmte Inhalte hervorzuheben, die umgebenden Inhalte auf der Seite zu ergänzen oder Funktionen sogar vollständig auszublenden.

Beispiele

Im folgenden Beispiel ist eine Karte von Brooklyn, USA, zu sehen. Die Nebenstraßen sind hellgrün und die Wohngebiete schwarz dargestellt. Außerdem wird die Helligkeit der Beschriftungen 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
Karte von Brooklyn mit benutzerdefiniertem Stil

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

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 „US Road Atlas“

Formatsyntax

Wenn Sie eine benutzerdefinierte Karte mit Stil erstellen möchten, fügen Sie der Anfrage-URL einen oder mehrere style-Parameter hinzu.

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

  • feature ist optional und gibt die Elemente an, die für diese Stiländerung ausgewählt werden sollen. Zu den Elementen gehören Elemente auf der Karte wie Straßen, Parks oder andere POIs. Wenn kein feature-Argument vorhanden ist, wird der angegebene Stil auf alle Elemente angewendet.
  • 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 Beschriftungen. Wenn kein element-Argument vorhanden ist, wird der Stil auf alle Unterelemente des angegebenen Elements angewendet.
  • Eine Reihe von Stilregeln (erforderlich), die auf die angegebenen Elemente und Unterelemente 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 beliebig viele Regeln angeben, sofern die URL-Länge die normalen Einschränkungen der Maps Static API nicht überschreitet.
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 Elemente der Karte.
  • Mit feature:road werden alle Straßen auf der Karte ausgewählt.
  • feature:road.local zum Auswählen aller Nebenstraß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 Unterelemente 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 Landbedeckungselementen, etwa Wäldern, Graslandschaft, Sumpfgebieten und unbedecktem Boden
    • landscape.natural.terrain zum Auswählen von Geländemerkmalen 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 von 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 örtlicher 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

Mit der folgenden style-Deklaration werden die Labels für alle örtlichen Straßen eingefärbt:

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 genau ein Unterelement oder auch einige oder alle Unterelemente unterstützen kann:

  • all (Standard): Zum Auswählen aller Unterelemente des angegebenen Elements
  • geometry zum Auswählen aller geometrischen Unterelemente 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.
  • Mit labels werden die mit dem angegebenen Element verknüpften Textlabels ausgewählt.
    • 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ünner und ohne Konturen sind:

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

Jede style-Deklaration muss einen oder mehrere Vorgänge enthalten, die durch das Pipe-Zeichen („|“) getrennt sind. Jeder Vorgang gibt seinen Argumentwert mit dem Doppelpunktzeichen (":") an. Alle Vorgänge gelten für die Auswahl in der von Ihnen angegebenen Reihenfolge.

Die folgenden Stiloptionen werden unterstützt:

  • hue (ein hexadezimaler RGB-String des Stils #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 Unterelement 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 Unterelemente 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 Elemente, die bereits ein Farbschema haben, durch das Ändern eines Werts wie zum Beispiel hue die vorhandenen saturation- oder lightness-Werte nicht geändert.