Min/Max values are taken after FIRST_MIN_MAX millisencods due to measurement failures

of the DHT22 at start.
master
Holger Wirtz 4 years ago
parent 2d88947830
commit 4dd57c2e44
  1. 17
      WLAN_Thermometer.ino

@ -30,6 +30,7 @@
#define WIFI_CONNECT_TIMEOUT 30 #define WIFI_CONNECT_TIMEOUT 30
#define CFG_PORTAL_TIMEOUT 90 #define CFG_PORTAL_TIMEOUT 90
#define DHTTYPE DHT22 #define DHTTYPE DHT22
#define FIRST_MIN_MAX 300000 // = 5 min
LiquidCrystal_I2C lcd(LCD_I2C_ADDR, LCD_COL, LCD_ROW); LiquidCrystal_I2C lcd(LCD_I2C_ADDR, LCD_COL, LCD_ROW);
looper sched; looper sched;
@ -195,9 +196,11 @@ void loop()
client.print(temp[ACT]); client.print(temp[ACT]);
client.println(" &deg;C</h2>\n"); client.println(" &deg;C</h2>\n");
client.print("<h2 style=\"color:green;\">Minimum: "); client.print("<h2 style=\"color:green;\">Minimum: ");
if (millis() > FIRST_MIN_MAX)
client.print(temp[MIN]); client.print(temp[MIN]);
client.println(" &deg;C</h2>\n"); client.println(" &deg;C</h2>\n");
client.print("<h2 style=\"color:green;\">Maximum: "); client.print("<h2 style=\"color:green;\">Maximum: ");
if (millis() > FIRST_MIN_MAX)
client.print(temp[MAX]); client.print(temp[MAX]);
client.println(" &deg;C</h2>\n"); client.println(" &deg;C</h2>\n");
client.println("<h1 style=\"color:blue;\">Luftfeuchtigkeit</h1>\n"); client.println("<h1 style=\"color:blue;\">Luftfeuchtigkeit</h1>\n");
@ -205,9 +208,11 @@ void loop()
client.print(hum[ACT]); client.print(hum[ACT]);
client.println(" %</h2>\n"); client.println(" %</h2>\n");
client.print("<h2 style=\"color:blue;\">Minimum: "); client.print("<h2 style=\"color:blue;\">Minimum: ");
if (millis() > FIRST_MIN_MAX)
client.print(hum[MIN]); client.print(hum[MIN]);
client.println(" %</h2>\n"); client.println(" %</h2>\n");
client.print("<h2 style=\"color:blue;\">Maximum: "); client.print("<h2 style=\"color:blue;\">Maximum: ");
if (millis() > FIRST_MIN_MAX)
client.print(hum[MAX]); client.print(hum[MAX]);
client.println(" %</h2>\n"); client.println(" %</h2>\n");
client.println("<h1 style=\"color:gray;\">Gef&uuml;hlte Temperatur</h1>\n"); client.println("<h1 style=\"color:gray;\">Gef&uuml;hlte Temperatur</h1>\n");
@ -215,9 +220,11 @@ void loop()
client.print(heat[ACT]); client.print(heat[ACT]);
client.println(" &deg;C</h2>\n"); client.println(" &deg;C</h2>\n");
client.print("<h2 style=\"color:gray;\">Minimum: "); client.print("<h2 style=\"color:gray;\">Minimum: ");
if (millis() > FIRST_MIN_MAX)
client.print(heat[MIN]); client.print(heat[MIN]);
client.println(" &deg;C</h2>\n"); client.println(" &deg;C</h2>\n");
client.print("<h2 style=\"color:gray;\">Maximum: "); client.print("<h2 style=\"color:gray;\">Maximum: ");
if (millis() > FIRST_MIN_MAX)
client.print(heat[MAX]); client.print(heat[MAX]);
client.println(" &deg;C</h2>\n"); client.println(" &deg;C</h2>\n");
@ -341,8 +348,10 @@ void show_temperature(void)
lcd.print("C"); lcd.print("C");
lcd.setCursor(0, 2); lcd.setCursor(0, 2);
lcd.print("Min: "); lcd.print("Min: ");
if (millis() > FIRST_MIN_MAX)
lcd.print(temp[MIN], 1); lcd.print(temp[MIN], 1);
lcd.print(" Max: "); lcd.print(" Max: ");
if (millis() > FIRST_MIN_MAX)
lcd.print(temp[MAX], 1); lcd.print(temp[MAX], 1);
lcd.setCursor(0, 3); lcd.setCursor(0, 3);
lcd.print("LF: "); lcd.print("LF: ");
@ -392,20 +401,24 @@ bool is_wintertime(time_t t)
void get_sensor_data(void) void get_sensor_data(void)
{ {
temp[ACT] = constrain(dht.readTemperature(), -40.0, 80.0); temp[ACT] = constrain(dht.readTemperature(), -40.0, 80.0);
hum[ACT] = constrain(dht.readHumidity(), 0.0, 100.0);
heat[ACT] = constrain(dht.computeHeatIndex(temp[ACT], hum[ACT], false), -40.0, 80.0);
if (millis() > FIRST_MIN_MAX)
{
if (temp[ACT] < temp[MIN]) if (temp[ACT] < temp[MIN])
temp[MIN] = temp[ACT]; temp[MIN] = temp[ACT];
if (temp[ACT] > temp[MAX]) if (temp[ACT] > temp[MAX])
temp[MAX] = temp[ACT]; temp[MAX] = temp[ACT];
hum[ACT] = constrain(dht.readHumidity(), 0.0, 100.0);
if (hum[ACT] < hum[MIN]) if (hum[ACT] < hum[MIN])
hum[MIN] = hum[ACT]; hum[MIN] = hum[ACT];
if (hum[ACT] > hum[MAX]) if (hum[ACT] > hum[MAX])
hum[MAX] = hum[ACT]; hum[MAX] = hum[ACT];
heat[ACT] = constrain(dht.computeHeatIndex(temp[ACT], hum[ACT], false), -40.0, 80.0);
if (heat[ACT] < heat[MIN]) if (heat[ACT] < heat[MIN])
heat[MIN] = heat[ACT]; heat[MIN] = heat[ACT];
if (heat[ACT] > heat[MAX]) if (heat[ACT] > heat[MAX])
heat[MAX] = heat[ACT]; heat[MAX] = heat[ACT];
}
} }

Loading…
Cancel
Save