move BME280 to separate file
This commit is contained in:
parent
b581fe9537
commit
899aa3fe4a
|
@ -0,0 +1,200 @@
|
||||||
|
#include "GwBME280.h"
|
||||||
|
#ifdef _GWIIC
|
||||||
|
#if defined(GWBME280) || defined(GWBME2801) || defined(GWBME2802)|| defined(GWBME2803)|| defined(GWBME2804)
|
||||||
|
#define _GWBME280
|
||||||
|
#else
|
||||||
|
#undef _GWBME280
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#undef _GWBME280
|
||||||
|
#undef GWBME280
|
||||||
|
#undef GWBME2801
|
||||||
|
#undef GWBME2802
|
||||||
|
#undef GWBME2803
|
||||||
|
#undef GWBME2804
|
||||||
|
#endif
|
||||||
|
#ifdef _GWBME280
|
||||||
|
#include <Adafruit_BME280.h>
|
||||||
|
#endif
|
||||||
|
#ifdef _GWBME280
|
||||||
|
class BME280Config : public SensorBase{
|
||||||
|
public:
|
||||||
|
bool prAct=true;
|
||||||
|
bool tmAct=true;
|
||||||
|
bool huAct=true;
|
||||||
|
tN2kTempSource tmSrc=tN2kTempSource::N2kts_InsideTemperature;
|
||||||
|
tN2kHumiditySource huSrc=tN2kHumiditySource::N2khs_InsideHumidity;
|
||||||
|
tN2kPressureSource prSrc=tN2kPressureSource::N2kps_Atmospheric;
|
||||||
|
String tmNam="Temperature";
|
||||||
|
String huNam="Humidity";
|
||||||
|
String prNam="Pressure";
|
||||||
|
float tmOff=0;
|
||||||
|
float prOff=0;
|
||||||
|
Adafruit_BME280 *device=nullptr;
|
||||||
|
uint32_t sensorId=-1;
|
||||||
|
BME280Config(GwApi * api, const String &prfx):SensorBase(api,prfx){
|
||||||
|
}
|
||||||
|
virtual bool isActive(){return prAct||huAct||tmAct;}
|
||||||
|
virtual bool initDevice(GwApi *api,TwoWire *wire){
|
||||||
|
GwLog *logger=api->getLogger();
|
||||||
|
device= new Adafruit_BME280();
|
||||||
|
if (! device->begin(addr,wire)){
|
||||||
|
LOG_DEBUG(GwLog::ERROR,"unable to initialize %s at %d",prefix.c_str(),addr);
|
||||||
|
delete device;
|
||||||
|
device=nullptr;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (tmOff != 0){
|
||||||
|
device->setTemperatureCompensation(tmOff);
|
||||||
|
}
|
||||||
|
sensorId=device->sensorID();
|
||||||
|
LOG_DEBUG(GwLog::LOG, "initialized %s at %d, sensorId 0x%x", prefix.c_str(), addr, sensorId);
|
||||||
|
return (huAct && sensorId == 0x60) || tmAct || prAct;
|
||||||
|
}
|
||||||
|
virtual bool preinit(GwApi * api){
|
||||||
|
GwLog *logger=api->getLogger();
|
||||||
|
LOG_DEBUG(GwLog::LOG,"%s configured",prefix.c_str());
|
||||||
|
api->addCapability(prefix,"true");
|
||||||
|
addPressureXdr(api,*this);
|
||||||
|
addTempXdr(api,*this);
|
||||||
|
addHumidXdr(api,*this);
|
||||||
|
return isActive();
|
||||||
|
}
|
||||||
|
virtual void measure(GwApi *api, TwoWire *wire, int counterId)
|
||||||
|
{
|
||||||
|
if (!device)
|
||||||
|
return;
|
||||||
|
GwLog *logger = api->getLogger();
|
||||||
|
if (prAct)
|
||||||
|
{
|
||||||
|
float pressure = device->readPressure();
|
||||||
|
float computed = pressure + prOff;
|
||||||
|
LOG_DEBUG(GwLog::DEBUG, "%s measure %2.0fPa, computed %2.0fPa", prefix.c_str(), pressure, computed);
|
||||||
|
sendN2kPressure(api, *this, computed, counterId);
|
||||||
|
}
|
||||||
|
if (tmAct)
|
||||||
|
{
|
||||||
|
float temperature = device->readTemperature(); // offset is handled internally
|
||||||
|
temperature = CToKelvin(temperature);
|
||||||
|
LOG_DEBUG(GwLog::DEBUG, "%s measure temp=%2.1f", prefix.c_str(), temperature);
|
||||||
|
sendN2kTemperature(api, *this, temperature, counterId);
|
||||||
|
}
|
||||||
|
if (huAct && sensorId == 0x60)
|
||||||
|
{
|
||||||
|
float humidity = device->readHumidity();
|
||||||
|
LOG_DEBUG(GwLog::DEBUG, "%s read humid=%02.0f", prefix.c_str(), humidity);
|
||||||
|
sendN2kHumidity(api, *this, humidity, counterId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
virtual void readConfig(GwConfigHandler *cfg) override
|
||||||
|
{
|
||||||
|
if (prefix == "BME2801")
|
||||||
|
{
|
||||||
|
busId = 1;
|
||||||
|
addr = 0x76;
|
||||||
|
#undef CG
|
||||||
|
#define CG(name) CFG_GET(name, BME2801)
|
||||||
|
CG(prAct);
|
||||||
|
CG(tmAct);
|
||||||
|
CG(huAct);
|
||||||
|
CG(tmSrc);
|
||||||
|
CG(huSrc);
|
||||||
|
CG(iid);
|
||||||
|
CG(intv);
|
||||||
|
CG(tmNam);
|
||||||
|
CG(huNam);
|
||||||
|
CG(prNam);
|
||||||
|
CG(tmOff);
|
||||||
|
CG(prOff);
|
||||||
|
ok=true;
|
||||||
|
}
|
||||||
|
if (prefix == "BME2802")
|
||||||
|
{
|
||||||
|
busId = 1;
|
||||||
|
addr = 0x77;
|
||||||
|
#undef CG
|
||||||
|
#define CG(name) CFG_GET(name, BME2802)
|
||||||
|
CG(prAct);
|
||||||
|
CG(tmAct);
|
||||||
|
CG(huAct);
|
||||||
|
CG(tmSrc);
|
||||||
|
CG(huSrc);
|
||||||
|
CG(iid);
|
||||||
|
CG(intv);
|
||||||
|
CG(tmNam);
|
||||||
|
CG(huNam);
|
||||||
|
CG(prNam);
|
||||||
|
CG(tmOff);
|
||||||
|
CG(prOff);
|
||||||
|
ok=true;
|
||||||
|
}
|
||||||
|
if (prefix == "BME2803")
|
||||||
|
{
|
||||||
|
busId = 2;
|
||||||
|
addr = 0x76;
|
||||||
|
#undef CG
|
||||||
|
#define CG(name) CFG_GET(name, BME2803)
|
||||||
|
CG(prAct);
|
||||||
|
CG(tmAct);
|
||||||
|
CG(huAct);
|
||||||
|
CG(tmSrc);
|
||||||
|
CG(huSrc);
|
||||||
|
CG(iid);
|
||||||
|
CG(intv);
|
||||||
|
CG(tmNam);
|
||||||
|
CG(huNam);
|
||||||
|
CG(prNam);
|
||||||
|
CG(tmOff);
|
||||||
|
CG(prOff);
|
||||||
|
ok=true;
|
||||||
|
}
|
||||||
|
if (prefix == "BME2804")
|
||||||
|
{
|
||||||
|
busId = 1;
|
||||||
|
addr = 0x77;
|
||||||
|
#undef CG
|
||||||
|
#define CG(name) CFG_GET(name, BME2804)
|
||||||
|
CG(prAct);
|
||||||
|
CG(tmAct);
|
||||||
|
CG(huAct);
|
||||||
|
CG(tmSrc);
|
||||||
|
CG(huSrc);
|
||||||
|
CG(iid);
|
||||||
|
CG(intv);
|
||||||
|
CG(tmNam);
|
||||||
|
CG(huNam);
|
||||||
|
CG(prNam);
|
||||||
|
CG(tmOff);
|
||||||
|
CG(prOff);
|
||||||
|
ok=true;
|
||||||
|
}
|
||||||
|
intv *= 1000;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
void registerBME280(GwApi *api,SensorList &sensors){
|
||||||
|
GwLog *logger=api->getLogger();
|
||||||
|
#if defined(GWBME280) || defined(GWBME2801)
|
||||||
|
BME280Config *cfg=new BME280Config(api,"BME2801");
|
||||||
|
sensors.add(api,cfg);
|
||||||
|
LOG_DEBUG(GwLog::LOG,"%s configured %d",cfg->prefix.c_str(),(int)cfg->ok);
|
||||||
|
#endif
|
||||||
|
#if defined(GWBME2802)
|
||||||
|
BME280Config *cfg=new BME280Config(api,"BME2802");
|
||||||
|
sensors.add(api,cfg);
|
||||||
|
#endif
|
||||||
|
#if defined(GWBME2803)
|
||||||
|
BME280Config *cfg=new BME280Config(api,"BME2803");
|
||||||
|
sensors.add(api,cfg);
|
||||||
|
#endif
|
||||||
|
#if defined(GWBME2804)
|
||||||
|
BME280Config *cfg=new BME280Config(api,"BME2804");
|
||||||
|
sensors.add(api,cfg);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
void registerBME280(GwApi *api,SensorList &sensors){
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
#ifndef _GWBME280_H
|
||||||
|
#define _GWBME280_H
|
||||||
|
#include "GwIicSensors.h"
|
||||||
|
void registerBME280(GwApi *api,SensorList &sensors);
|
||||||
|
#endif
|
|
@ -0,0 +1,140 @@
|
||||||
|
#ifndef _GWIICSENSSORS_H
|
||||||
|
#define _GWIICSENSSORS_H
|
||||||
|
#include "GwApi.h"
|
||||||
|
#include "N2kMessages.h"
|
||||||
|
#include "GwXdrTypeMappings.h"
|
||||||
|
#include "GwHardware.h"
|
||||||
|
#ifdef _GWIIC
|
||||||
|
#include <Wire.h>
|
||||||
|
#endif
|
||||||
|
#ifndef GWIIC_SDA
|
||||||
|
#define GWIIC_SDA -1
|
||||||
|
#endif
|
||||||
|
#ifndef GWIIC_SCL
|
||||||
|
#define GWIIC_SCL -1
|
||||||
|
#endif
|
||||||
|
#ifndef GWIIC_SDA2
|
||||||
|
#define GWIIC_SDA2 -1
|
||||||
|
#endif
|
||||||
|
#ifndef GWIIC_SCL2
|
||||||
|
#define GWIIC_SCL2 -1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define CFG_GET(name,prefix) \
|
||||||
|
cfg->getValue(name, GwConfigDefinitions::prefix ## name)
|
||||||
|
|
||||||
|
template <class CFG>
|
||||||
|
bool addPressureXdr(GwApi *api, CFG &cfg)
|
||||||
|
{
|
||||||
|
if (! cfg.prAct) return false;
|
||||||
|
if (cfg.prNam.isEmpty()){
|
||||||
|
api->getLogger()->logDebug(GwLog::LOG, "pressure active for %s, no xdr mapping", cfg.prefix.c_str());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
api->getLogger()->logDebug(GwLog::LOG, "adding pressure xdr mapping for %s", cfg.prefix.c_str());
|
||||||
|
GwXDRMappingDef xdr;
|
||||||
|
xdr.category = GwXDRCategory::XDRPRESSURE;
|
||||||
|
xdr.direction = GwXDRMappingDef::M_FROM2K;
|
||||||
|
xdr.selector = (int)cfg.prSrc;
|
||||||
|
xdr.instanceId = cfg.iid;
|
||||||
|
xdr.instanceMode = GwXDRMappingDef::IS_SINGLE;
|
||||||
|
xdr.xdrName = cfg.prNam;
|
||||||
|
api->addXdrMapping(xdr);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class CFG>
|
||||||
|
bool addTempXdr(GwApi *api, CFG &cfg)
|
||||||
|
{
|
||||||
|
if (!cfg.tmAct) return false;
|
||||||
|
if (cfg.tmNam.isEmpty()){
|
||||||
|
api->getLogger()->logDebug(GwLog::LOG, "temperature active for %s, no xdr mapping", cfg.prefix.c_str());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
api->getLogger()->logDebug(GwLog::LOG, "adding temperature xdr mapping for %s", cfg.prefix.c_str());
|
||||||
|
GwXDRMappingDef xdr;
|
||||||
|
xdr.category = GwXDRCategory::XDRTEMP;
|
||||||
|
xdr.direction = GwXDRMappingDef::M_FROM2K;
|
||||||
|
xdr.field = GWXDRFIELD_TEMPERATURE_ACTUALTEMPERATURE;
|
||||||
|
xdr.selector = (int)cfg.tmSrc;
|
||||||
|
xdr.instanceMode = GwXDRMappingDef::IS_SINGLE;
|
||||||
|
xdr.instanceId = cfg.iid;
|
||||||
|
xdr.xdrName = cfg.tmNam;
|
||||||
|
api->addXdrMapping(xdr);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class CFG>
|
||||||
|
bool addHumidXdr(GwApi *api, CFG &cfg)
|
||||||
|
{
|
||||||
|
if (! cfg.huAct) return false;
|
||||||
|
if (cfg.huNam.isEmpty()){
|
||||||
|
api->getLogger()->logDebug(GwLog::LOG, "humidity active for %s, no xdr mapping", cfg.prefix.c_str());
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
api->getLogger()->logDebug(GwLog::LOG, "adding humidity xdr mapping for %s", cfg.prefix.c_str());
|
||||||
|
GwXDRMappingDef xdr;
|
||||||
|
xdr.category = GwXDRCategory::XDRHUMIDITY;
|
||||||
|
xdr.direction = GwXDRMappingDef::M_FROM2K;
|
||||||
|
xdr.field = GWXDRFIELD_HUMIDITY_ACTUALHUMIDITY;
|
||||||
|
xdr.selector = (int)cfg.huSrc;
|
||||||
|
xdr.instanceMode = GwXDRMappingDef::IS_SINGLE;
|
||||||
|
xdr.instanceId = cfg.iid;
|
||||||
|
xdr.xdrName = cfg.huNam;
|
||||||
|
api->addXdrMapping(xdr);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class CFG>
|
||||||
|
void sendN2kHumidity(GwApi *api,CFG &cfg,double value, int counterId){
|
||||||
|
tN2kMsg msg;
|
||||||
|
SetN2kHumidity(msg,1,cfg.iid,cfg.huSrc,value);
|
||||||
|
api->sendN2kMessage(msg);
|
||||||
|
api->increment(counterId,cfg.prefix+String("hum"));
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class CFG>
|
||||||
|
void sendN2kPressure(GwApi *api,CFG &cfg,double value, int counterId){
|
||||||
|
tN2kMsg msg;
|
||||||
|
SetN2kPressure(msg,1,cfg.iid,cfg.prSrc,value);
|
||||||
|
api->sendN2kMessage(msg);
|
||||||
|
api->increment(counterId,cfg.prefix+String("press"));
|
||||||
|
}
|
||||||
|
|
||||||
|
template <class CFG>
|
||||||
|
void sendN2kTemperature(GwApi *api,CFG &cfg,double value, int counterId){
|
||||||
|
tN2kMsg msg;
|
||||||
|
SetN2kTemperature(msg,1,cfg.iid,cfg.tmSrc,value);
|
||||||
|
api->sendN2kMessage(msg);
|
||||||
|
api->increment(counterId,cfg.prefix+String("temp"));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
class SensorBase{
|
||||||
|
public:
|
||||||
|
int busId=0;
|
||||||
|
int iid=99; //N2K instanceId
|
||||||
|
int addr=-1;
|
||||||
|
String prefix;
|
||||||
|
long intv=0;
|
||||||
|
bool ok=false;
|
||||||
|
virtual void readConfig(GwConfigHandler *cfg)=0;
|
||||||
|
SensorBase(GwApi *api,const String &prfx):prefix(prfx){
|
||||||
|
}
|
||||||
|
virtual bool isActive(){return false;};
|
||||||
|
virtual bool initDevice(GwApi *api,TwoWire *wire){return false;};
|
||||||
|
virtual bool preinit(GwApi * api){return false;}
|
||||||
|
virtual void measure(GwApi * api,TwoWire *wire, int counterId){};
|
||||||
|
virtual ~SensorBase(){}
|
||||||
|
};
|
||||||
|
|
||||||
|
class SensorList : public std::vector<SensorBase*>{
|
||||||
|
public:
|
||||||
|
void add(GwApi *api, SensorBase *sensor){
|
||||||
|
sensor->readConfig(api->getConfig());
|
||||||
|
push_back(sensor);
|
||||||
|
}
|
||||||
|
using std::vector<SensorBase*>::vector;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
|
@ -1,8 +1,9 @@
|
||||||
#include "GwIicTask.h"
|
#include "GwIicTask.h"
|
||||||
|
#include "GwIicSensors.h"
|
||||||
#include "GwHardware.h"
|
#include "GwHardware.h"
|
||||||
|
#include "GwBME280.h"
|
||||||
#include <map>
|
#include <map>
|
||||||
#ifdef _GWIIC
|
#ifdef _GWIIC
|
||||||
#include <Wire.h>
|
|
||||||
#if defined(GWSHT3X) || defined(GWSHT3X1) || defined(GWSHT3X2) || defined(GWSHT3X2) || defined(GWSHT3X4)
|
#if defined(GWSHT3X) || defined(GWSHT3X1) || defined(GWSHT3X2) || defined(GWSHT3X2) || defined(GWSHT3X4)
|
||||||
#define _GWSHT3X
|
#define _GWSHT3X
|
||||||
#else
|
#else
|
||||||
|
@ -13,11 +14,6 @@
|
||||||
#else
|
#else
|
||||||
#undef _GWQMP6988
|
#undef _GWQMP6988
|
||||||
#endif
|
#endif
|
||||||
#if defined(GWBME280) || defined(GWBME2801) || defined(GWBME2802)|| defined(GWBME2803)|| defined(GWBME2804)
|
|
||||||
#define _GWBME280
|
|
||||||
#else
|
|
||||||
#undef _GWBME280
|
|
||||||
#endif
|
|
||||||
#else
|
#else
|
||||||
#undef _GWSHT3X
|
#undef _GWSHT3X
|
||||||
#undef GWSHT3X
|
#undef GWSHT3X
|
||||||
|
@ -31,12 +27,6 @@
|
||||||
#undef GWQMP69882
|
#undef GWQMP69882
|
||||||
#undef GWQMP69883
|
#undef GWQMP69883
|
||||||
#undef GWQMP69884
|
#undef GWQMP69884
|
||||||
#undef _GWBME280
|
|
||||||
#undef GWBME280
|
|
||||||
#undef GWBME2801
|
|
||||||
#undef GWBME2802
|
|
||||||
#undef GWBME2803
|
|
||||||
#undef GWBME2804
|
|
||||||
#endif
|
#endif
|
||||||
#ifdef _GWSHT3X
|
#ifdef _GWSHT3X
|
||||||
#include "SHT3X.h"
|
#include "SHT3X.h"
|
||||||
|
@ -45,144 +35,7 @@
|
||||||
#include "QMP6988.h"
|
#include "QMP6988.h"
|
||||||
#endif
|
#endif
|
||||||
#include "GwTimer.h"
|
#include "GwTimer.h"
|
||||||
#include "N2kMessages.h"
|
|
||||||
#include "GwHardware.h"
|
#include "GwHardware.h"
|
||||||
#include "GwXdrTypeMappings.h"
|
|
||||||
#ifdef _GWBME280
|
|
||||||
#include <Adafruit_BME280.h>
|
|
||||||
#endif
|
|
||||||
|
|
||||||
|
|
||||||
template <class CFG>
|
|
||||||
bool addPressureXdr(GwApi *api, CFG &cfg)
|
|
||||||
{
|
|
||||||
if (! cfg.prAct) return false;
|
|
||||||
if (cfg.prNam.isEmpty()){
|
|
||||||
api->getLogger()->logDebug(GwLog::LOG, "pressure active for %s, no xdr mapping", cfg.prefix.c_str());
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
api->getLogger()->logDebug(GwLog::LOG, "adding pressure xdr mapping for %s", cfg.prefix.c_str());
|
|
||||||
GwXDRMappingDef xdr;
|
|
||||||
xdr.category = GwXDRCategory::XDRPRESSURE;
|
|
||||||
xdr.direction = GwXDRMappingDef::M_FROM2K;
|
|
||||||
xdr.selector = (int)cfg.prSrc;
|
|
||||||
xdr.instanceId = cfg.iid;
|
|
||||||
xdr.instanceMode = GwXDRMappingDef::IS_SINGLE;
|
|
||||||
xdr.xdrName = cfg.prNam;
|
|
||||||
api->addXdrMapping(xdr);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class CFG>
|
|
||||||
bool addTempXdr(GwApi *api, CFG &cfg)
|
|
||||||
{
|
|
||||||
if (!cfg.tmAct) return false;
|
|
||||||
if (cfg.tmNam.isEmpty()){
|
|
||||||
api->getLogger()->logDebug(GwLog::LOG, "temperature active for %s, no xdr mapping", cfg.prefix.c_str());
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
api->getLogger()->logDebug(GwLog::LOG, "adding temperature xdr mapping for %s", cfg.prefix.c_str());
|
|
||||||
GwXDRMappingDef xdr;
|
|
||||||
xdr.category = GwXDRCategory::XDRTEMP;
|
|
||||||
xdr.direction = GwXDRMappingDef::M_FROM2K;
|
|
||||||
xdr.field = GWXDRFIELD_TEMPERATURE_ACTUALTEMPERATURE;
|
|
||||||
xdr.selector = (int)cfg.tmSrc;
|
|
||||||
xdr.instanceMode = GwXDRMappingDef::IS_SINGLE;
|
|
||||||
xdr.instanceId = cfg.iid;
|
|
||||||
xdr.xdrName = cfg.tmNam;
|
|
||||||
api->addXdrMapping(xdr);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class CFG>
|
|
||||||
bool addHumidXdr(GwApi *api, CFG &cfg)
|
|
||||||
{
|
|
||||||
if (! cfg.huAct) return false;
|
|
||||||
if (cfg.huNam.isEmpty()){
|
|
||||||
api->getLogger()->logDebug(GwLog::LOG, "humidity active for %s, no xdr mapping", cfg.prefix.c_str());
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
api->getLogger()->logDebug(GwLog::LOG, "adding humidity xdr mapping for %s", cfg.prefix.c_str());
|
|
||||||
GwXDRMappingDef xdr;
|
|
||||||
xdr.category = GwXDRCategory::XDRHUMIDITY;
|
|
||||||
xdr.direction = GwXDRMappingDef::M_FROM2K;
|
|
||||||
xdr.field = GWXDRFIELD_HUMIDITY_ACTUALHUMIDITY;
|
|
||||||
xdr.selector = (int)cfg.huSrc;
|
|
||||||
xdr.instanceMode = GwXDRMappingDef::IS_SINGLE;
|
|
||||||
xdr.instanceId = cfg.iid;
|
|
||||||
xdr.xdrName = cfg.huNam;
|
|
||||||
api->addXdrMapping(xdr);
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class CFG>
|
|
||||||
void sendN2kHumidity(GwApi *api,CFG &cfg,double value, int counterId){
|
|
||||||
tN2kMsg msg;
|
|
||||||
SetN2kHumidity(msg,1,cfg.iid,cfg.huSrc,value);
|
|
||||||
api->sendN2kMessage(msg);
|
|
||||||
api->increment(counterId,cfg.prefix+String("hum"));
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class CFG>
|
|
||||||
void sendN2kPressure(GwApi *api,CFG &cfg,double value, int counterId){
|
|
||||||
tN2kMsg msg;
|
|
||||||
SetN2kPressure(msg,1,cfg.iid,cfg.prSrc,value);
|
|
||||||
api->sendN2kMessage(msg);
|
|
||||||
api->increment(counterId,cfg.prefix+String("press"));
|
|
||||||
}
|
|
||||||
|
|
||||||
template <class CFG>
|
|
||||||
void sendN2kTemperature(GwApi *api,CFG &cfg,double value, int counterId){
|
|
||||||
tN2kMsg msg;
|
|
||||||
SetN2kTemperature(msg,1,cfg.iid,cfg.tmSrc,value);
|
|
||||||
api->sendN2kMessage(msg);
|
|
||||||
api->increment(counterId,cfg.prefix+String("temp"));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
class SensorBase{
|
|
||||||
public:
|
|
||||||
int busId=0;
|
|
||||||
int iid=99; //N2K instanceId
|
|
||||||
int addr=-1;
|
|
||||||
String prefix;
|
|
||||||
long intv=0;
|
|
||||||
bool ok=false;
|
|
||||||
virtual void readConfig(GwConfigHandler *cfg)=0;
|
|
||||||
SensorBase(GwApi *api,const String &prfx):prefix(prfx){
|
|
||||||
}
|
|
||||||
virtual bool isActive(){return false;};
|
|
||||||
virtual bool initDevice(GwApi *api,TwoWire *wire){return false;};
|
|
||||||
virtual bool preinit(GwApi * api){return false;}
|
|
||||||
virtual void measure(GwApi * api,TwoWire *wire, int counterId){};
|
|
||||||
virtual ~SensorBase(){}
|
|
||||||
};
|
|
||||||
|
|
||||||
class SensorList : public std::vector<SensorBase*>{
|
|
||||||
public:
|
|
||||||
void add(GwApi *api, SensorBase *sensor){
|
|
||||||
sensor->readConfig(api->getConfig());
|
|
||||||
push_back(sensor);
|
|
||||||
}
|
|
||||||
using std::vector<SensorBase*>::vector;
|
|
||||||
};
|
|
||||||
|
|
||||||
#ifndef GWIIC_SDA
|
|
||||||
#define GWIIC_SDA -1
|
|
||||||
#endif
|
|
||||||
#ifndef GWIIC_SCL
|
|
||||||
#define GWIIC_SCL -1
|
|
||||||
#endif
|
|
||||||
#ifndef GWIIC_SDA2
|
|
||||||
#define GWIIC_SDA2 -1
|
|
||||||
#endif
|
|
||||||
#ifndef GWIIC_SCL2
|
|
||||||
#define GWIIC_SCL2 -1
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#define CFG_GET(name,prefix) \
|
|
||||||
cfg->getValue(name, GwConfigDefinitions::prefix ## name)
|
|
||||||
|
|
||||||
|
|
||||||
#ifdef _GWSHT3X
|
#ifdef _GWSHT3X
|
||||||
class SHT3XConfig : public SensorBase{
|
class SHT3XConfig : public SensorBase{
|
||||||
|
@ -401,187 +254,6 @@ class QMP6988Config : public SensorBase{
|
||||||
};
|
};
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#ifdef _GWBME280
|
|
||||||
class BME280Config : public SensorBase{
|
|
||||||
public:
|
|
||||||
bool prAct=true;
|
|
||||||
bool tmAct=true;
|
|
||||||
bool huAct=true;
|
|
||||||
tN2kTempSource tmSrc=tN2kTempSource::N2kts_InsideTemperature;
|
|
||||||
tN2kHumiditySource huSrc=tN2kHumiditySource::N2khs_InsideHumidity;
|
|
||||||
tN2kPressureSource prSrc=tN2kPressureSource::N2kps_Atmospheric;
|
|
||||||
String tmNam="Temperature";
|
|
||||||
String huNam="Humidity";
|
|
||||||
String prNam="Pressure";
|
|
||||||
float tmOff=0;
|
|
||||||
float prOff=0;
|
|
||||||
Adafruit_BME280 *device=nullptr;
|
|
||||||
uint32_t sensorId=-1;
|
|
||||||
BME280Config(GwApi * api, const String &prfx):SensorBase(api,prfx){
|
|
||||||
}
|
|
||||||
virtual bool isActive(){return prAct||huAct||tmAct;}
|
|
||||||
virtual bool initDevice(GwApi *api,TwoWire *wire){
|
|
||||||
GwLog *logger=api->getLogger();
|
|
||||||
device= new Adafruit_BME280();
|
|
||||||
if (! device->begin(addr,wire)){
|
|
||||||
LOG_DEBUG(GwLog::ERROR,"unable to initialize %s at %d",prefix.c_str(),addr);
|
|
||||||
delete device;
|
|
||||||
device=nullptr;
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
if (tmOff != 0){
|
|
||||||
device->setTemperatureCompensation(tmOff);
|
|
||||||
}
|
|
||||||
sensorId=device->sensorID();
|
|
||||||
LOG_DEBUG(GwLog::LOG, "initialized %s at %d, sensorId 0x%x", prefix.c_str(), addr, sensorId);
|
|
||||||
return (huAct && sensorId == 0x60) || tmAct || prAct;
|
|
||||||
}
|
|
||||||
virtual bool preinit(GwApi * api){
|
|
||||||
GwLog *logger=api->getLogger();
|
|
||||||
LOG_DEBUG(GwLog::LOG,"%s configured",prefix.c_str());
|
|
||||||
api->addCapability(prefix,"true");
|
|
||||||
addPressureXdr(api,*this);
|
|
||||||
addTempXdr(api,*this);
|
|
||||||
addHumidXdr(api,*this);
|
|
||||||
return isActive();
|
|
||||||
}
|
|
||||||
virtual void measure(GwApi *api, TwoWire *wire, int counterId)
|
|
||||||
{
|
|
||||||
if (!device)
|
|
||||||
return;
|
|
||||||
GwLog *logger = api->getLogger();
|
|
||||||
if (prAct)
|
|
||||||
{
|
|
||||||
float pressure = device->readPressure();
|
|
||||||
float computed = pressure + prOff;
|
|
||||||
LOG_DEBUG(GwLog::DEBUG, "%s measure %2.0fPa, computed %2.0fPa", prefix.c_str(), pressure, computed);
|
|
||||||
sendN2kPressure(api, *this, computed, counterId);
|
|
||||||
}
|
|
||||||
if (tmAct)
|
|
||||||
{
|
|
||||||
float temperature = device->readTemperature(); // offset is handled internally
|
|
||||||
temperature = CToKelvin(temperature);
|
|
||||||
LOG_DEBUG(GwLog::DEBUG, "%s measure temp=%2.1f", prefix.c_str(), temperature);
|
|
||||||
sendN2kTemperature(api, *this, temperature, counterId);
|
|
||||||
}
|
|
||||||
if (huAct && sensorId == 0x60)
|
|
||||||
{
|
|
||||||
float humidity = device->readHumidity();
|
|
||||||
LOG_DEBUG(GwLog::DEBUG, "%s read humid=%02.0f", prefix.c_str(), humidity);
|
|
||||||
sendN2kHumidity(api, *this, humidity, counterId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
virtual void readConfig(GwConfigHandler *cfg) override
|
|
||||||
{
|
|
||||||
if (prefix == "BME2801")
|
|
||||||
{
|
|
||||||
busId = 1;
|
|
||||||
addr = 0x76;
|
|
||||||
#undef CG
|
|
||||||
#define CG(name) CFG_GET(name, BME2801)
|
|
||||||
CG(prAct);
|
|
||||||
CG(tmAct);
|
|
||||||
CG(huAct);
|
|
||||||
CG(tmSrc);
|
|
||||||
CG(huSrc);
|
|
||||||
CG(iid);
|
|
||||||
CG(intv);
|
|
||||||
CG(tmNam);
|
|
||||||
CG(huNam);
|
|
||||||
CG(prNam);
|
|
||||||
CG(tmOff);
|
|
||||||
CG(prOff);
|
|
||||||
ok=true;
|
|
||||||
}
|
|
||||||
if (prefix == "BME2802")
|
|
||||||
{
|
|
||||||
busId = 1;
|
|
||||||
addr = 0x77;
|
|
||||||
#undef CG
|
|
||||||
#define CG(name) CFG_GET(name, BME2802)
|
|
||||||
CG(prAct);
|
|
||||||
CG(tmAct);
|
|
||||||
CG(huAct);
|
|
||||||
CG(tmSrc);
|
|
||||||
CG(huSrc);
|
|
||||||
CG(iid);
|
|
||||||
CG(intv);
|
|
||||||
CG(tmNam);
|
|
||||||
CG(huNam);
|
|
||||||
CG(prNam);
|
|
||||||
CG(tmOff);
|
|
||||||
CG(prOff);
|
|
||||||
ok=true;
|
|
||||||
}
|
|
||||||
if (prefix == "BME2803")
|
|
||||||
{
|
|
||||||
busId = 2;
|
|
||||||
addr = 0x76;
|
|
||||||
#undef CG
|
|
||||||
#define CG(name) CFG_GET(name, BME2803)
|
|
||||||
CG(prAct);
|
|
||||||
CG(tmAct);
|
|
||||||
CG(huAct);
|
|
||||||
CG(tmSrc);
|
|
||||||
CG(huSrc);
|
|
||||||
CG(iid);
|
|
||||||
CG(intv);
|
|
||||||
CG(tmNam);
|
|
||||||
CG(huNam);
|
|
||||||
CG(prNam);
|
|
||||||
CG(tmOff);
|
|
||||||
CG(prOff);
|
|
||||||
ok=true;
|
|
||||||
}
|
|
||||||
if (prefix == "BME2804")
|
|
||||||
{
|
|
||||||
busId = 1;
|
|
||||||
addr = 0x77;
|
|
||||||
#undef CG
|
|
||||||
#define CG(name) CFG_GET(name, BME2804)
|
|
||||||
CG(prAct);
|
|
||||||
CG(tmAct);
|
|
||||||
CG(huAct);
|
|
||||||
CG(tmSrc);
|
|
||||||
CG(huSrc);
|
|
||||||
CG(iid);
|
|
||||||
CG(intv);
|
|
||||||
CG(tmNam);
|
|
||||||
CG(huNam);
|
|
||||||
CG(prNam);
|
|
||||||
CG(tmOff);
|
|
||||||
CG(prOff);
|
|
||||||
ok=true;
|
|
||||||
}
|
|
||||||
intv *= 1000;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
void registerBME280(GwApi *api,SensorList &sensors){
|
|
||||||
GwLog *logger=api->getLogger();
|
|
||||||
#if defined(GWBME280) || defined(GWBME2801)
|
|
||||||
BME280Config *cfg=new BME280Config(api,"BME2801");
|
|
||||||
sensors.add(api,cfg);
|
|
||||||
LOG_DEBUG(GwLog::LOG,"%s configured %d",cfg->prefix.c_str(),(int)cfg->ok);
|
|
||||||
#endif
|
|
||||||
#if defined(GWBME2802)
|
|
||||||
BME280Config *cfg=new BME280Config(api,"BME2802");
|
|
||||||
sensors.add(api,cfg);
|
|
||||||
#endif
|
|
||||||
#if defined(GWBME2803)
|
|
||||||
BME280Config *cfg=new BME280Config(api,"BME2803");
|
|
||||||
sensors.add(api,cfg);
|
|
||||||
#endif
|
|
||||||
#if defined(GWBME2804)
|
|
||||||
BME280Config *cfg=new BME280Config(api,"BME2804");
|
|
||||||
sensors.add(api,cfg);
|
|
||||||
#endif
|
|
||||||
}
|
|
||||||
#else
|
|
||||||
void registerBME280(GwApi *api,SensorList &sensors){
|
|
||||||
}
|
|
||||||
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void runIicTask(GwApi *api);
|
void runIicTask(GwApi *api);
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue