區域和路線的空氣品質和花粉指數

目標

空氣品質花粉 API 提供絕佳機會,可為任何地點的行程或地圖新增更多 洞察資料。您可以透過兩種方式使用這些 API 提供的資料:以文字形式建立索引,或以點陣圖像形式建立熱度圖磚。

alt_text

使用熱度圖圖塊 API 端點時,載入個別點陣圖塊時可能會遇到一些問題,例如:

  • 如何在網頁上的 Google 地圖載入圖塊?(也為了遵守 API 使用條款)
  • 如何在體驗期間管理要求數量?
  • 如何解讀動態磚值?

應用實例

我們會提供範例用途,協助您回答上述問題。

  • 特定區域的空氣品質和花粉在一個或多個自訂多邊形內,以熱度圖磚 (目前狀況) 點陣資料呈現。
  • 路線沿途的空氣品質和花粉 在路線航點上繪製熱視圖圖塊 (目前狀況) 點陣資料。

導入作業

您將瞭解有哪些動態磚可用,以及如何在網頁體驗中載入動態磚。您也會瞭解在將圖塊載入地圖的情況下,如何管理要求數量。最後,您會瞭解如何解讀圖塊。

依類型顯示可用的熱度圖方塊

Air Quality API

- UAQI_RED_GREEN (UAQI,紅綠色調色盤):通用空氣品質指數紅綠色調色盤。
- UAQI_INDIGO_PERSIAN (UAQI,靛藍色調):通用空氣品質指數靛藍色調。
- PM25_INDIGO_PERSIAN:PM2.5 指數靛藍色調色盤。
- GBR_DEFRA:英國每日空氣品質指數的調色盤。
- DEU_UBA:德國當地空氣品質指數調色盤。
- CAN_EC:加拿大空氣品質健康指數色調。
- FRA_ATMO:法國空氣品質指數色調。
- US_AQI:美國空氣品質指數調色盤。

Pollen API

- TREE_UP:熱視圖類型會代表樹狀結構索引圖形地圖。
- GRASS_UPI:熱視圖類型會代表草地指數圖形地圖。
- WEED_UPI:熱度圖類型會以圖形地圖表示雜草指數。

在網頁版中顯示熱視圖方塊

載入圖塊,並套用向量遮罩,只顯示地圖可視區域的所需部分。

載入資訊方塊

import { TileLayer } from "deck.gl";
import { GoogleMapsOverlay } from "@deck.gl/google-maps";

// const TileLayer = deck.TileLayer;
// const GoogleMapsOverlay = deck.GoogleMapsOverlay;

// Initialize and add the map
function initMap() {
  const map = new google.maps.Map(document.getElementById("map"), {
    center: { lat: 40, lng: -110 },
    zoom: 4,
  });

  const apiKey = 'YOUR_API_KEY';
 const airqualityType = 'UAQI_RED_GREEN' // AirQuality API heatmap type
  const deckOverlay = new GoogleMapsOverlay({
    layers: [
       // Heatmap Tiles layer
new TileLayer({
    id: 'heatmap-tiles',
    data: 'https://airquality.googleapis.com/v1/mapTypes/'+ heatmapType + +'/heatmapTiles/{z}/{x}/{y}?key=' + apiKey,
...
 })
    ],
  });

  deckOverlay.setMap(map);
}

window.initMap = initMap;

套用向量遮罩

您可以隱藏或顯示熱度圖格的任何部分。重要事項:您需要取得資料,用於建立套用至熱視圖圖塊的向量遮罩。

  • 在區域內:
  • 使用 deck.gl GeoJson 在 Air Quality TileLayer 上建立遮罩

alt_text

以下範例使用法國的多邊形 GeoJSON:

// geojson sample

{  "type": "Feature",
  "geometry": {
    "type": "MultiPolygon",
    "coordinates": [[[[-54.111527,2.11427],...[-54.194491,2.163073]]]]
  },
  "properties": {
    "name": "France"
  }
}

以下是 deckgl 導入作業的參考資料:

  // Loaded layers in maps overlay
  const deckOverlay = new GoogleMapsOverlay({ layers: layers });
  const MaskExtension = deck.MaskExtension; // or import extension
  ...

  // As part of object containing the different layers
  const layers = [
    // Masking layer
  new GeoJsonLayer({
    id: 'country-vector',
    operation: 'mask',
    data: "geojson.json", // <-- any custom geometry
  })
  ...
  ...

  // Heatmap Tiles layer
  new TileLayer({
      id: 'heatmap-tiles',
      maskId: 'country-vector', // <-- same as mask id
    extensions: [new MaskExtension()],  // <-- enable mask extension
  ...
  })
  ]
  • 沿著路線:使用 deck.gl 及其 TripsLayer,在 Air Quality TileLayer 上建立 Mask

行程中的空氣品質熱視圖圖塊

alt_text

管理 API 請求和費用

瀏覽器通常會將所有載入的圖塊快取到本機儲存空間 (在同一個工作階段內),但您可以進一步最佳化:

  • 限制載入區域:建立定界框 (以紅色表示) 並指派給圖層,在任何縮放層級,系統只會載入涵蓋定界框的熱視圖圖塊 (以藍色表示)

定界框 (紅色)、熱度圖圖塊 (藍色)

alt_text

 // Heatmap Tile layer
 new TileLayer({
    id: 'heatmap-tiles',
    extent: [minX, minY, maxX, maxY] // bounding box: southwest lat, southwest lng, northeast lat, northeast lng
    ...
 })
  • 設定視覺顯示圖塊大小,在任何縮放等級下都能涵蓋整個可視區域;建議介於 256 到 1024 之間。

    重要事項:API 圖塊的解析度仍為 256x256,但您可以調整視覺顯示設定,增加/減少圖塊要求數量,涵蓋整個地圖可視區域。

    (請確認這項功能適用於 Google 地圖的 minZoommaxZoom,也就是說,tilesize:1024 不會在縮放層級 0 或 1 載入圖塊)。

可視區域,圖塊為 256x256 像素與 512x512 像素

alt_text alt_text



    // Heatmap Tile layer
    new TileLayer({
        id: 'heatmap-tiles',
        tilesize:256, // <-- change to 512 for instance
        ...
    })

讀取像素值

如要在色階上顯示對應值

您可以將 onClick 事件指派為 deck.gl 圖層的屬性,然後使用 Luma.gl 程式庫及其 readPixelsToArray 方法。

像素值:rgba(128,0,0,255)

alt_text

alt_text

  // Uint8Array pixel sample
  import { readPixelsToArray } from "@luma.gl/core";
  ...

  // assign on the TileLayer
  new TileLayer({
      id: 'heatmap-tiles',
  ...
    onClick: ({
    bitmap,
    layer
  }) => {
    if (bitmap) {
      const pixel = readPixelsToArray(layer.props.image, {
        sourceX: bitmap.pixel[0],
        sourceY: bitmap.pixel[1],
        sourceWidth: 1,
        sourceHeight: 1
      });
      // console.log("color picked:"+ pixel);
    }
  }
  })

結論

您已瞭解 空氣品質花粉熱度圖圖塊 API 端點的用途:

  • 載入 Google 地圖網頁版,並確保符合使用條款
  • 根據您的用途進行最佳化
  • 讀取圖塊值

後續動作

建議閱讀:

貢獻者

主要作者:

Thomas Anglaret | Google 地圖平台解決方案工程師