מודלים הם נכסים תלת-ממדיים שאפשר להוסיף לסצנה כדי לייצג אובייקטים. מפות בתלת-ממד בממשק API של JavaScript במפות Google תומכות בהכללה של מודלים בפורמט gLTF. אפשר לשנות את הגודל של המודלים האלה ולסובב אותם כדי להתאים אותם אישית.
המודלים צריכים לתמוך במאפייני הליבה של glTF PBR. אין תמיכה בתוספים או במאפייני תוספים.
הוספת מודל
הקונסטרוקטור
Model3DElement
מקבל קבוצה של Model3DElementOptions שמציינת את הקואורדינטות של המודל LatLng וקבוצה של פרמטרים לתמיכה במיקום המודל.
המודלים תומכים באפשרויות הבאות:
-
position: המיקום של המודל בפורמט של קואורדינטותLatLng. -
orientation: הסיבוב של מערכת הקואורדינטות של המודל. הסיבובים מתבצעים בסדר הבא: גלגול, הטיה ואז כיוון. -
scale: שינוי קנה המידה של המודל במרחב הקואורדינטות שלו. ערך ברירת המחדל הוא1. -
altitudeMode: איך לפרש את הגובה שמצוין ב-position. -
src: כתובת ה-URL של המודל.
בדוגמה הבאה אפשר לראות איך מוסיפים מודל למפה ומשנים אותו באמצעות חלק מאפשרויות ההתאמה האישית שזמינות:
async function init() { // Import the needed libraries. const { Map3DElement, Model3DElement } = await google.maps.importLibrary('maps3d'); const map = new Map3DElement({ center: { lat: 39.1178, lng: -106.4452, altitude: 4395.4952 }, range: 1500, tilt: 74, heading: 0, mode: 'HYBRID', gestureHandling: 'COOPERATIVE', }); const model = new Model3DElement({ src: 'https://maps-docs-team.web.app/assets/windmill.glb', position: { lat: 39.1178, lng: -106.4452, altitude: 4495.4952 }, orientation: { heading: 0, tilt: 270, roll: 90 }, scale: 0.15, altitudeMode: 'CLAMP_TO_GROUND', }); document.body.append(map); map.append(model); } void init();
הוספת מודל אינטראקטיבי
המודלים תומכים גם באינטראקציה. בדוגמה הבאה, קנה המידה של המודל משתנה כשלוחצים עליו.
async function init() { // Import the needed libraries. const { Map3DElement, Model3DInteractiveElement } = await google.maps.importLibrary('maps3d'); const map = new Map3DElement({ center: { lat: 39.1178, lng: -106.4452, altitude: 4395.4952 }, range: 1500, tilt: 74, heading: 0, mode: 'HYBRID', gestureHandling: 'COOPERATIVE', }); const model = new Model3DInteractiveElement({ src: 'https://maps-docs-team.web.app/assets/windmill.glb', position: { lat: 39.1178, lng: -106.4452, altitude: 4495.4952 }, orientation: { heading: 0, tilt: 270, roll: 90 }, scale: 0.15, altitudeMode: 'CLAMP_TO_GROUND', }); model.addEventListener('gmp-click', function () { this.scale = Math.random() * (0.5 - 0.1) + 0.1; }); document.body.append(map); map.append(model); } void init();