Restreindre la vue et les limites de la caméra

Sélectionnez une plate-forme : Android iOS JavaScript

Vous pouvez contrôler le panoramique, l'altitude maximale de la caméra ou créer des limites de latitude et de longitude pour restreindre les déplacements d'un utilisateur sur une carte donnée. Pour ce faire, utilisez les restrictions de la caméra.

L'exemple suivant montre une carte avec des limites d'emplacement définies pour limiter les mouvements de la caméra :

Restreindre les limites de la carte

Vous pouvez restreindre les limites géographiques de la caméra en définissant l'option bounds.

L'exemple de code suivant montre comment restreindre les limites de la carte :

async function init() {
  const { Map3DElement, MapMode } = await google.maps.importLibrary("maps3d");

  const map = new Map3DElement({
    center: { lat: 37.7704, lng: -122.3985, altitude: 500 },
    tilt: 67.5,
    mode: MapMode.HYBRID,
    bounds: {south: 37, west: -123, north: 38, east: -121}
  });

init();
}

Restreindre la caméra

Vous pouvez restreindre les mouvements de la caméra en définissant l'une des options suivantes :

  • maxAltitude
  • minAltitude
  • maxHeading
  • minHeading
  • maxTilt
  • minTilt

L'exemple de code suivant montre comment restreindre la caméra :

async function init() {
  const { Map3DElement, MapMode } = await google.maps.importLibrary("maps3d");

  const map = new Map3DElement({
    center: { lat: 37.7704, lng: -122.3985, altitude: 500 },
    tilt: 67.5,
    mode: MapMode.HYBRID,
    minAltitude: 1,
    maxAltitude: 1000,
    minTilt: 35,
    maxTilt: 55
  });

 document.body.append(map);
}

init();

Restreindre les limites de la carte et de la caméra

Vous pouvez restreindre simultanément les limites de la carte et de la caméra. L'exemple de code suivant montre comment restreindre les limites de la carte et de la caméra :

async function init() {
  const { Map3DElement, MapMode } = await google.maps.importLibrary("maps3d");

  const map = new Map3DElement({
    center: { lat: 37.7704, lng: -122.3985, altitude: 500 },
    tilt: 67.5,
    mode: MapMode.HYBRID,
    minAltitude: 1,
    maxAltitude: 1000,
    minTilt: 35,
    maxTilt: 55,
    bounds: {south: 37, west: -123, north: 38, east: -121}
  });

 document.body.append(map);
}

init();

Contrôler le traitement des gestes

Lorsque l'utilisateur fait défiler une page contenant une carte, il peut la zoomer par inadvertance. Vous pouvez contrôler ce comportement en définissant l'option de carte gestureHandling.

gestureHandling: cooperative

Le traitement des gestes "coopératif" permet à l'utilisateur de faire défiler la page sans affecter le zoom ni le panoramique de la carte. Pour effectuer un zoom, les utilisateurs peuvent utiliser les commandes, les gestes à deux doigts (pour les appareils à écran tactile) ou maintenir la touche CMD/CTRL enfoncée tout en faisant défiler la page.

Le code suivant montre comment définir le traitement des gestes sur "coopératif" :

new Map3DElement({
  center: { lat: 37.729901343702736, lng: -119.63788444355905, altitude: 1500 },
  tilt: 70,
  heading: 50,
  range: 4000,
  gestureHandling: 'COOPERATIVE',
});

gestureHandling: greedy

Le traitement des gestes "greedy" réagit à tous les événements de défilement et aux gestes tactiles.

gestureHandling: auto

Le traitement des gestes "auto" modifie le comportement de la carte selon qu'elle est contenue ou non dans un <iframe>, et selon que la page est défilable ou non.

  • Si la carte se trouve dans un <iframe>, le traitement des gestes sera "coopératif".
  • Si la carte ne se trouve pas dans un <iframe>, le traitement des gestes sera "greedy".