جودة الهواء وحبوب اللقاح في المناطق والطرق

الهدف

توفّر واجهتا برمجة التطبيقات Air Quality وPollen فرصًا رائعة لإضافة المزيد من الإحصاءات إلى رحلة أو خريطة في أي موقع جغرافي. هناك طريقتان لاستخدام البيانات المتاحة من واجهات برمجة التطبيقات هذه: الفهرسة كنص أو مربّعات خريطة الكثافة كصور نقطية.

alt_text

أثناء استخدام نقاط نهاية واجهات برمجة التطبيقات للمربّعات الخرائط الحرارية، قد تواجه بعض التحديات أثناء تحميل مربّعات الصور النقطية الفردية، مثل:

  • كيف يمكن تحميل المربّعات على "خريطة Google" على الويب؟ (للامتثال أيضًا لبنود الاستخدام الخاصة بواجهات برمجة التطبيقات)
  • كيف يمكن إدارة عدد الطلبات أثناء التجربة؟
  • كيفية قراءة قيم المربّعات

أمثلة لحالات الاستخدام

سيتم عرض أمثلة على حالات الاستخدام لمحاولة الإجابة عن الأسئلة أعلاه.

  • جودة الهواء وحبوب اللقاح في منطقة: يمكنك عرض مربّعات الخريطة الحرارية (الظروف الحالية) لبيانات نقطية داخل مضلّع مخصّص واحد أو أكثر.
  • جودة الهواء وحبوب اللقاح على طول المسار: يمكنك عرض مربّعات الخريطة الحرارية (الظروف الحالية) لبيانات نقطية تم ربطها بنقاط طريق المسارات.

التنفيذ

ستتعرّف على البلاطات المتوفّرة وكيفية تحميلها في تجربة على الويب. ستتعرّف أيضًا على الإجراءات التي يمكن اتّخاذها لإدارة عدد الطلبات في سيناريو يتم فيه تحميل المربّعات على خريطة. أخيرًا، سيتم عرض كيفية قراءة المربّعات.

مربّعات الخريطة الحرارية المتوفّرة حسب الأنواع

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;

تطبيق قناع متّجه

يمكنك إخفاء أو إظهار أي جزء من مربّعات خريطة الحرارة بشكل مرئي. ملاحظة مهمة: عليك الحصول على البيانات التي سيتم استخدامها لإنشاء قناع متّجه يتم تطبيقه على مربّعات خريطة الكثافة.

  • في مساحة:
  • استخدِم GeoJson في deck.gl لإنشاء Mask فوق 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

مربّع خريطة حرارية لجودة الهواء فوق رحلة

alt_text

إدارة طلبات البيانات من واجهة برمجة التطبيقات والتكلفة

على الرغم من أنّ السلوك التلقائي للمتصفّح هو عادةً تخزين جميع المربّعات التي تم تحميلها في مساحة التخزين المحلية (خلال الجلسة نفسها)، يمكنك إجراء المزيد من التحسينات:

  • حصر منطقة التحميل: أنشئ مربّع حدود التظليل (باللون الأحمر) وخصّصه للطبقة، ولن يتم تحميل سوى مربّعات الخريطة الحرارية (باللون الأزرق) التي تغطّي مربّع حدود التظليل عند أي مستوى تكبير/تصغير معيّن

مربع الإحاطة (باللون الأحمر)، ومربعات خريطة الكثافة (باللون الأزرق)

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.

    ملاحظة مهمة: تظل مربّعات واجهات برمجة التطبيقات بدقة 256×256، ولكن سيسمح لك تعديل العرض المرئي بزيادة/تقليل عدد طلبات المربّعات لتغطية كامل إطار عرض الخريطة.

    (تأكَّد من أنّها تعمل مع minZoom وmaxZoom في "خريطة Google"، أي أنّ 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
        ...
    })

قراءة قيم وحدات البكسل

لعرض القيمة المقابلة على مقياس الألوان

يمكنك استخدام مكتبة Luma.gl وطريقتها readPixelsToArray عند وقوع حدث onClick تم تعيينه كخاصية إلى طبقة deck.gl.

قيمة البكسل: 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);
    }
  }
  })

الخاتمة

لقد اكتشفت كيف يمكن أن تكون نقاط نهاية واجهة برمجة التطبيقات الخاصة بمربّعات الخرائط الحرارية جودة الهواء وحبوب اللقاح على النحو التالي:

  • يجب أن يتم تحميلها على خريطة Google على الويب مع التأكّد من الالتزام ببنود الاستخدام.
  • تم تحسينها لتناسب حالة الاستخدام
  • قراءة قيم المربّعات

الإجراءات التالية

محتوى إضافي للقراءة:

المساهمون

المؤلفون الرئيسيون:

توماس أنغلاريه | مهندس حلول في "منصة خرائط Google"