Limitare l'inquadratura e i limiti della videocamera

Seleziona la piattaforma: Android iOS JavaScript

Potrebbe essere utile controllare la panoramica della videocamera, l'altitudine massima o creare limiti di latitudine e longitudine che limitano il movimento di un utente in una determinata mappa. Puoi farlo utilizzando le limitazioni della videocamera.

L'esempio seguente mostra una mappa con i confini della posizione impostati per limitare il movimento della videocamera:

Limita i limiti della mappa

Puoi limitare i confini geografici della videocamera impostando l'opzione bounds.

Il seguente esempio di codice mostra come limitare i limiti della mappa:

TypeScript

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

    const map = new Map3DElement({
        center: { lat: -36.86, lng: 174.76, altitude: 10000 },
        tilt: 67.5,
        mode: 'HYBRID',
        bounds: { south: -48.3, west: 163.56, north: -32.86, east: -180 },
        gestureHandling: 'COOPERATIVE',
    });

    document.body.append(map);
}

void init();

JavaScript

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

    const map = new Map3DElement({
        center: { lat: -36.86, lng: 174.76, altitude: 10000 },
        tilt: 67.5,
        mode: 'HYBRID',
        bounds: { south: -48.3, west: 163.56, north: -32.86, east: -180 },
        gestureHandling: 'COOPERATIVE',
    });

    document.body.append(map);
}

void init();

CSS

/* 
 * Always set the map height explicitly to define the size of the div element
 * that contains the map. 
 */
html,
map {
    height: 100%;
}
body {
    height: 100%;
    margin: 0;
    padding: 0;
}

HTML

<html>
    <head>
        <title>Map</title>

        <link rel="stylesheet" type="text/css" href="./style.css" />
        <script type="module" src="./index.js"></script>
        <script>
            // prettier-ignore
            (g=>{var h,a,k,p="The Google Maps JavaScript API",c="google",l="importLibrary",q="__ib__",m=document,b=window;b=b[c]||(b[c]={});var d=b.maps||(b.maps={}),r=new Set,e=new URLSearchParams,u=()=>h||(h=new Promise(async(f,n)=>{await (a=m.createElement("script"));e.set("libraries",[...r]+"");for(k in g)e.set(k.replace(/[A-Z]/g,t=>"_"+t[0].toLowerCase()),g[k]);e.set("callback",c+".maps."+q);a.src=`https://maps.${c}apis.com/maps/api/js?`+e;d[q]=f;a.onerror=()=>h=n(Error(p+" could not load."));a.nonce=m.querySelector("script[nonce]")?.nonce||"";m.head.append(a)}));d[l]?console.warn(p+" only loads once. Ignoring:",g):d[l]=(f,...n)=>r.add(f)&&u().then(()=>d[l](f,...n))})({
                key: "AIzaSyA6myHzS10YXdcazAFalmXvDkrYCp5cLc8"
            });
        </script>
    </head>
    <body>
        <div id="map"></div>
    </body>
</html>

Prova campione

Limitare la videocamera

Puoi limitare il movimento della videocamera impostando una delle seguenti opzioni:

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

Il seguente esempio di codice mostra come limitare la videocamera:

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();

Limitare i limiti della mappa e della videocamera

Puoi limitare contemporaneamente i limiti della mappa e della videocamera. Il seguente esempio di codice mostra come limitare i confini della mappa e della videocamera:

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();

Gestione dei gesti di controllo

Quando un utente scorre una pagina contenente una mappa, l'azione di scorrimento può causare inavvertitamente lo zoom della mappa. Puoi controllare questo comportamento impostando l'opzione della mappa gestureHandling.

gestureHandling: cooperative

La gestione dei gesti "cooperativa" consente all'utente di scorrere la pagina senza influire sullo zoom o sulla panoramica della mappa. Per ingrandire, gli utenti possono utilizzare i controlli, i gesti con due dita (per i dispositivi touchscreen) o tenendo premuto CMD/CTRL durante lo scorrimento.

Il seguente codice mostra l'impostazione della gestione dei gesti su "cooperativa":

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

gestureHandling: greedy

La gestione dei gesti "greedy" reagisce a tutti gli eventi di scorrimento e ai gesti tattili.

gestureHandling: auto

La gestione dei gesti "Automatica" modifica il comportamento della mappa a seconda che sia contenuta o meno in un <iframe> e se la pagina è scorrevole.

  • Se la mappa si trova all'interno di un <iframe>, la gestione dei gesti sarà "cooperativa".
  • Se la mappa non si trova all'interno di un <iframe>, la gestione dei gesti sarà "greedy".