הגבלת השידור מהמצלמה והגבולות שלו

בחירת פלטפורמה: Android iOS JavaScript

יכול להיות שתרצו לשלוט בתנועת המצלמה, בגובה המקסימלי או ליצור גבולות של קווי רוחב וקווי אורך שיגבילו את התנועה של המשתמש במפה נתונה. אפשר לעשות זאת באמצעות הגבלות על המצלמה.

בדוגמה הבאה מוצגת מפה עם גבולות מיקום שהוגדרו כדי להגביל את התנועה של המצלמה:

הגבלת גבולות המפה

אפשר להגביל את הגבולות הגיאוגרפיים של המצלמה על ידי הגדרת האפשרות bounds.

בדוגמת הקוד הבאה מוצגות הגבלות על גבולות המפה:

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

הגבלת המצלמה

אתם יכולים להגביל את תנועת המצלמה על ידי הגדרת אחת מהאפשרויות הבאות:

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

בדוגמת הקוד הבאה אפשר לראות איך מגבילים את המצלמה:

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

הגבלת גבולות המפה והמצלמה

אפשר להגביל בו-זמנית את גבולות המפה והמצלמה. בדוגמת הקוד הבאה אפשר לראות איך מגבילים את הגבולות של המפה ושל המצלמה:

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

שליטה בטיפול בתנועות

כשמשתמש גולל דף שמכיל מפה, פעולת הגלילה עלולה לגרום למפה לשנות את מרחק התצוגה. אפשר לשלוט בהתנהגות הזו באמצעות ההגדרה gestureHandling map.

gestureHandling: cooperative

טיפול 'משותף' בתנועות מאפשר למשתמש לגלול בדף בלי להשפיע על שינוי מרחק התצוגה או על ההזזה של המפה. כדי להגדיל את התצוגה, המשתמשים יכולים להשתמש באמצעי הבקרה, במחוות של שתי אצבעות (במכשירי מסך מגע) או בלחיצה על CMD/CTRL בזמן הגלילה.

הקוד הבא מדגים איך מגדירים את הטיפול במחוות כ'שיתופי':

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

gestureHandling: greedy

טיפול בתנועות 'חמדני' מגיב לכל אירועי הגלילה ולתנועות המגע.

gestureHandling: auto

ההגדרה 'אוטומטי' לטיפול במחוות משנה את ההתנהגות של המפה בהתאם לשאלה אם המפה מוכלת ב-<iframe> או לא, ולשאלה אם אפשר לגלול בדף.

  • אם המפה נמצאת בתוך <iframe>, הטיפול במחוות יהיה 'שיתופי'.
  • אם המפה לא נמצאת בתוך <iframe>, הטיפול במחוות יהיה "חמדני".