Maps JavaScript API 提供了两种不同的地图实现方式:光栅和矢量。默认情况下,系统会加载光栅地图,并将地图加载为基于像素的光栅图像图块网格,这些图块由 Google Maps Platform 服务器端生成,然后提供给您的 Web 应用。矢量地图由基于矢量的图块组成,这些图块在加载时使用 WebGL 在客户端绘制,WebGL 是一种 Web 技术,可让浏览器访问用户设备上的 GPU 以渲染 2D 和 3D 图形。建议您使用矢量地图类型,以便获得最佳用户体验,因为这种地图类型可提供更出色的视觉保真度,并且能够控制地图上的倾斜度和航向。详细了解矢量地图项。
您可以通过指定 renderingType
地图选项或在关联的地图 ID 上设置该选项来为地图设置渲染类型。renderingType
选项会替换通过配置地图 ID 进行的任何渲染类型设置。
指定 renderingType
选项
使用 renderingType
选项为地图指定光栅或矢量渲染类型(无需地图 ID)。对于使用 div
元素和 JavaScript 加载的地图,默认渲染类型为 google.maps.RenderingType.RASTER
。请按以下步骤设置 renderingType
选项:
加载
RenderingType
库;可以在加载 Google 地图库时执行此操作:const { Map, RenderingType } = await google.maps.importLibrary("maps");
初始化地图时,请使用
renderingType
选项指定RenderingType.VECTOR
或RenderingType.RASTER
:map = new Map( document.getElementById('map'), { zoom: 4, center: position, renderingType: RenderingType.VECTOR, } );
设置矢量地图渲染类型后,您必须为所需地图项设置选项。
- 如需启用倾斜功能,请将
tiltInteractionEnabled
地图选项设置为true
或调用map.setTiltInteractionEnabled(true)
。 - 如需启用平移功能,请将
headingInteractionEnabled
地图选项设置为true
或调用map.setHeadingInteractionEnabled(true)
。
对于使用 <gmp-map>
元素加载的地图,默认渲染类型为 google.maps.RenderingType.VECTOR
,并启用了倾斜度和航向控制。如需使用 <gmp-map>
元素设置渲染类型,请使用 rendering-type
属性。
使用地图 ID 设置渲染类型
您还可以使用地图 ID 指定渲染类型。如需创建新的地图 ID,请按照使用云端地图样式设置 - 获取地图 ID 一文中的步骤操作。请务必将地图类型设置为 JavaScript,然后选择一个选项(矢量或光栅)。选中倾斜和旋转,以在地图上启用倾斜和旋转。这样一来,您就可以通过编程方式调整这些值,并且用户也可以直接在地图上调整倾斜度和航向。如果使用倾斜或朝向会对应用产生不利影响,则不要选中倾斜和旋转,这样用户就无法调整倾斜度和旋转度。
接下来,使用您创建的地图 ID 更新地图初始化代码。您可以在地图管理页面上找到您的地图 ID。在实例化地图时,请通过 mapId
属性提供地图 ID,如下所示:
map = new google.maps.Map(document.getElementById('map'), { center: {lat: -34.397, lng: 150.644}, zoom: 8, mapId: 'MAP_ID' });