在本文档中,您将了解如何使用 Air Quality API 打造丰富的地点搜索体验。 我们将展示空气质量如何从漏斗的开头到末尾为用户提供有价值的信号,以及如何将 Air Quality API 数据嵌入到现有体验中。
使用场景和附加价值
Air Quality API 信号可用于各种搜索体验,例如当用户查找要访问的地点时。Air Quality API 提供以下功能:
- 实时 * 和历史数据 - 代表当前状态的新鲜准确数据,以及 30 天内以小时分辨率回溯的数据。(* 室外空气质量每小时数据快照)
- 全球和本地数据 - 覆盖 100 多个国家/地区的整个区域,但高度本地化(最小 500 米)的空气质量 API 数据可为用户提供关键信号,以便用户进行比较并做出最合适的决定。
即使是相邻的地点,空气质量也可能截然不同
演示示例
在体验的早期显示空气质量数据
显示 Air Quality API 数据主要有两种方式:
当前状况 / 每小时:获取要针对每个地理位置显示的各个值。
(请参阅部分:在地图针上显示 Air Quality API 数据)热图图块:在地图上叠加一个彩色图层,表示当前的室外空气质量状况。提供针对特定国家/地区的图层索引。
(请参阅部分:在地图上显示 Air Quality API 热图图层)
在位置图钉上显示 Air Quality API 数据
- 选择您的位置指数:通用 AQI 或当地 AQI(最多可使用 70 种不同的空气质量指数 [AQI])。空气质量指数 (AQI) 是某个国家/地区(例如 美国国家环境保护局)根据不同的计算方法、数据源和指定用途对不同空气质量水平进行分类的量表。
- 直接从地点搜索体验中直观呈现主要 Air Quality API 值和颜色代码。
默认显示内容只能包含颜色代码。
在选择图钉时显示更多 Air Quality API 信息:
- 您可以根据需要调整默认显示的信息级别。请注意,与其他位置相比,某个位置的数据点通常很有用。
空气质量部分显示示例
{ "dateTime": "2023-08-09T10:00:00Z", "regionCode": "fr", "indexes": [ { "code": "uaqi", "displayName": "Universal AQI", "aqi": 76, "aqiDisplay": "76", "color": { "red": 0.4117647, "green": 0.77254903, "blue": 0.20392157 }, "category": "Good air quality", "dominantPollutant": "pm10" }, … ], "pollutants": [ { "code": "co", "displayName": "CO", "fullName": "Carbon monoxide", "concentration": { "value": 95.18, "units": "PARTS_PER_BILLION" }... }, … ], "healthRecommendations": -{ "generalPopulation": "With this level of air quality, you have no limitations. Enjoy the outdoors!", "elderly": "If you start to feel respiratory discomfort such as coughing or breathing difficulties, consider red ...", "lungDiseasePopulation": … } }
- 或者,您也可以仅在与某个地点互动时查询空气质量数据。
- 您可以使用 Air Quality API 索引过滤附近的地点,例如,如果您要查找所在地区的公园,则只会显示空气质量良好的公园。
空气质量响应
... "color":{ "red": 0.9490196, "green": 0.98039216, "blue": 0.019607844 } ...
var red = parseInt(colorResponse.red*255)|| 1; var green = parseInt(colorResponse.green*255)|| 1; var blue = parseInt(colorResponse.blue*255)|| 1; // --> output rgb(241,250,5)
在地图上显示 Air Quality API 热图图层
热图彩色图块非常适合:
- 以提供大区域概览。
- 以快速显示该区域内的细微差别。
将 Maps JavaScript API 与 ImateMapType 结合使用,即可显示覆盖 Google 地图整个视口所需的各个图块。当用户通过平移、缩放或更改位置与地图互动时,热图图块会刷新。
请注意,允许的缩放级别值不得超过 16。
在超本地搜索时,Air Quality API 热图图块图层可能会消失。
您可以在一组有限的空气质量指数中选择热图地图类型:
请务必指明颜色标度,以便用户了解该值及其颜色排名:
- 渐变标度 UAQI(0-100):不好 / 极佳
颜色调色板 CSS 代码段:
.gradient-scale { background: linear-gradient(to right, rgb(99, 20, 161) 0%, /* purple */ rgb(149, 0, 25) 20%, /* red */ rgb(248, 47, 21) 40%, /* orange */ rgb(255, 248, 35) 60%, /* yellow */ rgb(34,163,120) 80%, /* steelblue */ rgb(255,255,255) 100% /* white */ ); }
- 使用纯色来表示 UAQI(0-100)量表中的关键点:不好 / 极好
查询次数和相关费用
- Maps JavaScript API:在加载体验时,1 张地图。
- Air Quality API:
- 每个地点 1 次查询(在地图加载时全部查询,或仅在用户选择时查询)。
- 热图图块图层:每个图块图片的大小为 256*256 像素,若要覆盖移动设备或网站上显示的标准地图,您需要 12-14 个图块。每个拉取的功能块都算作 1 个 SKU 单元。
- 附近搜索(新)API:每显示 20 个地点,计 1 次查询。根据查询响应中的地点数据进行不同的结算。
总结
我们证明了 Air Quality API 可以成为用户决定去哪里旅行的重要数据点。因此,空气质量数据应尽早在搜索体验中显示,同时注意一次显示的信息量和显示方式。
后续操作
建议的进一步阅读材料:
贡献者
本文由 Google 维护。以下贡献者最初撰写了这篇文章。
主要作者:
Thomas Anglaret | 解决方案工程师