Personalize a apresentação do mapa padrão do Google aplicando seus próprios estilos ao usar a API Maps Static. É possível mudar a exibição visual de elementos como vias, parques, áreas construídas e outros pontos de interesse. Mude a cor ou o estilo para enfatizar um conteúdo específico, complemente o conteúdo ao redor na página ou até mesmo oculte recursos completamente.
Exemplos
O exemplo a seguir mostra um mapa de Brooklyn, nos EUA, com estilo para colorir as vias locais em verde-claro e as áreas residenciais em preto. Ele também inverte a luminosidade dos rótulos para que eles se destaquem melhor em um fundo escuro. Observe que esse exemplo funcional usa codificação de URL:
https://maps.googleapis.com/maps/api/staticmap?size=512x512&zoom=15¢er=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
O exemplo a seguir usa operações de estilo e simplificações para aproximar a aparência de um atlas rodoviário dos EUA:
https://maps.googleapis.com/maps/api/staticmap?size=512x512&zoom=12¢er=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
Sintaxe de estilo
Para criar um mapa personalizado, inclua um ou mais parâmetros style
no URL da solicitação.
Cada declaração style
pode conter os seguintes argumentos,
separados por caracteres de pipe ("|
"):
feature
(opcional) indica os recursos que vão ser selecionados para essa modificação de estilo. Os recursos incluem elementos no mapa, como vias, parques ou outros pontos de interesse. Se nenhum argumentofeature
estiver presente, o estilo especificado será aplicado a todos os elementos.element
(opcional) indica os elementos do recurso especificado a serem selecionados para essa modificação de estilo. Os elementos são características de um elemento, como geometria ou rótulos. Se nenhum argumentoelement
estiver presente, o estilo será aplicado a todos os elementos do elemento especificado.- Um conjunto de regras de estilo (obrigatório) a serem aplicadas aos elementos e recursos especificados. A API aplica as regras na ordem em que
aparecem na declaração
style
. É possível incluir qualquer número de regras, dentro das restrições normais de comprimento do URL da API Maps Static.
style=feature:myFeatureArgument|element:myElementArgument|myRule1:myRule1Argument|myRule2:myRule2Argument
Recursos
A declaração style
a seguir colore todas as vias no mapa:
style=feature:road|color:0xffffff
Estas são algumas seleções de recursos comuns:
feature:all
(padrão) seleciona todos os elementos do mapa.feature:road
seleciona todas as vias no mapa.feature:road.local
seleciona todas as vias locais.
Os recursos ou os tipos de recurso são características geográficas do mapa, como vias, parques, corpos hídricos, empresas e outros.
Eles formam uma árvore de categorias, com all
como raiz. Se você não especificar um recurso, todos eles serão selecionados.
Definir um recurso como all
tem o mesmo resultado.
Alguns recursos contêm recursos secundários que você especifica usando um ponto. Por exemplo, landscape.natural
ou road.local
. Se você definir apenas o recurso pai, como road
, os estilos estabelecidos para o pai vão ser aplicados a todos os filhos, como road.local
e road.highway
.
Os recursos primários podem conter elementos não incluídos em todos os secundários.
Os seguintes recursos estão disponíveis:
all
(padrão) seleciona todos os recursos.administrative
seleciona todas as áreas político-administrativas. A aplicação de estilo afeta somente as etiquetas das áreas político-administrativas, e não das fronteiras ou de preenchimentos geográficos.administrative.country
seleciona países.administrative.land_parcel
seleciona lotes.administrative.locality
seleciona localidades.administrative.neighborhood
seleciona bairros.administrative.province
seleciona províncias.
landscape
seleciona todas as paisagens.landscape.man_made
seleciona recursos criados pelo homem, como edifícios e outras estruturas.landscape.natural
seleciona atributos naturais, como montanhas, rios, desertos e geleiras.landscape.natural.landcover
seleciona características da cobertura do solo, o material físico que cobre a superfície terrestre, como florestas, pastagens, pântanos e terra virgem.landscape.natural.terrain
seleciona características do terreno de uma superfície terrestre, como elevação, inclinação e orientação.
poi
seleciona todos os pontos de interesse.poi.attraction
seleciona atrações turísticas.poi.business
seleciona empresas.poi.government
seleciona edifícios públicos.poi.medical
seleciona serviços de emergência, incluindo hospitais, farmácias, delegacias, hospitais e outros.poi.park
seleciona parques.poi.place_of_worship
seleciona locais de cultos, incluindo igrejas, templos, mesquitas e outros.poi.school
seleciona escolas.poi.sports_complex
seleciona complexos esportivos.
road
seleciona todas as vias.road.arterial
seleciona vias arteriais.road.highway
seleciona rodovias.road.highway.controlled_access
seleciona rodovias com acesso controlado.road.local
seleciona vias locais.
transit
seleciona todas as estações e linhas de transporte público.transit.line
seleciona linhas de transporte público.transit.station
seleciona todas as estações de transporte público.transit.station.airport
seleciona aeroportos.transit.station.bus
seleciona pontos de ônibus.transit.station.rail
seleciona estações de trem.
water
seleciona corpos hídricos.
Elementos
A declaração style
a seguir colore os rótulos de todas as vias locais:
style=feature:road.local|element:labels|color:0xffffff
Elementos são subdivisões de um recurso. Uma via, por exemplo, é composta pela linha gráfica (a geometria) no mapa, e pelo texto que indica o nome dela (uma etiqueta).
Os elementos a seguir estão disponíveis, mas um recurso específico pode oferecer suporte a todos, alguns ou nenhum dos elementos:
As cores do texto fill
e stroke
do rótulo mudam com base no nível de zoom.
Para tornar a experiência consistente em todos os níveis de zoom, sempre defina fill
e stroke
.
all
(padrão) seleciona todos os elementos do elemento especificado.-
geometry
seleciona todos os elementos geométricos do elemento especificado.geometry.fill
seleciona apenas o preenchimento da geometria do elemento.geometry.stroke
seleciona apenas o traço da geometria do elemento.
-
labels
seleciona os rótulos de texto associados ao recurso especificado.labels.icon
seleciona apenas o ícone mostrado na etiqueta do recurso.labels.text
seleciona apenas o texto da etiqueta.-
labels.text.fill
seleciona apenas o preenchimento da etiqueta. Normalmente, o preenchimento de uma etiqueta é renderizado como um contorno colorido em volta do texto. labels.text.stroke
seleciona apenas o traço do texto da etiqueta.
Regras de estilo
As regras de estilo são opções de formatação aplicadas aos elementos e recursos especificados em cada declaração style
.
A declaração style
a seguir aplica duas regras de estilo às
vias no mapa. A primeira regra aplica uma cor às vias. A segunda regra simplifica a exibição das vias, para que elas tenham linhas mais finas sem contornos:
style=feature:road|color:0xffffff|visibility:simplified
Cada declaração style
precisa conter uma ou mais operações
separadas usando o caractere de barra vertical ("|
"). Cada operação especifica
o valor do argumento usando o caractere dois pontos (":
"). Todas
as operações são aplicadas à seleção na ordem em que são especificadas.
As seguintes opções de estilo têm suporte:
hue
(uma string hexadecimal RGB do formato#RRGGBB
) indica a cor básica.Essa opção define o matiz ao mesmo tempo que mantém a saturação e o brilho especificados no estilo padrão do Google (ou outras opções de estilo que você definir no mapa). A cor resultante está associada ao estilo do mapa de base. Se o Google fizer alguma alteração no estilo de base do mapa, os recursos do seu mapa serão afetados e estilizados com
hue
. Se você puder, use o stylercolor
absoluto.lightness
(um valor de ponto flutuante entre-100
e100
) indica a variação percentual no brilho do elemento. Valores negativos reduzem o brilho (-100 especifica a cor preta), e valores positivos aumentam o brilho (+100 especifica a cor branca).Essa opção define o brilho e mantém a saturação e o matiz especificados no estilo padrão do Google (ou outras opções de estilo que você definir no mapa). A cor resultante está associada ao estilo do mapa de base. Se o Google fizer alguma alteração no estilo do mapa de base, os recursos do seu mapa serão afetados e estilizados com
lightness
. Se possível, use o stylercolor
absoluto.saturation
(um valor de ponto flutuante entre-100
e100
) indica a variação percentual na intensidade da cor básica a ser aplicada ao elemento.Essa opção define a saturação e mantém o matiz e o brilho especificados no estilo padrão do Google (ou outras opções de estilo que você definir no mapa). A cor resultante está associada ao estilo do mapa de base. Se o Google fizer alguma alteração no estilo do mapa de base, os recursos do seu mapa serão afetados e estilizados com
saturation
. Se possível, use o stylercolor
absoluto.gamma
(um valor de ponto flutuante entre0.01
e10.0
, em que1.0
não faz correções) indica a quantidade de correção de gamma a ser aplicada ao elemento. As correções de gamma modificam o brilho das cores de maneira não linear, mas não afetam os valores de branco e preto. Esse recurso é geralmente usado para modificar o contraste de vários elementos. Por exemplo, é possível alterar a gamma para aumentar ou diminuir o contraste entre as margens e o interior dos elementos.Essa opção ajusta o brilho relacionado ao estilo padrão do Google usando uma curva de gamma. Se o Google fizer alguma alteração no estilo do mapa de base, os recursos do seu mapa serão afetados e estilizados com
gamma
. Se possível, use o stylercolor
absoluto.invert_lightness
(setrue
) inverte o brilho atual. Isso é útil, por exemplo, para alternar rapidamente a um mapa mais escuro com texto em branco.Essa opção simplesmente inverte o estilo padrão do Google. Se o Google fizer alguma alteração no estilo do mapa de base, os recursos do seu mapa serão afetados e estilizados com
invert_lightness
. Se possível, use o stylercolor
absoluto.visibility
(on
,off
ousimplified
) indica se o elemento aparece no mapa e como ele é exibido. Uma visibilidadesimplified
remove alguns recursos de estilo dos elementos afetados. As vias, por exemplo, são simplificadas para linhas mais finas sem contornos, enquanto os parques perdem o texto da etiqueta, mas mantêm o ícone da etiqueta.color
(uma string hexadecimal RGB do formato#RRGGBB
) define a cor do recurso.weight
(um valor inteiro, maior ou igual a zero) define a espessura do recurso, em pixels. Um valor de espessura alta pode resultar em truncamento perto das margens da borda.
As regras de estilo são aplicadas na ordem em que são especificadas. Não combine várias operações em uma única operação de estilo. Em vez disso, defina cada operação como uma entrada separada na matriz de estilo.
A ordem é importante, porque algumas operações não são comutativas. Os recursos e/ou elementos modificados normalmente já tinham um estilo. A operação atua nesses estilos existentes.
O modelo matiz, saturação e brilho
Os mapas estilizados usam o modelo matiz, saturação e brilho (HSL) para denotar cores nas operações do styler. Hue indica a cor básica, saturation indica a intensidade dessa cor, lightness indica o valor referente à quantidade de branco ou preto na cor integrante.
A correção de gamma modifica o brilho no espaço da cor, geralmente aumentando ou reduzindo o contraste. Além disso, o modelo HSL define a cor em um espaço de coordenadas, em que hue
indica a orientação em um disco de cores, enquanto a saturação e o brilho mostram as amplitudes ao longo de diferentes eixos. Os matizes são medidos dentro de um espaço de cor RGB, que é similar à maioria dos espaços de cor RGB, mas sem os tons de preto e branco.
Embora hue
assuma um valor de cor hexadecimal HTML, ele só usa esse valor para determinar a cor básica, ou seja, a orientação no disco de cores. Ele não define a saturação ou o brilho, que são indicados separadamente como mudanças percentuais.
Por exemplo, você pode definir o matiz de verde puro como hue:0x00ff00
ou hue:0x000100
. Os dois são idênticos. Ambos os valores apontam para o verde puro no modelo de cor HSL.
Uma roda de cores RGB
Os valores em RGB de hue
, que consiste em frações ideais de vermelho, verde e azul, não indicam um matiz, porque nenhum desses valores mostra uma orientação no espaço de coordenadas HSL. Alguns exemplos são "#000000" (preto), "#FFFFFF" (branco), e todos os tons puros de cinza. Para indicar preto, branco ou cinza, remova todos os valores de saturation
(defina como -100
) e ajuste lightness
.
Além disso, ao modificar os recursos atuais que já têm um esquema de cores, alterar um valor como hue
não muda a saturation
ou o lightness
atuais.