Zarządzanie znacznikami, etykietami i konfliktami z miejscami

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

Zanim zaczniesz

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

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

Określanie priorytetów znaczników

Użyj Marker.CollisionBehavior, aby określić priorytet znacznika.

Użyj jednej z tych wartości:

  • REQUIRED – domyślny. Wymaga wyświetlania znacznika, który nakłada się na inne znaczniki, etykiety i ciekawe miejsca.
  • OPTIONAL_AND_HIDES_LOWER_PRIORITY – oznacza, że marker może zostać zastąpiony lub nałożony na wymagany marker albo zastąpiony przez marker o wyższym priorytecie.OPTIONAL_AND_HIDES_LOWER_PRIORITY Używaj symbolu zIndex, aby określić względny priorytet 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 wszystkich znaczników, etykiet lub ciekawych miejsc, które się z nim pokrywają.OPTIONAL_AND_HIDES_LOWER_PRIORITY Może on pokrywać się z innymi wymaganymi znacznikami.

Poniższy przykład kodu pokazuje ustawienie CollisionBehavior dla nowego markera:

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