2020-11-10 17:38:33 +01:00
|
|
|
//
|
|
|
|
// Created by lukas on 10.11.20.
|
|
|
|
//
|
|
|
|
|
|
|
|
#include "Heating.h"
|
|
|
|
#include "Pins.h"
|
|
|
|
|
|
|
|
void Heating::init(Temperature *tempsensor) {
|
|
|
|
mFanWaiting = false;
|
|
|
|
|
|
|
|
mHeizungTicker.attach(10, [&tempsensor, this]() {
|
|
|
|
// shedule this function because tempread is blocking
|
|
|
|
schedule_function([this, &tempsensor](){
|
|
|
|
// check temperature
|
|
|
|
Serial.println("checking humidity");
|
|
|
|
const float hum = tempsensor->getHum();
|
|
|
|
if (hum == -1) return;
|
|
|
|
|
|
|
|
Serial.print("humidity read: ");
|
|
|
|
Serial.println(hum);
|
|
|
|
|
2020-11-14 21:21:22 +01:00
|
|
|
if (hum > 65.0) {
|
2020-11-10 17:38:33 +01:00
|
|
|
// turn off active turnoff timers
|
|
|
|
mLuefterTicker.detach();
|
2020-11-14 21:21:22 +01:00
|
|
|
Serial.println("heating should run now!");
|
2020-11-10 17:38:33 +01:00
|
|
|
// turn on heating and fan
|
|
|
|
digitalWrite(LuefterPin, HIGH);
|
|
|
|
digitalWrite(HeizungPin, HIGH);
|
|
|
|
|
|
|
|
// if fan waiting detach its ticker
|
|
|
|
if (mFanWaiting) {
|
|
|
|
mLuefterTicker.detach();
|
|
|
|
mFanWaiting = false;
|
|
|
|
}
|
2020-11-14 21:21:22 +01:00
|
|
|
} else if (hum < 60.0) {
|
2020-11-10 17:38:33 +01:00
|
|
|
// if humidity too low turn off heating and fan after 60secs
|
|
|
|
digitalWrite(HeizungPin, LOW);
|
2020-11-14 21:21:22 +01:00
|
|
|
Serial.println("heating should NOT run now!");
|
2020-11-10 17:38:33 +01:00
|
|
|
if (!mFanWaiting) {
|
|
|
|
mFanWaiting = true;
|
|
|
|
mLuefterTicker.once(60, []() {
|
|
|
|
// turn off fan
|
|
|
|
digitalWrite(LuefterPin, LOW);
|
|
|
|
Serial.println("turning off fan");
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|