Gestione di indicatori, etichette e collisioni dei PDI

Questa pagina mostra come gestire le collisioni tra gli indicatori che aggiungi <0A>alla mappa e le etichette predefinite, come punti di interesse (PDI) o nomi <0A>delle strade.

Prima di iniziare

Per gestire le collisioni di indicatori ed etichette, devi utilizzare un ID mappa.

Se utilizzi un'immagine bitmap di una mappa in modalità Lite, non puoi gestire le collisioni di indicatori ed etichette.

Specifica delle priorità dei marcatori

Utilizza Marker.Proprietà CollisionBehavior per specificare la priorità di un indicatore.

Usa uno dei seguenti valori:

  • REQUIRED: valore predefinito. Richiede la visualizzazione di un indicatore che si sovrappone ad altri indicatori, etichette e PDI.
  • OPTIONAL_AND_HIDES_LOWER_PRIORITY - Indica che l'indicatore potrebbe essere sostituito o sovrapposto a un indicatore obbligatorio oppure sostituito da un indicatore con priorità più alta.OPTIONAL_AND_HIDES_LOWER_PRIORITY Utilizza zIndex per determinare la priorità relativa tra i marcatori OPTIONAL_AND_HIDES_LOWER_PRIORITY. Un valore di zIndex più alto indica una priorità più elevata.
  • REQUIRED_AND_HIDES_OPTIONAL - Richiede la visualizzazione di un indicatore nascondendo eventuali indicatori, etichette o PDI OPTIONAL_AND_HIDES_LOWER_PRIORITY che si sovrappongono all'indicatore. Il marcatore potrebbe sovrapporsi ad altri marcatori obbligatori.

Il seguente esempio di codice mostra l'impostazione di CollisionBehavior per un nuovo indicatore:

Kotlin

// Collision behavior can only be changed in the AdvancedMarkerOptions object.
// Changes to collision behavior after a marker has been created are not possible
val collisionBehavior: Int = CollisionBehavior.REQUIRED_AND_HIDES_OPTIONAL
val advancedMarkerOptions: AdvancedMarkerOptions = AdvancedMarkerOptions()
    .position(LatLng(10.0, 10.0))
    .collisionBehavior(collisionBehavior)

val marker: Marker = map.addMarker(advancedMarkerOptions) ?: error("Failed to add marker")

Java

// Collision behavior can only be changed in the AdvancedMarkerOptions object.
// Changes to collision behavior after a marker has been created are not possible
int collisionBehavior = AdvancedMarkerOptions.CollisionBehavior.REQUIRED_AND_HIDES_OPTIONAL;
AdvancedMarkerOptions options = new AdvancedMarkerOptions()
        .position(new LatLng(10.0, 10.0))
        .collisionBehavior(collisionBehavior);

Marker marker = map.addMarker(options);