Zarządzanie znacznikami, etykietami i konfliktami z miejscami

Na tej stronie dowiesz się, jak zarządzać kolizjami między znacznikami dodanymi do mapy a etykietami domyślnymi, takimi jak punkty orientacyjne czy nazwy ulic.

Zanim zaczniesz

Aby zarządzać kolizjami znaczników i etykietek, musisz używać identyfikatora mapy.

Jeśli używasz mapy w postaci obrazu bitmapowego w wersji uproszczonej, nie możesz zarządzać kolizjami znaczników i etykietek.

Określanie priorytetów znaczników

Użyj biblioteki Marker.Właściwość CollisionBehavior, aby określić priorytet znacznika.

Użyj jednej z tych wartości:

  • REQUIRED – wartość domyślna. Wymaga wyświetlenia znacznika, który pokrywa się z innymi znacznikami, etykietami i ciekawymi miejscami.
  • OPTIONAL_AND_HIDES_LOWER_PRIORITY – wskazuje, że znacznik może zostać zastąpiony lub nałożony na wymagany znacznik albo zastąpiony przez znacznik OPTIONAL_AND_HIDES_LOWER_PRIORITY o wyższym priorytecie. Użyj zIndex, aby określić względną ważność między znacznikami OPTIONAL_AND_HIDES_LOWER_PRIORITY. Wyższa wartość zIndex oznacza wyższy priorytet.
  • REQUIRED_AND_HIDES_OPTIONAL – wymaga wyświetlania znacznika przy jednoczesnym ukrywaniu wszelkich znaczników, etykiet lub ciekawych miejsc OPTIONAL_AND_HIDES_LOWER_PRIORITY, które nakładają się na ten znacznik. Może on zachodzić na inne wymagane znaczniki.

Poniższy przykładowy kod pokazuje ustawienie CollisionBehavior dla nowego znacznika:

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