模型

模型是可添加到场景中以表示对象的 3D 资源。Maps JavaScript API 中的仿真 3D 地图支持包含 gLTF 模型。您可以缩放和旋转这些模型,以便进一步自定义。

模型必须支持 glTF PBR 的核心属性。不支持任何扩展程序或扩展程序属性。

添加模型

Model3DElement 构造函数采用一组 Model3DElementOptions(用于指定模型的 LatLng 坐标)和一组参数(用于支持模型定位)。

模型支持以下选项:

  • position:模型的位置(以 LatLng 坐标表示)。
  • orientation:模型坐标系的旋转情况。按以下顺序应用旋转:滚动、倾斜,然后朝向。
  • scale:在模型的坐标空间中缩放模型。默认值为 1
  • altitudeMode:如何解释以 position 表示的海拔。
  • src:模型的网址。

以下示例演示了如何将模型添加到地图中,以及如何使用可用的自定义选项对其进行修改:

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

  const map = new Map3DElement({
    center: {lat: 37.7438, lng: -121.5088, altitude: 1800},
    heading: -90,
    tilt: 90,
    mode: MapMode.SATELLITE,
  });

  document.body.append(map);
  
  const models = [
    // A model with regular settings.
    {
      position: {lat: 37.76, lng: -121.63, altitude: 0},
      orientation: {tilt: 270},
    },
    // Scaled down model.
    {
      position: {lat: 37.75, lng: -121.63, altitude: 0},
      orientation: {tilt: 270},
      scale: 0.8,
    },
    // Scaled up model.
    {
      position: {lat: 37.735, lng: -121.63, altitude: 0},
      orientation: {tilt: 270},
      scale: 1.2,
    },
    // A model with an additional transformation applied.
    {
      position: {lat: 37.72, lng: -121.63, altitude: 0},
      orientation: {tilt: 270, roll: 90},
    },
    // Non-clamped to the ground model.
    {
      position: {lat: 37.71, lng: -121.63, altitude: 1000},
      altitudeMode: 'RELATIVE_TO_GROUND',
      orientation: {tilt: 270},
    },
  ];

  for (const {position, altitudeMode, orientation, scale} of models) {
    const model = new Model3DElement({
      src: 'https://storage.googleapis.com/maps-web-api.appspot.com/gltf/windmill.glb',
      position,
      altitudeMode,
      orientation,
      scale,
    });

    map.append(model);
  }
}

init();

添加交互式模型

模型还支持互动。以下示例会更改模型的缩放比例。

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

  const map = new Map3DElement({
    center: {lat: 37.7438, lng: -121.5088, altitude: 1800},
    heading: -90,
    tilt: 90,
    mode: MapMode.SATELLITE,
  });

  document.body.append(map);

  const model = new Model3DInteractiveElement({
    src: 'https://storage.googleapis.com/maps-web-api.appspot.com/gltf/windmill.glb',
    position: {lat: 37.76, lng: -121.63, altitude: 0},
    scale: 1.0,
  });

  model.addEventListener('gmp-click', (event) => {
    model.scale = (Math.random() * (1 - 2)).toFixed(2);

  });

  map.append(model);
}

init();