forked from github/ebk_co2ampel
initial commit, still heavily wip
This commit is contained in:
parent
5dce35b6ae
commit
0ae89c1194
2 changed files with 139 additions and 0 deletions
50
README.md
Normal file
50
README.md
Normal file
|
@ -0,0 +1,50 @@
|
||||||
|
# CO² Ampel
|
||||||
|
|
||||||
|
Implementierung einer CO² Ampel mit ESP32 + MH-Z19B + SSD1306.
|
||||||
|
|
||||||
|
Inspiriert vom Projekt ["CO² Ampeln für alle" von der Un-Hack-Bar](https://www.un-hack-bar.de/2020/10/25/co2-ampeln-fuer-alle/).
|
||||||
|
|
||||||
|
Eine weitere tolle Seite mit vielen Infos über das Lüften und CO², auch wie man den Bau einer solchen Ampel in den Unterricht integrieren kann, findet sich unter [co2ampel.org](https://co2ampel.org).
|
||||||
|
|
||||||
|
Unsere Ampel ist sehr simpel gehalten, und komplett offline. So verbraucht sie wenig Strom und kann mit einer Powerbank mehrere Stunden betrieben werden.
|
||||||
|
|
||||||
|
Auf dem Display erscheint nur der aktuelle Wert und der historische Verlauf der letzten 120 Messwerte als Grafik.
|
||||||
|
|
||||||
|
Eine RGB-LED zeigt rot, gelb oder grün, je nach Messwert.
|
||||||
|
|
||||||
|
|
||||||
|
# Flashen
|
||||||
|
|
||||||
|
Wir benutzen bisher die Arduino IDE.
|
||||||
|
|
||||||
|
## ESP32 Boarddefinitionen
|
||||||
|
|
||||||
|
Falls noch nicht geschehen, müssen die Boarddefinitionen für den ESP32 installiert werden. Hierzu im Menü: Datei -> Voreinstellungen. Im Fenster dann bei "Zusätzliche Boardverwalter-URLs" diese URL eintragen:
|
||||||
|
|
||||||
|
```
|
||||||
|
https://dl.espressif.com/dl/package_esp32_index.json
|
||||||
|
```
|
||||||
|
|
||||||
|
Sollte dort schon etwas anderes drin stehen, mit einem Komma getrennt dazuschreiben.
|
||||||
|
|
||||||
|
Danach im Menü: Werkzeuge -> Board -> Boardverwalter nach "ESP32" suchen, und installieren.
|
||||||
|
|
||||||
|
## Libraries
|
||||||
|
|
||||||
|
Die benötigten Libraries installieren wir über die Bibliotheksverwaltung der Arduino IDE (Menü: Sketch -> Bibliothek einbinden -> Bibliotheken verwalten…), und zwar:
|
||||||
|
|
||||||
|
* [MH-Z19](https://github.com/crisap94/MHZ19) für das Auslesen des Sensors
|
||||||
|
* [ESP8266 and ESP32 OLED driver for SSD1306 displays](https://github.com/ThingPulse/esp8266-oled-ssd1306) für die Ansteuerung des Displays
|
||||||
|
|
||||||
|
## Flashen
|
||||||
|
|
||||||
|
* Als Board muss "ESP32 Dev Module" ausgewählt sein.
|
||||||
|
|
||||||
|
* Mit Strg+U kompilieren und auf den ESP laden.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
# Wiring
|
||||||
|
|
||||||
|
bild: todo
|
89
ebk_co2ampel/ebk_co2ampel.ino
Normal file
89
ebk_co2ampel/ebk_co2ampel.ino
Normal file
|
@ -0,0 +1,89 @@
|
||||||
|
#include <Arduino.h>
|
||||||
|
#include "MHZ19.h"
|
||||||
|
|
||||||
|
#include <Wire.h> // Only needed for Arduino 1.6.5 and earlier
|
||||||
|
#include "SSD1306Wire.h" // legacy include: `#include "SSD1306.h"`
|
||||||
|
#define RX_PIN 16 // Rx pin which the MHZ19 Tx pin is attached to
|
||||||
|
#define TX_PIN 17 // Tx pin which the MHZ19 Rx pin is attached to
|
||||||
|
#define BAUDRATE 9600 // Device to MH-Z19 Serial baudrate (should not be changed)
|
||||||
|
|
||||||
|
MHZ19 myMHZ19; // Constructor for library
|
||||||
|
|
||||||
|
HardwareSerial mySerial(1); // (ESP32 Example) create device to MH-Z19 serial
|
||||||
|
SSD1306Wire display(0x3c, 21, 22);
|
||||||
|
|
||||||
|
unsigned long getDataTimer = 0;
|
||||||
|
int lastvals[120];
|
||||||
|
|
||||||
|
void setup()
|
||||||
|
{
|
||||||
|
Serial.begin(9600); // Device to serial monitor feedback
|
||||||
|
|
||||||
|
mySerial.begin(BAUDRATE, SERIAL_8N1, RX_PIN, TX_PIN); // (ESP32 Example) device to MH-Z19 serial start
|
||||||
|
myMHZ19.begin(mySerial); // *Serial(Stream) refence must be passed to library begin().
|
||||||
|
display.init();
|
||||||
|
|
||||||
|
// display.flipScreenVertically();
|
||||||
|
|
||||||
|
display.setContrast(255);
|
||||||
|
delay(1000);
|
||||||
|
display.clear();
|
||||||
|
|
||||||
|
myMHZ19.autoCalibration(); // Turn auto calibration ON (OFF autoCalibration(false))
|
||||||
|
|
||||||
|
|
||||||
|
for (int x; x<=119; x=x+1) {
|
||||||
|
lastvals[x] = -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void loop()
|
||||||
|
{
|
||||||
|
if (millis() - getDataTimer >= 2000)
|
||||||
|
{
|
||||||
|
int CO2;
|
||||||
|
|
||||||
|
/* note: getCO2() default is command "CO2 Unlimited". This returns the correct CO2 reading even
|
||||||
|
if below background CO2 levels or above range (useful to validate sensor). You can use the
|
||||||
|
usual documented command with getCO2(false) */
|
||||||
|
CO2 = myMHZ19.getCO2(); // Request CO2 (as ppm)
|
||||||
|
|
||||||
|
for (int x=1; x<=119; x=x+1) {
|
||||||
|
lastvals[x-1] = lastvals[x];
|
||||||
|
}
|
||||||
|
|
||||||
|
lastvals[119] = CO2;
|
||||||
|
|
||||||
|
|
||||||
|
display.clear();
|
||||||
|
|
||||||
|
for (int h=1; h<120; h=h+1) {
|
||||||
|
int curval = lastvals[h];
|
||||||
|
if (curval > 0) {
|
||||||
|
int vpos = display.getHeight() - int((float(display.getHeight()) / 3000) * lastvals[h]);
|
||||||
|
int vpos_1 = display.getHeight() - int((float(display.getHeight()) / 3000) * lastvals[h-1]);
|
||||||
|
|
||||||
|
display.drawLine(h-1, vpos_1, h, vpos);
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int8_t Temp;
|
||||||
|
Temp = myMHZ19.getTemperature(); // Request Temperature (as Celsius)
|
||||||
|
|
||||||
|
display.setLogBuffer(5, 30);
|
||||||
|
display.println(CO2);
|
||||||
|
display.drawLogBuffer(0, 0);
|
||||||
|
display.display();
|
||||||
|
Serial.print("CO2 (ppm): ");
|
||||||
|
Serial.println(CO2);
|
||||||
|
Serial.println();
|
||||||
|
Serial.print("Temperature (C): ");
|
||||||
|
Serial.println(Temp);
|
||||||
|
|
||||||
|
getDataTimer = millis();
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue