Sterowanie powiększeniem i przesuwaniem

Wybierz platformę: Android iOS JavaScript

Omówienie

Użycie mapy na stronie internetowej może wymagać określonych opcji kontrolowania sposobu, w jaki użytkownicy korzystają z mapy – powiększania i przesuwania. Te opcje, takie jak gestureHandling, minZoom, maxZoomrestriction, są zdefiniowane w interfejsie MapOptions.

Zachowanie domyślne

Poniższa mapa przedstawia domyślne zachowanie w przypadku interakcji z mapą z mapą utworzoną tylko ze zdefiniowanymi opcjami zoom i center.

Kod tej mapy znajduje się poniżej.

TypeScript

new google.maps.Map(document.getElementById("map")!, {
  zoom,
  center,
});

JavaScript

new google.maps.Map(document.getElementById("map"), {
  zoom,
  center,
});

Sterowanie obsługą gestów

Gdy użytkownik przewija stronę zawierającą mapę, może to przypadkowo spowodować powiększenie mapy. Tym działaniem można sterować za pomocą opcji mapy gestureHandling.

Obsługa gestów: cooperative

Poniższa mapa korzysta z opcji gestureHandling, która ma wartość cooperative, co umożliwia użytkownikowi normalne przewijanie strony bez powiększania czy przesuwania mapy. Użytkownicy mogą powiększać mapę, klikając elementy sterujące powiększeniem. Mogą też powiększać i przesuwać mapę za pomocą 2 palców na ekranie dotykowym.

Kod tej mapy znajduje się poniżej.

TypeScript

new google.maps.Map(document.getElementById("map")!, {
  zoom,
  center,
  gestureHandling: "cooperative",
});

JavaScript

new google.maps.Map(document.getElementById("map"), {
  zoom,
  center,
  gestureHandling: "cooperative",
});

Wyświetl próbkę

Obsługa gestów: auto

Mapa u góry strony bez opcji gestureHandling działa tak samo jak poprzednia mapa z ustawieniem gestureHandling na cooperative, ponieważ wszystkie mapy na tej stronie znajdują się w obiekcie <iframe>. Domyślna wartość gestureHandling auto przełącza się między greedy a cooperative w zależności od tego, czy mapa jest zawarta w <iframe>.

Mapa zawarta w <iframe> Zachowanie
tak cooperative
nie greedy

gestureHandling: greedy

Poniżej znajduje się mapa z ustawionym parametrem gestureHandling o wartości greedy. W przeciwieństwie do cooperative ta mapa reaguje na wszystkie gesty dotykowe i zdarzenia przewijania.

gestureHandling: none

Opcję gestureHandling można też ustawić na none, aby wyłączyć gesty na mapie.

Wyłączanie funkcji przesuwania i powiększania

Aby całkowicie wyłączyć możliwość przesuwania i powiększania mapy, musisz uwzględnić 2 opcje: gestureHandling i zoomControl.

TypeScript

new google.maps.Map(document.getElementById("map")!, {
  zoom,
  center,
  gestureHandling: "none",
  zoomControl: false,
});

JavaScript

new google.maps.Map(document.getElementById("map"), {
  zoom,
  center,
  gestureHandling: "none",
  zoomControl: false,
});

Mapa poniżej pokazuje połączenie gestureHandlingzoomControl w powyższym kodzie.

Ograniczanie granic i powiększenia mapy

Możesz na przykład zezwolić na gesty i sterowanie powiększaniem, ale ograniczyć mapę do określonych granic lub do minimalnego i maksymalnego powiększenia. W tym celu możesz ustawić opcje ograniczenia, minZoom i maxZoom. Poniżej znajdziesz kod i mapę, które pokazują te opcje.

TypeScript

new google.maps.Map(document.getElementById("map")!, {
  zoom,
  center,
  minZoom: zoom - 3,
  maxZoom: zoom + 3,
  restriction: {
    latLngBounds: {
      north: -10,
      south: -40,
      east: 160,
      west: 100,
    },
  },
});

JavaScript

new google.maps.Map(document.getElementById("map"), {
  zoom,
  center,
  minZoom: zoom - 3,
  maxZoom: zoom + 3,
  restriction: {
    latLngBounds: {
      north: -10,
      south: -40,
      east: 160,
      west: 100,
    },
  },
});