将会话令牌与 Map Tiles API 搭配使用

会话令牌是一段数据 (UUID),在 REST 调用中用于标识会话(一系列相关的消息交换)。您必须在对 2D 图块和街景图像的所有请求中添加会话令牌。您可以将其作为 session 参数的值附加到所有请求网址。

在 Map Tiles API 中,会话令牌表示一组定义的显示选项。这意味着您不必为每个图块请求传递一组显示选项。您可以在多个客户端中使用同一会话令牌。 会话令牌目前的有效期为自颁发时间起的两周,但此期限可能会发生变化。您始终可以通过查看响应消息中的 expiry 字段来检查会话令牌的到期时间。

会话令牌请求

如需请求会话令牌,请向 createSession 端点发送 HTTPS POST 请求,如以下示例所示。您必须使用 Content-Type: application/json 标头发送请求。

curl -X POST -d '{
  "mapType": "streetview",
  "language": "en-US",
  "region": "US"
}' \
-H 'Content-Type: application/json' \
"https://tile.googleapis.com/v1/createSession?key=YOUR_API_KEY"

必填字段

mapType

基本地图的类型。这个值可以是以下值之一:

roadmap
标准的 Google 地图绘制地图图块。
satellite
卫星图像。
terrain
地形图像。选择 terrain 作为地图类型时,您还必须添加 layerRoadmap 图层类型(相关说明见可选字段部分)。
streetview
街景全景图片。如需了解详情,请参阅街景图块
language

IETF 语言标记,用于指定在图块上显示信息时使用的语言。例如,en-US 指定美国境内使用的英语。

region

通用语言区域数据代码库区域标识符(两个大写字母),表示用户的实际位置。例如 US

可选字段

imageFormat
指定要返回的文件格式。有效值为 jpegpng。JPEG 文件不支持透明度,因此不建议将其用于叠加图块。如果您未指定 imageFormat,则系统会自动选择功能块的最佳格式。
scale

放大地图元素(例如道路标签),同时保持默认图块的图块大小和覆盖区域。增加缩放比例还可减少地图上的标签数量,从而降低杂乱程度。以下值是有效的 scale 值:

  • scaleFactor1x:默认值。
  • scaleFactor2x:将标签大小加倍并移除次要特征标签。
  • scaleFactor4x:四倍标签大小并移除次要特征标签。

以下示例展示了缩放地图元素的效果。

缩放系数 1x 缩放系数 2x
显示缩放比例 1x 的地图 显示缩放比例 2x 的地图
highDpi
指定是否返回高分辨率图块。如果放大缩放比例,则使用 highDpi 增加图块的大小。通常,增加缩放比例会将生成的图块放大为相同大小的图像,这会降低画质。使用 highDpi 后,生成的大小也会增加,同时保持质量。DPI 代表每英寸点数,高 DPI 表示图块在渲染时使用的每英寸点数比正常值要多。如果为 true,则将 x 和 y 尺寸中的像素数乘以缩放比例(即 2x 或 4x)。功能块的覆盖区域保持不变。此参数仅适用于 2 倍或 4 倍的 scale 值。它对 1 倍缩放图块没有影响。
缩放系数 1x 缩放系数 2x 高 DPI
地图以常规分辨率显示 地图以 2 倍高 DPI 分辨率显示
layerTypes

值数组,用于指定添加到地图的图层类型。有效值包括:

layerRoadmap
如果您将地图类型指定为 terrain,则必须提供此值。也可以选择性地叠加在 satellite 地图类型上。对路线图图块没有影响。
layerStreetview
在地图上使用蓝色轮廓显示已启用街景的街道和位置。
layerTraffic
显示当前路况。
styles

一个 JSON 样式对象数组,用于指定地图项(例如道路、公园和建筑物区域)的外观和细节级别。样式设置用于自定义标准 Google 基本地图。仅当地图类型为 roadmap 时,styles 参数才有效。如需了解完整的样式语法,请参阅样式参考

overlay

一个布尔值,用于指定应将 layerTypes 渲染为单独的叠加层,还是与基础图像结合使用。如果设置为 true,则不会显示基本地图。如果您尚未定义任何 layerTypes,则此值将被忽略。

例如,如果请求包含 layerRoadmap 图层的 satellite 地图类型,并将 overlay 设置为 false,所生成的图块与 Maps JavaScript API 中使用的 hybrid 地图类型等效(左图)。对于相同的地图和图层类型,如果将 overlay 设置为 true,则会得到带有地图叠加层的透明图块,并且图块会设置适当的样式以叠加在卫星图像上(右图)。

overlay:false overlay:true
叠加层设置为 false 叠加层设置为 true

以下 JSON 是包含必填字段和选填字段的典型请求正文示例。

{
  "mapType": "satellite",
  "language": "en-US",
  "region": "us",
  "layerTypes": [ "layerRoadmap", "layerStreetview" ],
  "overlay":  true,
  "scale": "scaleFactor1x",
  "styles": [
    {
      "stylers": [
        { "hue": "#00ffe6" },
        { "saturation": -20 }
      ]
    },{
      "featureType": "road",
      "elementType": "geometry",
      "stylers": [
        { "lightness": 100 },
        { "visibility": "simplified" }
      ]
    }
  ]
}

此示例提供了一个适合与卫星图像组合的叠加层。此示例同时包含路线图和街景叠加层。最终地图会使用英语的名称和数据渲染,正如美国所说的那样。

apiOptions:一组值,用于指定要应用的其他选项。 支持的选项包括:

  • MCYJ5E517XR2JC - 选择启用新地图样式。在选择启用期间,除非指定此值,否则您的请求将采用现有样式。

会话令牌响应

下面的 JSON 是响应正文示例。

{
  "session": "IgAAAHGU9jnAU4KOAfwY3Bcd6eH_WxQsyocSBAdUnAr9pnvTTNXtF9c_27RBo94ytEXTDg",
  "expiry": "1361828036",
  "tileWidth": 256,
  "tileHeight": 256,
  "imageFormat": "png"
}

以下列表包含响应正文中字段的定义。

session
您必须在所有 Map Tiles API 请求中包含的会话令牌值。
expiry
一个字符串,包含令牌到期的时间(从公元纪年开始计算的秒数)。会话令牌的有效期为自创建之日起两周,但此政策可能会发生更改,恕不另行通知。
tileWidth
图块的宽度(以像素为单位)。
tileHeight
图块的高度(以像素为单位)。
imageFormat
图片格式,可以是 pngjpeg