Per iniziare

Seleziona la piattaforma: Android iOS JavaScript

Segui questi passaggi per configurare gli stili basati sui dati per i confini.

Attivare il nuovo visualizzatore delle mappe

È disponibile un renderer delle mappe di cui è stato eseguito l'upgrade a partire dalla versione 18.0.0 del Maps SDK for Android. Questo renderer apporta molti miglioramenti, tra cui il supporto per la Personalizzazione delle mappe basata su cloud, a Maps SDK for Android.

Con il rilascio della versione 18.2.0 di Maps SDK for Android, Google ha cambiato il renderer predefinito dal renderer precedente al renderer delle mappe aggiornato. Questa modifica significa che il renderer delle mappe aggiornato viene ora utilizzato per impostazione predefinita nella tua app quando crei una nuova app o ricrei un'app esistente.

Creare un ID mappa

Per creare un nuovo ID mappa, segui la procedura descritta in Creare un ID mappa. Assicurati di impostare il tipo di mappa su Android.

Crea un nuovo stile di mappa

Per creare un nuovo stile di mappa, segui le istruzioni in Gestire gli stili di mappa per creare lo stile e associare lo stile all'ID mappa appena creato.

Seleziona i livelli degli elementi nel nuovo stile della mappa

Nella console API di Google puoi selezionare i livelli degli elementi da visualizzare per il nuovo stile di mappa. Il livello degli elementi determina i tipi di confini visualizzati sulla mappa (ad esempio località, stati e così via).

  1. Nella console API di Google, vai alla pagina Stili di mappa.
  2. Seleziona un progetto, se richiesto.
  3. Seleziona uno stile di mappa.
  4. Fai clic sul menu a discesa Livelli degli elementi per aggiungere o rimuovere livelli.
  5. Fai clic su Salva per salvare le modifiche e renderle disponibili per le tue mappe.

Uno screenshot che mostra il menu a discesa.

Aggiorna il codice di inizializzazione della mappa

Questo passaggio richiede l'ID mappa appena creato. Puoi trovarlo nella pagina Gestione Maps.

Per aggiungere l'ID mappa al codice di inizializzazione, consulta Aggiungere l'ID mappa all'app.

Ottenere l'accesso a un livello di funzionalità di una mappa

Puoi utilizzare un oggetto FeatureLayer per rappresentare ogni livello di elementi di una mappa, ad esempio un livello di elementi Codice postale o Località. Per ottenere l'accesso a un oggetto del livello delle caratteristiche, chiama GoogleMap.getFeatureLayer() quando la mappa viene inizializzata:

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()) ... }

Passa un oggetto FeatureLayerOptions a getFeatureLayer() per specificare il tipo di livello di funzionalità. In questo esempio, vuoi accedere al livello POSTAL_CODE. Crea un oggetto FeatureLayer diverso per ogni livello a cui vuoi applicare uno stile.

Una volta ottenuto l'oggetto FeatureLayer, puoi applicare lo stile ai poligoni dei confini nella caratteristica.

Controlla le funzionalità della mappa (obbligatorio)

L'applicazione di stili basati sui dati per i confini richiede un ID mappa. Se l'ID mappa non è presente o se viene passato un ID mappa non valido, lo stile basato sui dati per i confini non può essere caricato. Come passaggio per la risoluzione dei problemi, puoi utilizzare MapCapabilities per verificare se lo stile basato sui dati per i confini è supportato.

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());