2025-01-18 14:10:13 +01:00
|
|
|
#include "configuration.h"
|
|
|
|
|
|
2025-04-28 18:35:13 -05:00
|
|
|
#if !MESHTASTIC_EXCLUDE_ENVIRONMENTAL_SENSOR && __has_include(<DFRobot_RainfallSensor.h>)
|
2025-01-18 14:10:13 +01:00
|
|
|
|
|
|
|
|
#include "../mesh/generated/meshtastic/telemetry.pb.h"
|
|
|
|
|
#include "DFRobotGravitySensor.h"
|
|
|
|
|
#include "TelemetrySensor.h"
|
|
|
|
|
#include <DFRobot_RainfallSensor.h>
|
|
|
|
|
#include <string>
|
|
|
|
|
|
|
|
|
|
DFRobotGravitySensor::DFRobotGravitySensor() : TelemetrySensor(meshtastic_TelemetrySensorType_DFROBOT_RAIN, "DFROBOT_RAIN") {}
|
|
|
|
|
|
2025-10-13 18:09:33 +02:00
|
|
|
DFRobotGravitySensor::~DFRobotGravitySensor()
|
2025-01-18 14:10:13 +01:00
|
|
|
{
|
2025-10-13 18:09:33 +02:00
|
|
|
if (gravity) {
|
2025-11-21 10:42:15 +01:00
|
|
|
#pragma GCC diagnostic push
|
|
|
|
|
#pragma GCC diagnostic ignored "-Wdelete-non-virtual-dtor"
|
2025-10-13 18:09:33 +02:00
|
|
|
delete gravity;
|
2025-11-21 10:42:15 +01:00
|
|
|
#pragma GCC diagnostic pop
|
2025-10-13 18:09:33 +02:00
|
|
|
gravity = nullptr;
|
2025-01-18 14:10:13 +01:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2025-10-13 18:09:33 +02:00
|
|
|
bool DFRobotGravitySensor::initDevice(TwoWire *bus, ScanI2C::FoundDevice *dev)
|
2025-01-18 14:10:13 +01:00
|
|
|
{
|
2025-10-13 18:09:33 +02:00
|
|
|
LOG_INFO("Init sensor: %s", sensorName);
|
|
|
|
|
|
|
|
|
|
gravity = new DFRobot_RainfallSensor_I2C(bus);
|
|
|
|
|
status = gravity->begin();
|
|
|
|
|
|
|
|
|
|
LOG_DEBUG("%s VID: %x, PID: %x, Version: %s", sensorName, gravity->vid, gravity->pid, gravity->getFirmwareVersion().c_str());
|
|
|
|
|
|
|
|
|
|
initI2CSensor();
|
|
|
|
|
return status;
|
2025-01-18 14:10:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
bool DFRobotGravitySensor::getMetrics(meshtastic_Telemetry *measurement)
|
|
|
|
|
{
|
2025-10-13 18:09:33 +02:00
|
|
|
if (!gravity) {
|
|
|
|
|
LOG_ERROR("DFRobotGravitySensor not initialized");
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
2025-01-18 14:10:13 +01:00
|
|
|
measurement->variant.environment_metrics.has_rainfall_1h = true;
|
|
|
|
|
measurement->variant.environment_metrics.has_rainfall_24h = true;
|
|
|
|
|
|
2025-10-13 18:09:33 +02:00
|
|
|
measurement->variant.environment_metrics.rainfall_1h = gravity->getRainfall(1);
|
|
|
|
|
measurement->variant.environment_metrics.rainfall_24h = gravity->getRainfall(24);
|
2025-01-18 14:10:13 +01:00
|
|
|
|
|
|
|
|
LOG_INFO("Rain 1h: %f mm", measurement->variant.environment_metrics.rainfall_1h);
|
|
|
|
|
LOG_INFO("Rain 24h: %f mm", measurement->variant.environment_metrics.rainfall_24h);
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
#endif
|