Atmosfera ifloslanishining vizualizatsiyasi: 4 qadam
Atmosfera ifloslanishining vizualizatsiyasi: 4 qadam
Anonim
Atmosfera ifloslanishining vizualizatsiyasi
Atmosfera ifloslanishining vizualizatsiyasi

Havoning ifloslanishi muammosi ko'proq e'tiborni tortmoqda. Bu safar biz PM2.5 ni Wio LTE va yangi Laser PM2.5 Sensor yordamida kuzatishga harakat qildik.

1 -qadam: Ushbu loyihada ishlatilgan narsalar

Uskuna komponentlari

  • Wio LTE EU versiyasi v1.3- 4G, Cat.1, GNSS, Espruino bilan mos keladi
  • Grove - lazer PM2.5 sensori (HM3301)
  • Grove - 16 x 2 LCD (oq rangda)

Dasturiy ta'minot va onlayn xizmatlar

  • Arduino IDE
  • PubNub Publish/Subscribe API

2 -qadam: Uskuna ulanishi

Uskuna ulanishi
Uskuna ulanishi

Yuqoridagi rasmga ko'ra, biz I2C aloqasi uchun ikkita o'rmon chizig'ini kesib tashladik, shunda Wio LTE LCD Grove va PM2.5 Sensor Grove -ga bir vaqtning o'zida ulanishi mumkin. Bunga erishish uchun siz I2C uyasidan foydalanishingiz mumkin.

Shuni unutmangki, LTE antennasini Wio LTE -ga ulang va unga SIM -kartangizni ulang.

3 -qadam: veb -konfiguratsiya

Veb -konfiguratsiya
Veb -konfiguratsiya

PubNub hisobiga kirish yoki ro'yxatdan o'tish uchun bu erni bosing, u real vaqtda ma'lumotlarni uzatish uchun ishlatiladi.

PubNub Admin Portal -da siz demo -loyihani ko'rasiz. Loyihaga kiring, u erda 2 ta kalit bor: Nashriyot kaliti va obuna kaliti, ularni dasturiy ta'minot uchun eslab qoling.

4 -qadam: dasturiy ta'minot

1 -qism. Wio LTE

Wio LTE uchun PubNub kutubxonasi yo'qligi sababli, biz HTTP so'rovi orqali real vaqtda ma'lumotlarni nashr etishimiz mumkin, PubNub REST API hujjatini ko'ring.

Rasm
Rasm

Wio LTE -ga ulangan SIM -kartangizdan HTTP -ga ulanish uchun avval APN -ni o'rnatishingiz kerak. Agar buni bilmasangiz, mobil operatoringizga murojaat qiling.

APNni o'rnatgandan so'ng PubNub nashr kalitini, obuna kaliti va kanalini o'rnating. Bu erdagi kanal, nashriyot va obunachilarni farqlash uchun ishlatiladi, obunachilar bir xil kanalga ega bo'lgan nashriyotlardan ma'lumotlarni oladi.

Wio LTE -dagi Boot0 tugmachasini bosib ushlab turing, uni USB kabeli orqali kompyuteringizga ulang, Arduino IDE -dagi kodni unga yuklang. Yuklab olgandan so'ng, WST LTE -ni tiklash uchun RST tugmasini bosing.

2 -qism. Veb -sahifa

PubNub -ga o'ting, Demo Keyset -ni kiriting va chapda Debug Console -ni bosing, u yangi sahifani ochadi.

Rasm
Rasm

Kanal nomini Standart kanal matn maydoniga to'ldiring va "Mijoz qo'shish" tugmasini bosing. Biroz kutib turing, Debug Console -da PM1.0, PM2.5 va PM10 qiymatlari paydo bo'ladi.

Lekin bu biz uchun do'stona emas, shuning uchun biz uni jadval sifatida ko'rsatishni o'ylaymiz.

Birinchidan, kompyuteringizda yangi html faylini yarating. Matn muharriri orqali oching, unga asosiy HTML teglarini qo'shing.

Keyin PubNub va Chart.js skriptlarini boshiga qo'shing, siz ham ushbu sahifaga sarlavha qo'shishingiz mumkin.

Ko'rilgan chang monitor

Jadvalni ko'rsatish uchun joy bo'lishi kerak, shuning uchun biz sahifaning tanasiga tuval qo'shamiz.

Va skript yorlig'ini qo'shing, shunda biz real vaqtda ma'lumotlarga obuna bo'lish va grafik chizish uchun javascript qo'sha olamiz.

PubNub-dan real vaqtda ma'lumotlarga obuna bo'lish uchun PubNub obyekti bo'lishi kerak, var pubnub = yangi PubNub ({

publishKey: "", subscribeKey: ""});

va unga tinglovchini qo'shing.

pubnub.addListener ({

xabar: funktsiya (msg) {}});

Msg funktsiyasi xabarining xabar a'zosi - bu bizga kerakli ma'lumotlar. Endi biz PubNub-dan real vaqtda ma'lumotlarga obuna bo'lishimiz mumkin:

pubnub.subolish ({

kanal: ["chang"]});

Ammo uni jadval sifatida qanday ko'rsatish mumkin? Biz real vaqtda ma'lumotlarni saqlash uchun 4 ta massiv yaratdik:

var chartLabels = yangi Array ();

var chartPM1Data = yangi qator (); var chartPM25Data = yangi qator (); var chartPM10Data = yangi qator ();

Ulardan grafikLabels massivi ma'lumotlarga etib kelgan vaqtni saqlash uchun ishlatiladi, chartPM1Data, chartPM25Data va chartPM10Data mos ravishda PM1.0, PM2.5 va PM10 ma'lumotlarini saqlash uchun ishlatiladi. Haqiqiy vaqtda ma'lumotlar kelganda, ularni alohida massivlarga o'tkazing.

chartLabels.push (yangi sana (). toLocalString ());

chartPM1Data.push (msg.message.pm1); chartPM25Data.push (msg.message.pm25); chartPM10Data.push (msg.message.pm10);

Keyin jadvalni ko'rsating:

var ctx = document.getElementById ("grafik"). getContext ("2d");

var chart = yangi grafik (ctx, {type: "line", ma'lumotlar: {labels: chartLabels, ma'lumotlar to'plamlari: [{label: "PM1.0", data: chartPM1Data, borderColor: "#FF6384", to'ldirish: false), {label: "PM2.5", ma'lumotlar: chartPM25Data, borderColor: "#36A2EB", to'ldirish: false}, {teg: "PM10", ma'lumotlar: chartPM10Data, borderColor: "#CC65FE", to'ldirish: noto'g'ri}]}});

Endi bu html faylini veb -brauzer bilan oching, ma'lumotlar o'zgarishini ko'rasiz.