2024-05-10 07:13:12 -05:00
|
|
|
#include "configuration.h"
|
|
|
|
|
|
2025-04-28 18:35:13 -05:00
|
|
|
#if !MESHTASTIC_EXCLUDE_ENVIRONMENTAL_SENSOR && __has_include(<Adafruit_SHT4x.h>)
|
2024-05-10 07:13:12 -05:00
|
|
|
|
|
|
|
|
#include "../mesh/generated/meshtastic/telemetry.pb.h"
|
|
|
|
|
#include "SHT4XSensor.h"
|
|
|
|
|
#include "TelemetrySensor.h"
|
2024-05-14 21:07:44 +02:00
|
|
|
#include <Adafruit_SHT4x.h>
|
2024-05-10 07:13:12 -05:00
|
|
|
|
|
|
|
|
SHT4XSensor::SHT4XSensor() : TelemetrySensor(meshtastic_TelemetrySensorType_SHT4X, "SHT4X") {}
|
|
|
|
|
|
2026-01-04 12:15:53 +01:00
|
|
|
bool SHT4XSensor::initDevice(TwoWire *bus, ScanI2C::FoundDevice *dev)
|
|
|
|
|
{
|
|
|
|
|
LOG_INFO("Init sensor: %s", sensorName);
|
|
|
|
|
|
|
|
|
|
uint32_t serialNumber = 0;
|
|
|
|
|
|
|
|
|
|
status = sht4x.begin(bus);
|
|
|
|
|
if (!status) {
|
|
|
|
|
return status;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
serialNumber = sht4x.readSerial();
|
|
|
|
|
if (serialNumber != 0) {
|
|
|
|
|
LOG_DEBUG("serialNumber : %x", serialNumber);
|
|
|
|
|
status = 1;
|
|
|
|
|
} else {
|
|
|
|
|
LOG_DEBUG("Error trying to execute readSerial(): ");
|
|
|
|
|
status = 0;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
initI2CSensor();
|
2025-10-13 18:09:33 +02:00
|
|
|
return status;
|
2024-05-10 07:13:12 -05:00
|
|
|
}
|
|
|
|
|
|
2026-01-04 12:15:53 +01:00
|
|
|
bool SHT4XSensor::getMetrics(meshtastic_Telemetry *measurement)
|
|
|
|
|
{
|
|
|
|
|
measurement->variant.environment_metrics.has_temperature = true;
|
|
|
|
|
measurement->variant.environment_metrics.has_relative_humidity = true;
|
2024-08-16 17:15:51 -05:00
|
|
|
|
2026-01-04 12:15:53 +01:00
|
|
|
sensors_event_t humidity, temp;
|
|
|
|
|
sht4x.getEvent(&humidity, &temp);
|
|
|
|
|
measurement->variant.environment_metrics.temperature = temp.temperature;
|
|
|
|
|
measurement->variant.environment_metrics.relative_humidity = humidity.relative_humidity;
|
|
|
|
|
return true;
|
2024-05-10 07:13:12 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endif
|