#include "configuration.h" #if !MESHTASTIC_EXCLUDE_ENVIRONMENTAL_SENSOR && __has_include() #include "../mesh/generated/meshtastic/telemetry.pb.h" #include "LPS22HBSensor.h" #include "TelemetrySensor.h" #include #include LPS22HBSensor::LPS22HBSensor() : TelemetrySensor(meshtastic_TelemetrySensorType_LPS22, "LPS22HB") {} bool LPS22HBSensor::initDevice(TwoWire *bus, ScanI2C::FoundDevice *dev) { LOG_INFO("Init sensor: %s", sensorName); status = lps22hb.begin_I2C(dev->address.address, bus); if (!status) { return status; } lps22hb.setDataRate(LPS22_RATE_10_HZ); initI2CSensor(); return status; } bool LPS22HBSensor::getMetrics(meshtastic_Telemetry *measurement) { measurement->variant.environment_metrics.has_temperature = true; measurement->variant.environment_metrics.has_barometric_pressure = true; sensors_event_t temp; sensors_event_t pressure; lps22hb.getEvent(&pressure, &temp); measurement->variant.environment_metrics.temperature = temp.temperature; measurement->variant.environment_metrics.barometric_pressure = pressure.pressure; return true; } #endif