Kualitas Udara dan Serbuk Sari di area dan rute

Tujuan

Air Quality dan Pollen API menawarkan peluang besar untuk menambahkan lebih banyak insight ke perjalanan atau peta di lokasi tertentu. Ada dua cara untuk menggunakan data yang tersedia dari API tersebut: indeks sebagai petak teks atau peta panas sebagai gambar raster.

alt_text

Saat menggunakan endpoint karta panas API, Anda mungkin menghadapi beberapa tantangan saat memuat setiap ubin raster seperti:

  • bagaimana cara memuat ubin di Google Maps di Web? (juga untuk mematuhi Persyaratan penggunaan API)
  • bagaimana cara mengelola jumlah permintaan selama pengalaman?
  • bagaimana cara membaca nilai kartu?

Kasus penggunaan sampel

Anda akan melihat contoh kasus penggunaan untuk mencoba menjawab pertanyaan di atas.

  • Kualitas Udara & Serbuk Sari di suatu area: memvisualisasikan data raster karta panas (kondisi saat ini) di dalam satu atau beberapa poligon kustom.
  • Kualitas Udara & Serbuk Sari di sepanjang rute: memvisualisasikan data raster karta panas (kondisi saat ini) yang dipetakan di titik jalan rute.

Penerapan

Anda akan menemukan kartu yang tersedia dan cara memuat kartu tersebut di pengalaman Web. Anda juga akan melihat apa yang bisa dilakukan untuk mengelola jumlah permintaan dalam skenario di mana petak dimuat ke peta. Terakhir Anda akan disajikan cara membaca ubin.

Kartu peta panas yang tersedia menurut jenis

Air Quality API

- UAQI_RED_GREEN (UAQI, palet merah-hijau): Palet merah-hijau Indeks Kualitas Udara Universal.
- UAQI_INDIGO_PERSIAN (UAQI, palet indigo-persian): Palet indigo-persian Indeks Kualitas Udara Universal.
- PM25_INDIGO_PERSIAN: palet indigo-persian indeks PM2.5.
- GBR_DEFRA: Palet warna Indeks Kualitas Udara Harian (Inggris Raya).
- DEU_UBA: Palet warna Indeks Kualitas Udara Lokal Jerman.
- CAN_EC: Palet warna Indeks Kesehatan Kualitas Udara Kanada.
- FRA_ATMO: Palet warna Indeks Kualitas Udara Prancis.
- US_AQI: Palet warna Indeks Kualitas Udara Amerika Serikat.

Pollen API

- TREE_UP: Jenis peta panas akan mewakili peta grafis indeks pohon.
- GRASS_UPI: Jenis peta panas akan merepresentasikan peta grafis indeks rumput.
- WEED_UPI: Jenis peta panas akan merepresentasikan peta indeks gulma secara grafis.

Menampilkan kartu peta panas di Web

Muat ubin dan terapkan mask vektor untuk hanya menampilkan area yang diinginkan dari area pandang peta.

Memuat kartu

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;

Menerapkan Mask vektor

Anda dapat menyembunyikan atau menampilkan bagian mana pun dari kartu peta panas secara visual. Penting: Anda harus mendapatkan data yang akan digunakan untuk membuat mask vektor yang diterapkan ke ubin peta panas.

  • Di Area:
  • menggunakan GeoJson deck.gl untuk membuat Mask di atas TileLayer Kualitas Udara.

alt_text

Contoh di bawah menggunakan geojson multipoligon Prancis

// geojson sample

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

Berikut adalah referensi untuk penerapan 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
  ...
  })
  ]
  • Di Sepanjang Rute: Gunakan deck.gl dengan TripsLayer untuk membuat Mask di atas TileLayer Kualitas Udara

Kartu peta panas Kualitas Udara selama perjalanan

alt_text

Mengelola permintaan dan biaya API

Meskipun perilaku default browser biasanya menyimpan semua kartu yang dimuat dalam penyimpanan lokal ke dalam cache (dalam sesi yang sama), Anda dapat mengoptimalkannya lebih lanjut:

  • Batasi area pemuatan: buat kotak pembatas (dalam warna merah) dan tetapkan ke lapisan, hanya ubin peta panas (dalam warna biru) yang menutupi kotak pembatas yang akan dimuat pada tingkat zoom tertentu

Kotak Pembatas (dalam warna merah), Kartu peta panas (dalam warna biru)

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
    ...
 })
  • Menyetel ukuran ubin tampilan visual agar menutupi seluruh area pandang pada tingkat zoom yang ditentukan; disarankan: antara 256 hingga 1024.

    Penting: Ubin API tetap memiliki resolusi 256x256, tetapi penyesuaian tampilan visual akan memungkinkan Anda meningkatkan/menurunkan jumlah permintaan ubin untuk mencakup seluruh Viewport peta

    (pastikan berfungsi dengan minZoom dan maxZoom Google Maps, yaitu: tilesize:1024 tidak akan memuat ubin pada zoom 0 atau 1).

Area pandang dengan kotak 256x256 piksel vs 512x512 piksel

alt_text alt_text



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

Membaca nilai piksel

Untuk menampilkan nilai yang sesuai pada skala warna

Anda dapat menggunakan library Luma.gl dan metode readPixelsToArray-nya setelah peristiwa onClick ditetapkan sebagai properti ke lapisan deck.gl.

Nilai piksel: rgba(128,0,0,255)

alt_text

RENDAH alt_text TINGGI

  // 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);
    }
  }
  })

Kesimpulan

Anda telah mengetahui cara endpoint API ubin peta panas Kualitas Udara dan Serbuk Sari dapat:

  • yang dimuat pada Google Maps di Web. Pastikan juga sesuai dengan Persyaratan penggunaan
  • dioptimalkan agar sesuai dengan kasus penggunaan Anda
  • membaca nilai kartu

Tindakan Berikutnya

Bacaan lebih lanjut yang disarankan:

Kontributor

Penulis utama:

Thomas Anglaret | Engineer Solusi Google Maps Platform