Na tej stronie dowiesz się, jak kontrolować te aspekty znaczników zaawansowanych:
- Ustawianie zachowania w przypadku kolizji znacznika
- Ustawianie wysokości znacznika
- Sterowanie widocznością znacznika na podstawie poziomu powiększenia mapy
Ustawianie zachowania w przypadku kolizji znacznika
Zachowanie w przypadku kolizji określa sposób wyświetlania znacznika, gdy koliduje (nakłada się) z innym znacznikiem. Zachowanie w przypadku kolizji jest obsługiwane tylko na mapach wektorowych.
Aby określić zachowanie w przypadku kolizji, ustaw wartość AdvancedMarkerElement.collisionBehavior
na jeden z tych parametrów:
REQUIRED
: (wartość domyślna) zawsze wyświetlaj znacznik niezależnie od kolizji.OPTIONAL_AND_HIDES_LOWER_PRIORITY
Wyświetlaj znacznik tylko wtedy, gdy nie zachodzi na inne znaczniki. Jeśli 2 takie znaczniki nakładają się na siebie, wyświetla się ten z wyższymzIndex
. Jeśli mają ten sam atrybutyzIndex
, wyświetlana jest pozycja z niższym pionowym położeniem ekranu.REQUIRED_AND_HIDES_OPTIONAL
zawsze wyświetlać znacznik bez względu na kolizje i ukrywać dowolne znaczniki lub etykietyOPTIONAL_AND_HIDES_LOWER_PRIORITY
, które nakładają się na znacznik.
Przykład poniżej pokazuje ustawienie zachowania w przypadku kolizji znacznika:
TypeScript
const advancedMarker = new AdvancedMarkerElement({ position: new google.maps.LatLng({ lat, lng }), map, collisionBehavior: collisionBehavior, });
JavaScript
const advancedMarker = new AdvancedMarkerElement({ position: new google.maps.LatLng({ lat, lng }), map, collisionBehavior: collisionBehavior, });
Ustawianie wysokości znacznika
Na mapach wektorowych możesz ustawić wysokość, na której ma się pojawiać znacznik. Jest to przydatne, aby wskaźniki wyświetlały się prawidłowo w związku z treścią mapy 3D. Aby ustawić wysokość znacznika, jako wartość opcji MarkerView.position
podaj LatLngAltitude
:
TypeScript
const pin = new PinElement({ background: '#4b2e83', borderColor: '#b7a57a', glyphColor: '#b7a57a', scale: 2.0, }); const markerView = new AdvancedMarkerElement({ map, content: pin.element, // Set altitude to 20 meters above the ground. position: { lat: 47.65170843460547, lng: -122.30754, altitude: 20 } as google.maps.LatLngAltitudeLiteral, });
JavaScript
const pin = new PinElement({ background: "#4b2e83", borderColor: "#b7a57a", glyphColor: "#b7a57a", scale: 2.0, }); const markerView = new AdvancedMarkerElement({ map, content: pin.element, // Set altitude to 20 meters above the ground. position: { lat: 47.65170843460547, lng: -122.30754, altitude: 20 }, });
Sterowanie widocznością znacznika na podstawie poziomu powiększenia mapy
Obserwuj, jak zmienia się widoczność znaczników (zacznij od oddalenia):
Aby kontrolować widoczność znacznika zaawansowanego, utwórz listenera zoom_changed
i dodaj funkcję warunkową, która ustawia AdvancedMarkerElement.map
na null
, jeśli poziom powiększenia przekracza określony poziom, jak w tym przykładzie:
TypeScript
map.addListener('zoom_changed', () => { const zoom = map.getZoom(); if (zoom) { // Only show each marker above a certain zoom level. marker01.map = zoom > 14 ? map : null; marker02.map = zoom > 15 ? map : null; marker03.map = zoom > 16 ? map : null; marker04.map = zoom > 17 ? map : null; } });
JavaScript
map.addListener("zoom_changed", () => { const zoom = map.getZoom(); if (zoom) { // Only show each marker above a certain zoom level. marker01.map = zoom > 14 ? map : null; marker02.map = zoom > 15 ? map : null; marker03.map = zoom > 16 ? map : null; marker04.map = zoom > 17 ? map : null; } });
Dalsze kroki
Ustawianie znaczników w taki sposób, aby można je było kliknąć i aby były dostępne