CO2-Ampel mit Server und Display

/* This program is distributed in the hope that it will be useful,
      but WITHOUT ANY WARRANTY; without even the implied warranty of
      MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
      GNU General Public License for more details. */
#include <ESP8266WiFi.h>
#include <MHZ19.h>
#include <SoftwareSerial.h>
#include <ESP8266WebServer.h>

#include <Wire.h>

#include <LiquidCrystal_I2C.h>

LiquidCrystal_I2C lcd1(0x27, 16, 2);

String matrixausgabe_text  = " "; // Ausgabetext als globale Variable

volatile int matrixausgabe_index = 0;// aktuelle Position in Matrix

IPAddress myOwnIP; // ownIP for mDNS 

int Temp = 0 ;
//Reading CO2, temperature from the MHZ19 By: Jonathan Dempsey

//https://github.com/WifWaf/MH-Z19

MHZ19 myMHZ19; // Objekt MHZ19 Umweltsensor
SoftwareSerial MHZSerial(12,14, false); // TX,RX

int CO2 = 0 ;
String CO2TEXT = "" ;
String TempTEXT = "" ;
int doCal=0;  // Kalibriermerker
void CO2_Kalibrierfunktion(){ // Kalibrierfunktion
// Forced Calibration MH-Z19
Serial.print("Start MH-Z19 calibration, please wait 20 s ...");delay(20000);
myMHZ19.setRange(2000);
myMHZ19.calibrateZero();
myMHZ19.setSpan(2000); 
myMHZ19.autoCalibration(false);
Serial.println(" done");
}


ESP8266WebServer server(80);
//------------------------------ Server Hompage html-Code
const char INDEX_HTML_START[] =
 "<!DOCTYPE HTML>"
  "<html>"
  "<META HTTP-EQUIV=\"refresh\" CONTENT=\"20\">"
   "<head>"
   "<meta name = \"viewport\" content = \"width = device-width, initial-scale = 1.0, maximum-scale = 1.0, user-scalable=0\">"
     "<title>IoT-Werkstatt Umwelt-Campus Birkenfeld</title>"
   "</head>"
    "<body>"
    "<CENTER>";

const char INDEX_HTML_SUBMIT[] =
     "<FORM action=\"/\" method=\"post\">"
     "<P>"
        "Password: "
        "<INPUT type=\"text\" name=\"message\">"
        "<INPUT type=\"submit\" value=\"Calibrate\">"
      "</P>"
     "</FORM>";

const char INDEX_HTML_END[] =
    "</CENTER>"
   "</body>"
  "</html>";
 
 String cal_passwort = "Kalibrieren"; // Kalibrierpasswort
 String cal_message  = "";      // Nachricht
 
//------------------------------ Server Ausgabe Messwerte in Form einer html-Tabelle

String messwertTabelle(){ 
  String unit1=" C";
  String unit2="";
  String unit3="";

  String nam1="Temperatur";
  String nam2="";
  String nam3="";

  float mess1=myMHZ19.getTemperature();
  float mess2=0;
  float mess3=0;
  //String html =  "<h2>Aktuelle Informationen:</h2>";
  String html = "<h2><table>";
  if (nam1.length()>0)
     html = html +  "<tr><td>" + nam1 + ":</td> <td>" + String(mess1) + "</td><td>"+ unit1 +" </td></tr>";
  if (nam2.length()>0)
     html = html +  "<tr><td>" + nam2 + ":</td> <td>" + String(mess2) + "</td><td>"+ unit2 +" </td></tr>";
  if (nam3.length()>0)
     html = html +  "<tr><td>" + nam3 + ":</td> <td>" + String(mess3) + "</td><td>"+ unit3 +" </td></tr>";
  html=html+"</table></h2>";
  return html;
}
//------------------------------ Server Ausgabe Bild in Abhängigkeit von Messert und Grenzen
void serverSendFigure(){ 
  String unit ="ppm";
  String nam  ="CO2";
  float mess=myMHZ19.getCO2();
  float limit1 = 1000;
  float limit2 = 1800;
  if (mess < limit1) // grün
     server.sendContent(F("<img src= ''alt=''>"));
    else
     if (mess>limit2) // rot 
        server.sendContent(F("<img src='' alt=''>"));
       else // gelb
        server.sendContent(F("<img src='' alt=''>"));
     String val = String("<h1>")+String(nam)+String(": ")+String(mess)+String(" ")+unit+ String("</h1>");
     server.sendContent(val);
 }
//------------------------------ Server Unterprogramm zur Bearbeitung der Anfragen
void serverHomepage() { 
 if (server.hasArg("message")) {// Wenn Kalibrierpasswort eingetroffen,
   String input = server.arg("message");     // dann Text vom Client einlesen
   if (input == cal_passwort){
      cal_message = "do calibration (20 s wait)";
      doCal = 1;
   } else
      cal_message = "wrong password";
 } else cal_message = "";
	 server.setContentLength(CONTENT_LENGTH_UNKNOWN);
 server.send ( 200, "text/html", INDEX_HTML_START);
 serverSendFigure();             // Ampel integrieren
 server.sendContent(F("<img src=' ' alt=''>"));
 server.sendContent(messwertTabelle());
 if (cal_passwort != "your password") {
  server.sendContent(INDEX_HTML_SUBMIT);
  server.sendContent(cal_message);
 }
 server.sendContent(INDEX_HTML_END);
}



void setup(){ // Einmalige Initialisierung
Serial.begin(115200);
MHZSerial.begin(9600);         // MHZ19 CO2-Sensor 9600 Baud
myMHZ19.begin(MHZSerial);
myMHZ19.autoCalibration(false);// keine Autokalibrierung

Serial.println();
pinMode( 0 , OUTPUT);
pinMode( 2 , OUTPUT);
pinMode( 13 , OUTPUT);
//------------ HTML-Server initialisieren
server.on("/", serverHomepage);
 server.begin();// Server starten



//------------ eigenen WLAN - Accespoint aufbauen 
WiFi.softAP("MeinOctiWLAN","12345678");
Serial.print("\nAccessPoint SSID:"); Serial.print("MeinOctiWLAN");
Serial.println ("  IP:"+ WiFi.softAPIP().toString());
myOwnIP = WiFi.softAPIP();
matrixausgabe_text = String("Mein Netz:") + String("MeinOctiWLAN") + String( " IP:") + WiFi.softAPIP().toString();
matrixausgabe_index=0;

lcd1.init();  lcd1.backlight();   start();

}

void loop() { // Kontinuierliche Wiederholung 
Temp = myMHZ19.getTemperature() ;
CO2 = myMHZ19.getCO2() ;
CO2TEXT = "CO2 ppm="+String(String(myMHZ19.getCO2())) ;
TempTEXT = "Temp C="+String(String(myMHZ19.getTemperature())) ;
Serial.print(CO2TEXT);
Serial.println();
Serial.print(TempTEXT);
Serial.println();
lcd1.clear(); lcd1.setCursor(0,0); lcd1.print(String(String(CO2))+"ppm CO2"+" "+String(Temp)+"\xDF"+"C");
if (( ( CO2 ) > ( 1800 ) ))
{
digitalWrite( 0 , HIGH );
digitalWrite( 2 , LOW );
digitalWrite( 13 , LOW );
lcd1.setCursor(0,1);
lcd1.print("Jetzt l\xF5");
lcd1.print("ften!");
	delay( 20000 );
}
else
{
if (( ( CO2 ) > ( 1000 ) ))
{
digitalWrite( 0 , LOW );
digitalWrite( 2 , HIGH );
digitalWrite( 13 , LOW );
lcd1.setCursor(0,1); lcd1.print("L\xF5");
lcd1.print("ften geraten");
}
else
{
digitalWrite( 0 , LOW );
digitalWrite( 2 , LOW );
digitalWrite( 13 , HIGH );
lcd1.setCursor(0,1); lcd1.print("Luft OK");
}
	delay( 20000 );
}
//Block------------------------------ HTML-Server
server.handleClient(); //Homepageanfragen versorgen
delay(1);
if (doCal) {
   CO2_Kalibrierfunktion(); // Kalibrierfunktion aufrufen 
   doCal=0; 
}}

void start()
{
lcd1.clear();   lcd1.setCursor(0,0);   lcd1.print("   CO2-Ampel");   lcd1.setCursor(0,1);   lcd1.print("Naturbez Bildung");
lcd1.backlight();   delay(2000);   lcd1.noBacklight();    delay(1000);   lcd1.backlight();    delay(2000);   lcd1.noBacklight();
delay(1000);   lcd1.backlight();      delay(2000);   lcd1.noBacklight();     delay(1000);   lcd1.backlight();     delay(1000);
}