Siga estas etapas para configurar o estilo baseado em dados para limites.
Ativar o novo renderizador de mapas
Um renderizador de mapa atualizado está disponível a partir da versão 18.0.0 do SDK do Maps para Android. Ele traz muitas melhorias, incluindo o suporte à Estilização de mapas baseada na nuvem.
Com o lançamento da versão 18.2.0 do SDK do Maps para Android, o Google mudou do renderizador de mapas padrão legado para o atualizado. Assim, o renderizador atualizado agora é usado por padrão para criar ou recriar um app.
Criar um ID de mapa
Para criar um novo ID de mapa, siga as etapas em Criar um ID de mapa. Defina o tipo de mapa como Android.
Criar um estilo de mapa
Para criar um estilo de mapa, siga as instruções em Gerenciar estilos de mapa. Crie um estilo e associe ao ID do mapa que acabou de criar.
Selecione as camadas de elementos no novo estilo de mapa
No Google API Console, você pode selecionar quais camadas de elementos serão exibidas no novo estilo de mapa. A camada de elementos determina quais tipos de limites aparecem no mapa (por exemplo, localidades, estados etc.).
- No Console de APIs do Google, acesse a página Estilos de mapa.
- Selecione um projeto, se solicitado.
- Selecione um estilo de mapa.
- Clique no menu suspenso Camadas de elementos para adicionar ou remover camadas.
- Clique em Salvar para disponibilizar as mudanças nos mapas.
Atualizar o código de inicialização do seu mapa
Nesta etapa, você vai precisar do ID de mapa que acabou de criar. Ele está disponível na página Gerenciamento de mapas.
Para adicionar o ID do mapa ao código de inicialização, consulte Adicionar o ID do mapa ao seu app.
Acessar uma camada de elementos de um mapa
Você usa um objeto FeatureLayer
para representar cada camada de elementos de um mapa, como um código postal ou
uma camada de elementos de localidade. Para ter acesso a um objeto de camada de elemento, chame
GoogleMap.getFeatureLayer()
quando o mapa for inicializado:
Java
private FeatureLayer postalCodeLayer;
@Override public void onMapReady(GoogleMap map) { // Get the POSTAL_CODE feature layer. postalCodeLayer = map.getFeatureLayer(new FeatureLayerOptions.Builder() .featureType(FeatureType.POSTAL_CODE) .build()); ... }
Kotlin
private var postalCodeLayer: FeatureLayer? = null
override fun onMapReady(googleMap: GoogleMap) { // Get the POSTAL_CODE feature layer. postalCodeLayer = googleMap.getFeatureLayer(new FeatureLayerOptions.Builder() .featureType(FeatureType.POSTAL_CODE) .build()) ... }
Transmita um objeto FeatureLayerOptions
para getFeatureLayer()
para especificar o tipo da camada de elementos. Neste
exemplo, você quer acessar a camada POSTAL_CODE
. Crie um objeto
FeatureLayer
diferente para cada camada que você quer estilizar.
Depois de ter o objeto FeatureLayer
, você pode aplicar estilos aos polígonos de limite no elemento.
Verificar os recursos do mapa (obrigatório)
O estilo baseado em dados para limites exige um ID do mapa. Se o ID do mapa estiver ausente ou se um ID inválido for transmitido, o estilo baseado em dados para limites não poderá ser carregado. Como uma
etapa de solução de problemas, use
MapCapabilities
para verificar se o estilo orientado a dados para limites é aceito.
Kotlin
val capabilities: MapCapabilities = googleMap.getMapCapabilities() System.out.println("Data-driven Styling is available: " + capabilities.isDataDrivenStylingAvailable())
Java
MapCapabilities capabilities = googleMap.getMapCapabilities(); System.out.println("Data-driven Styling is available: " + capabilities.isDataDrivenStylingAvailable());