Na tej stronie dowiesz się, jak zarządzać kolizjami między dodanymi przez Ciebie znacznikami 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 symboluzIndex
, aby określić względny priorytet między znacznikamiOPTIONAL_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);