Mapas estilizados

Personalize a apresentação do mapa do Google padrão aplicando seus próprios estilos ao usar a API Maps Static. Você pode alterar a exibição visual de recursos, como vias, parques, áreas construídas e outros pontos de interesse. Altere a cor ou o estilo para destacar determinado conteúdo, complementar o conteúdo ao redor na página ou até mesmo ocultar completamente os recursos.

Exemplos

O exemplo a seguir exibe um mapa do Brooklyn, EUA, com estilização para colorir as vias locais brilhantes em verde e as áreas residenciais em preto. Ele também inverte o brilho dos rótulos para que 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&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

Mapa estilizado do Brooklyn

O exemplo a seguir usa operações e simplificações de estilo para aproximar a aparência de um atlas de vias dos EUA:

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

Estilo de mapa do Atlas da US Road

Sintaxe de estilo

Para criar um mapa estilizado personalizado, inclua um ou mais parâmetros style no URL da solicitação.

Cada declaração style pode conter os seguintes argumentos, separados por barra vertical ("|"):

  • feature (opcional) indica os recursos a serem selecionados para essa modificação de estilo. Os recursos incluem elementos no mapa, como vias, parques ou outros pontos de interesse. Se não houver nenhum argumento feature, o estilo especificado será aplicado a todos os recursos.
  • 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 recurso, como geometria ou rótulos. Se nenhum argumento element estiver presente, o estilo se aplicará a todos os elementos do recurso especificado.
  • Um conjunto de regras de estilo (obrigatório) a serem aplicadas aos recursos e elementos especificados. A API aplica as regras na ordem em que aparecem na declaração style. Você pode incluir qualquer número de regras dentro das restrições normais de tamanho de URL da API Maps Static.
style=feature:myFeatureArgument|element:myElementArgument|myRule1:myRule1Argument|myRule2:myRule2Argument

Recursos

A seguinte declaração style colore todas as vias do mapa:

style=feature:road|color:0xffffff

Estas são algumas seleções de recursos comuns:

  • feature:all (padrão) seleciona todos os recursos do mapa.
  • feature:road seleciona todas as vias do 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 primário, como road, os estilos estabelecidos para o primário 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:

  • all (padrão) seleciona todos os elementos do recurso especificado.
  • geometry seleciona todos os elementos geométricos do recurso especificado.
    • geometry.fill seleciona apenas o preenchimento da geometria do recurso.
    • geometry.stroke seleciona apenas o traço da geometria do recurso.
  • labels seleciona as etiquetas textuais associadas ao recurso especificado.
    • labels.icon seleciona apenas o ícone exibido 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 que rodeia o texto dela.
    • 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 recursos e elementos 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, portanto, elas têm linhas mais finas sem contornos:

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

Cada declaração style precisa conter uma ou mais operações separadas do caractere de barra vertical ("|"). Cada operação especifica o valor de argumento usando o caractere de dois-pontos (":"), e todas as operações se aplicam à seleção na ordem em que você as especifica.

As seguintes opções de estilo são compatíveis:

  • 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 tem relação com o estilo do mapa básico. Se o Google fizer alguma alteração no estilo do mapa básico, os recursos do seu mapa serão afetados e estilizados com hue. Se você puder, use o estilizador color absoluto.

  • lightness (um valor de ponto flutuante entre -100 e 100) 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 ao mesmo tempo que 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 tem relação com o estilo do mapa básico. Se o Google fizer alguma alteração no estilo do mapa básico, os recursos do seu mapa serão afetados e estilizados com lightness. Se você puder, use o estilizador color absoluto.

  • saturation (um valor de ponto flutuante entre -100 e 100) indica a variação percentual na intensidade da cor básica a ser aplicada ao elemento.

    Essa opção define a saturação ao mesmo tempo que 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 tem relação com o estilo do mapa básico. Se o Google fizer alguma alteração no estilo do mapa básico, os recursos do seu mapa serão afetados e estilizados com saturation. Se você puder, use o estilizador color absoluto.

  • gamma (um valor de ponto flutuante entre 0.01 e 10.0, em que 1.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 Google usando uma curva de gamma. Se o Google fizer alguma alteração no estilo do mapa básico, os recursos do seu mapa serão afetados e estilizados com gamma. Se você puder, use o estilizador color absoluto.

  • invert_lightness (se true) 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 básico, os recursos do seu mapa serão afetados e estilizados com invert_lightness. Se você puder, use o estilizador color absoluto.

  • visibility (on, off ou simplified) indica se o elemento aparece no mapa e como ele é exibido. Uma visibilidade simplified 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 se aplicam na ordem em que forem 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 com operações de estilo normalmente já têm estilos. Caso haja estilos, as operações os modificam.

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 estilizador. 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 a luminosidade 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.

Modelo matiz, saturação e brilho

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, não definindo a saturação ou o brilho, que são indicados em separado 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.