mirror of
https://github.com/meshtastic/firmware.git
synced 2025-12-20 09:43:03 +00:00
* rework I2C sensor init the goal is to only instantiate sensors that are pressend to save memory. side effacts: - easyer sensor integration (less C&P code) - nodeTelemetrySensorsMap can be removed when all devices are migrated * add missing ifdef * refactor a bunch of more sensors RAM -816 Flash -916 * fix build for t1000 * refactor more sensors RAM -192 Flash -60 * improve error handling Flash -112 * fix build * fix build * fix IndicatorSensor * fix tracker-t1000-e build not sure what magic is used but it works * Apply suggestion from @Copilot Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Apply suggestion from @Copilot Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Apply suggestion from @Copilot Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Update src/modules/Telemetry/Sensor/DFRobotGravitySensor.h Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com> * Fix --------- Co-authored-by: Ben Meadors <benmmeadors@gmail.com> Co-authored-by: Copilot <175728472+Copilot@users.noreply.github.com>
88 lines
2.9 KiB
C++
88 lines
2.9 KiB
C++
#include "configuration.h"
|
|
|
|
#if !MESHTASTIC_EXCLUDE_ENVIRONMENTAL_SENSOR && __has_include(<Adafruit_BMP3XX.h>)
|
|
|
|
#include "BMP3XXSensor.h"
|
|
|
|
BMP3XXSensor::BMP3XXSensor() : TelemetrySensor(meshtastic_TelemetrySensorType_BMP3XX, "BMP3XX") {}
|
|
|
|
bool BMP3XXSensor::initDevice(TwoWire *bus, ScanI2C::FoundDevice *dev)
|
|
{
|
|
LOG_INFO("Init sensor: %s", sensorName);
|
|
|
|
// Get a singleton instance and initialise the bmp3xx
|
|
if (bmp3xx == nullptr) {
|
|
bmp3xx = BMP3XXSingleton::GetInstance();
|
|
}
|
|
status = bmp3xx->begin_I2C(dev->address.address, bus);
|
|
if (!status) {
|
|
return status;
|
|
}
|
|
|
|
// set up oversampling and filter initialization
|
|
bmp3xx->setTemperatureOversampling(BMP3_OVERSAMPLING_4X);
|
|
bmp3xx->setPressureOversampling(BMP3_OVERSAMPLING_8X);
|
|
bmp3xx->setIIRFilterCoeff(BMP3_IIR_FILTER_COEFF_3);
|
|
bmp3xx->setOutputDataRate(BMP3_ODR_25_HZ);
|
|
|
|
// take a couple of initial readings to settle the sensor filters
|
|
for (int i = 0; i < 3; i++) {
|
|
bmp3xx->performReading();
|
|
}
|
|
initI2CSensor();
|
|
return status;
|
|
}
|
|
|
|
bool BMP3XXSensor::getMetrics(meshtastic_Telemetry *measurement)
|
|
{
|
|
if (bmp3xx == nullptr) {
|
|
bmp3xx = BMP3XXSingleton::GetInstance();
|
|
}
|
|
if ((int)measurement->which_variant == meshtastic_Telemetry_environment_metrics_tag) {
|
|
bmp3xx->performReading();
|
|
|
|
measurement->variant.environment_metrics.has_temperature = true;
|
|
measurement->variant.environment_metrics.has_barometric_pressure = true;
|
|
measurement->variant.environment_metrics.has_relative_humidity = false;
|
|
|
|
measurement->variant.environment_metrics.temperature = static_cast<float>(bmp3xx->temperature);
|
|
measurement->variant.environment_metrics.barometric_pressure = static_cast<float>(bmp3xx->pressure) / 100.0F;
|
|
measurement->variant.environment_metrics.relative_humidity = 0.0f;
|
|
|
|
LOG_DEBUG("BMP3XX getMetrics id: %i temp: %.1f press %.1f", measurement->which_variant,
|
|
measurement->variant.environment_metrics.temperature,
|
|
measurement->variant.environment_metrics.barometric_pressure);
|
|
} else {
|
|
LOG_DEBUG("BMP3XX getMetrics id: %i", measurement->which_variant);
|
|
}
|
|
return true;
|
|
}
|
|
|
|
// Get a singleton wrapper for an Adafruit_bmp3xx
|
|
BMP3XXSingleton *BMP3XXSingleton::GetInstance()
|
|
{
|
|
if (pinstance == nullptr) {
|
|
pinstance = new BMP3XXSingleton();
|
|
}
|
|
return pinstance;
|
|
}
|
|
|
|
BMP3XXSingleton::BMP3XXSingleton() {}
|
|
|
|
BMP3XXSingleton::~BMP3XXSingleton() {}
|
|
|
|
BMP3XXSingleton *BMP3XXSingleton::pinstance{nullptr};
|
|
|
|
bool BMP3XXSingleton::performReading()
|
|
{
|
|
bool result = Adafruit_BMP3XX::performReading();
|
|
if (result) {
|
|
double atmospheric = this->pressure / 100.0;
|
|
altitudeAmslMetres = 44330.0 * (1.0 - pow(atmospheric / SEAL_LEVEL_HPA, 0.1903));
|
|
} else {
|
|
altitudeAmslMetres = 0.0;
|
|
}
|
|
return result;
|
|
}
|
|
|
|
#endif |