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ści CollisionBehavior
, aby określić priorytet znacznika.
Użyj jednej z tych wartości:
REQUIRED
– wartość domyślna. Wymaga wyświetlenia znacznika, który nakłada się na inne znaczniki, etykiety i ciekawe miejsca.OPTIONAL_AND_HIDES_LOWER_PRIORITY
– wskazuje, że znacznik może zostać zastąpiony lub nałożony na znacznik wymagany albo zastąpiony przez znacznikOPTIONAL_AND_HIDES_LOWER_PRIORITY
o wyższym priorytecie. UżyjzIndex
, aby określić względną ważność 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 wszelkich znaczników, etykiet lub ciekawych miejscOPTIONAL_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);