/* Theengs OpenMQTTGateway - We Unite Sensors in One Open-Source Interface Act as a gateway between your 433mhz, infrared IR, BLE, LoRa signal and one interface like an MQTT broker Send and receiving command by MQTT This is the Climate Addon: - Measures Temperature, Humidity and Pressure - Generates Values for: Temperature in degrees C and F, Humidity in %, Pressure in Pa, Altitude in Meter and Feet - Required Hardware Module: HTU21 - Required Library: SparkFun HTU21 Library v1.1.3 Connection Schemata: -------------------- HTU21 ------> ESP8266 ============================================== Vcc ---------> Vu (5V) GND ---------> GND SCL ---------> D1 SDA ---------> D2 This file is part of OpenMQTTGateway. OpenMQTTGateway is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. OpenMQTTGateway 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. You should have received a copy of the GNU General Public License along with this program. If not, see . */ #include "User_config.h" #ifdef ZsensorHTU21 # include # include "SparkFunHTU21D.h" # include "TheengsCommon.h" # include "Wire.h" // Library for communication with I2C / TWI devices # include "config_HTU21.h" //Time used to wait for an interval before resending measured values unsigned long timehtu21 = 0; //Global sensor object HTU21D htuSensor; void setupZsensorHTU21() { delay(10); // Gives the Sensor enough time to turn on THEENGS_LOG_NOTICE(F("HTU21 Initialized - begin()" CR)); # if defined(ESP32) Wire.begin(I2C_SDA, I2C_SCL); htuSensor.begin(Wire); # else htuSensor.begin(); # endif } void MeasureTempHum() { if (millis() > (timehtu21 + TimeBetweenReadinghtu21)) { THEENGS_LOG_TRACE(F("Read HTU21 Sensor" CR)); timehtu21 = millis(); static float persisted_htu_tempc; static float persisted_htu_hum; float HtuTempC = htuSensor.readTemperature(); float HtuHum = htuSensor.readHumidity(); if (HtuTempC >= 998 || HtuHum >= 998) { THEENGS_LOG_ERROR(F("Failed to read from sensor HTU21!" CR)); return; } // Check if reads failed and exit early (to try again). if (isnan(HtuTempC) || isnan(HtuHum)) { THEENGS_LOG_ERROR(F("Failed to read from sensor HTU21!" CR)); } else { THEENGS_LOG_NOTICE(F("Creating HTU21 buffer" CR)); StaticJsonDocument HTU21dataBuffer; JsonObject HTU21data = HTU21dataBuffer.to(); // Generate Temperature in degrees C if (HtuTempC != persisted_htu_tempc || htu21_always) { float HtuTempF = (HtuTempC * 1.8) + 32; HTU21data["tempc"] = (float)HtuTempC; HTU21data["tempf"] = (float)HtuTempF; } else { THEENGS_LOG_NOTICE(F("Same Temp. Don't send it" CR)); } // Generate Humidity in percent if (HtuHum != persisted_htu_hum || htu21_always) { HTU21data["hum"] = (float)HtuHum; } else { THEENGS_LOG_NOTICE(F("Same Humidity. Don't send it" CR)); } HTU21data["origin"] = HTUTOPIC; enqueueJsonObject(HTU21data); } persisted_htu_tempc = HtuTempC; persisted_htu_hum = HtuHum; } } #endif