unify sensor parameter names

This commit is contained in:
andreas 2023-10-31 15:32:08 +01:00
parent f606b78929
commit 9d3390b086
3 changed files with 169 additions and 116 deletions

View File

@ -41,6 +41,52 @@ class GwConfigHandler: public GwConfigDefinitions{
unsigned long getSaltBase(){return saltBase;} unsigned long getSaltBase(){return saltBase;}
~GwConfigHandler(); ~GwConfigHandler();
bool userChangesAllowed(){return allowChanges;} bool userChangesAllowed(){return allowChanges;}
template <typename T>
bool getValue(T & target, const String &name, int defaultv=0){
GwConfigInterface *i=getConfigItem(name);
if (!i){
target=(T)defaultv;
return false;
}
target=(T)(i->asInt());
return true;
}
bool getValue(int &target, const String &name, int defaultv=0){
GwConfigInterface *i=getConfigItem(name);
if (!i){
target=defaultv;
return false;
}
target=i->asInt();
return true;
}
bool getValue(long &target, const String &name, long defaultv=0){
GwConfigInterface *i=getConfigItem(name);
if (!i){
target=defaultv;
return false;
}
target=i->asInt();
return true;
}
bool getValue(bool &target, const String name, bool defaultv=false){
GwConfigInterface *i=getConfigItem(name);
if (!i){
target=defaultv;
return false;
}
target=i->asBoolean();
return true;
}
bool getValue(String &target, const String name, const String &defaultv=""){
GwConfigInterface *i=getConfigItem(name);
if (!i){
target=defaultv;
return false;
}
target=i->asString();
return true;
}
private: private:
unsigned long saltBase=0; unsigned long saltBase=0;
void populateConfigs(GwConfigInterface **); void populateConfigs(GwConfigInterface **);

View File

@ -24,75 +24,86 @@
#ifndef GWIIC_SCL #ifndef GWIIC_SCL
#define GWIIC_SCL -1 #define GWIIC_SCL -1
#endif #endif
#define CFG_GET(cfg,name,prefix) \
cfg->getValue(name, GwConfigDefinitions::prefix ## name)
#define CSHT3X(name) \
CFG_GET(config,name,SHT3X)
#define CQMP6988(name) \
CFG_GET(config,name,QMP6988)
#define CBME280(name) \
CFG_GET(config,name,BME280)
class SHT3XConfig{ class SHT3XConfig{
public: public:
String tempTransducer; String tmNam;
String humidTransducer; String huNam;
int iid; int iid;
bool tempActive; bool tmAct;
bool humidActive; bool huAct;
long interval; long intv;
tN2kHumiditySource humiditySource; tN2kHumiditySource huSrc;
tN2kTempSource tempSource; tN2kTempSource tmSrc;
SHT3XConfig(GwConfigHandler *config){ SHT3XConfig(GwConfigHandler *config){
tempTransducer=config->getString(GwConfigDefinitions::SHT3XTempName); CSHT3X(tmNam);
humidTransducer=config->getString(GwConfigDefinitions::SHT3XHumidName); CSHT3X(huNam);
iid=config->getInt(GwConfigDefinitions::SHT3Xiid,99); CSHT3X(iid);
tempActive=config->getBool(GwConfigDefinitions::iicSHT3XTemp); CSHT3X(tmAct);
humidActive=config->getBool(GwConfigDefinitions::iicSHT3XHumid); CSHT3X(huAct);
interval=config->getInt(GwConfigDefinitions::SHT3Xinterval); CSHT3X(intv);
interval*=1000; intv*=1000;
humiditySource=(tN2kHumiditySource)(config->getInt(GwConfigDefinitions::SHT3XHumSource)); CSHT3X(huSrc);
tempSource=(tN2kTempSource)(config->getInt(GwConfigDefinitions::SHT3XTempSource)); CSHT3X(tmSrc);
} }
}; };
class QMP6988Config{ class QMP6988Config{
public: public:
String transducer="Pressure"; String prNam="Pressure";
int iid=99; int iid=99;
bool active=true; bool prAct=true;
long interval=2000; long intv=2000;
tN2kPressureSource source=tN2kPressureSource::N2kps_Atmospheric; tN2kPressureSource source=tN2kPressureSource::N2kps_Atmospheric;
float offset=0; float prOff=0;
QMP6988Config(GwConfigHandler *config){ QMP6988Config(GwConfigHandler *config){
transducer=config->getString(GwConfigDefinitions::QMP6988PName); CQMP6988(prNam);
iid=config->getInt(GwConfigDefinitions::QMP6988iid); CQMP6988(iid);
active=config->getBool(GwConfigDefinitions::QMP6988act); CQMP6988(prAct);
interval=config->getInt(GwConfigDefinitions::QMP6988interval); CQMP6988(intv);
interval*=1000; intv*=1000;
offset=config->getInt(GwConfigDefinitions::QMP6988POffset); CQMP6988(prOff);
} }
}; };
class BME280Config{ class BME280Config{
public: public:
bool pressureActive=true; bool prAct=true;
bool tempActive=true; bool tmAct=true;
bool humidActive=true; bool huAct=true;
tN2kTempSource tempSource=tN2kTempSource::N2kts_InsideTemperature; tN2kTempSource tmSrc=tN2kTempSource::N2kts_InsideTemperature;
tN2kHumiditySource humidSource=tN2kHumiditySource::N2khs_InsideHumidity; tN2kHumiditySource huSrc=tN2kHumiditySource::N2khs_InsideHumidity;
tN2kPressureSource pressureSource=tN2kPressureSource::N2kps_Atmospheric; tN2kPressureSource prSrc=tN2kPressureSource::N2kps_Atmospheric;
int iid=99; int iid=99;
long interval=2000; long intv=2000;
String tempXdrName="Temperature"; String tmNam="Temperature";
String humidXdrName="Humidity"; String huNam="Humidity";
String pressXdrName="Pressure"; String prNam="Pressure";
float tempOffset=0; float tmOff=0;
float pressureOffset=0; float prOff=0;
BME280Config(GwConfigHandler *config){ BME280Config(GwConfigHandler *config){
pressureActive=config->getBool(GwConfigDefinitions::iicBME280Press); CBME280(prAct);
tempActive=config->getBool(GwConfigDefinitions::iicBME280Temp); CBME280(tmAct);
humidActive=config->getBool(GwConfigDefinitions::iicBME280Humid); CBME280(huAct);
tempSource=(tN2kTempSource)config->getInt(GwConfigDefinitions::BME280TSource); CBME280(tmSrc);
humidSource=(tN2kHumiditySource)config->getInt(GwConfigDefinitions::BME280HumSource); CBME280(huSrc);
iid=config->getInt(GwConfigDefinitions::BME280iid); CBME280(iid);
interval=1000*config->getInt(GwConfigDefinitions::BME280interval); CBME280(intv);
tempXdrName=config->getString(GwConfigDefinitions::BME280TempName); intv*=1000;
humidXdrName=config->getString(GwConfigDefinitions::BME280HumidName); CBME280(tmNam);
pressXdrName=config->getString(GwConfigDefinitions::BME280PressName); CBME280(huNam);
tempOffset=config->getInt(GwConfigDefinitions::BME280TOffset); CBME280(prNam);
pressureOffset=config->getInt(GwConfigDefinitions::BME280POffset); CBME280(tmOff);
CBME280(prOff);
} }
}; };
void runIicTask(GwApi *api); void runIicTask(GwApi *api);
@ -108,38 +119,38 @@ void initIicTask(GwApi *api){
api->addCapability("SHT3X","true"); api->addCapability("SHT3X","true");
LOG_DEBUG(GwLog::LOG,"SHT3X configured"); LOG_DEBUG(GwLog::LOG,"SHT3X configured");
SHT3XConfig sht3xConfig(api->getConfig()); SHT3XConfig sht3xConfig(api->getConfig());
if (sht3xConfig.humidActive && ! sht3xConfig.humidTransducer.isEmpty()){ if (sht3xConfig.huAct && ! sht3xConfig.humidTransducer.isEmpty()){
LOG_DEBUG(GwLog::DEBUG,"SHT3X humidity measure active, adding capability and xdr mappings"); LOG_DEBUG(GwLog::DEBUG,"SHT3X humidity measure active, adding capability and xdr mappings");
//add XDR mapping for humidity //add XDR mapping for humidity
GwXDRMappingDef xdr; GwXDRMappingDef xdr;
xdr.category=GwXDRCategory::XDRHUMIDITY; xdr.category=GwXDRCategory::XDRHUMIDITY;
xdr.direction=GwXDRMappingDef::M_FROM2K; xdr.direction=GwXDRMappingDef::M_FROM2K;
xdr.field=GWXDRFIELD_HUMIDITY_ACTUALHUMIDITY; xdr.field=GWXDRFIELD_HUMIDITY_ACTUALHUMIDITY;
xdr.selector=(int)sht3xConfig.humiditySource; xdr.selector=(int)sht3xConfig.huSrc;
xdr.instanceMode=GwXDRMappingDef::IS_SINGLE; xdr.instanceMode=GwXDRMappingDef::IS_SINGLE;
xdr.instanceId=sht3xConfig.iid; xdr.instanceId=sht3xConfig.iid;
xdr.xdrName=sht3xConfig.humidTransducer; xdr.xdrName=sht3xConfig.humidTransducer;
api->addXdrMapping(xdr); api->addXdrMapping(xdr);
} }
if (sht3xConfig.tempActive && ! sht3xConfig.tempTransducer.isEmpty()){ if (sht3xConfig.tmAct && ! sht3xConfig.tName.isEmpty()){
LOG_DEBUG(GwLog::DEBUG,"SHT3X temperature measure active, adding capability and xdr mappings"); LOG_DEBUG(GwLog::DEBUG,"SHT3X temperature measure active, adding capability and xdr mappings");
//add XDR mapping for humidity //add XDR mapping for humidity
GwXDRMappingDef xdr; GwXDRMappingDef xdr;
xdr.category=GwXDRCategory::XDRTEMP; xdr.category=GwXDRCategory::XDRTEMP;
xdr.direction=GwXDRMappingDef::M_FROM2K; xdr.direction=GwXDRMappingDef::M_FROM2K;
xdr.field=GWXDRFIELD_TEMPERATURE_ACTUALTEMPERATURE; xdr.field=GWXDRFIELD_TEMPERATURE_ACTUALTEMPERATURE;
xdr.selector=(int)sht3xConfig.tempSource; xdr.selector=(int)sht3xConfig.tmSrc;
xdr.instanceMode=GwXDRMappingDef::IS_SINGLE; xdr.instanceMode=GwXDRMappingDef::IS_SINGLE;
xdr.instanceId=sht3xConfig.iid; xdr.instanceId=sht3xConfig.iid;
xdr.xdrName=sht3xConfig.tempTransducer; xdr.xdrName=sht3xConfig.tName;
api->addXdrMapping(xdr); api->addXdrMapping(xdr);
} }
if (sht3xConfig.tempActive || sht3xConfig.humidActive) addTask=true; if (sht3xConfig.tmAct || sht3xConfig.huAct) addTask=true;
#endif #endif
#ifdef GWQMP6988 #ifdef GWQMP6988
api->addCapability("QMP6988","true"); api->addCapability("QMP6988","true");
QMP6988Config qmp6988Config(api->getConfig()); QMP6988Config qmp6988Config(api->getConfig());
if (qmp6988Config.active) { if (qmp6988Config.prAct) {
LOG_DEBUG(GwLog::LOG,"QMP6988 configured, adding capability and xdr mappings"); LOG_DEBUG(GwLog::LOG,"QMP6988 configured, adding capability and xdr mappings");
addTask=true; addTask=true;
GwXDRMappingDef xdr; GwXDRMappingDef xdr;
@ -148,7 +159,7 @@ void initIicTask(GwApi *api){
xdr.selector=(int)qmp6988Config.source; xdr.selector=(int)qmp6988Config.source;
xdr.instanceId=qmp6988Config.iid; xdr.instanceId=qmp6988Config.iid;
xdr.instanceMode=GwXDRMappingDef::IS_SINGLE; xdr.instanceMode=GwXDRMappingDef::IS_SINGLE;
xdr.xdrName=qmp6988Config.transducer; xdr.xdrName=qmp6988Config.prName;
api->addXdrMapping(xdr); api->addXdrMapping(xdr);
} }
else{ else{
@ -159,42 +170,42 @@ void initIicTask(GwApi *api){
api->addCapability("BME280","true"); api->addCapability("BME280","true");
BME280Config bme280Config(api->getConfig()); BME280Config bme280Config(api->getConfig());
bool bme280Active=false; bool bme280Active=false;
if (bme280Config.pressureActive){ if (bme280Config.prAct){
LOG_DEBUG(GwLog::DEBUG,"BME280 pressure active, adding capability and xdr mapping"); LOG_DEBUG(GwLog::DEBUG,"BME280 pressure active, adding capability and xdr mapping");
bme280Active=true; bme280Active=true;
GwXDRMappingDef xdr; GwXDRMappingDef xdr;
xdr.category=GwXDRCategory::XDRPRESSURE; xdr.category=GwXDRCategory::XDRPRESSURE;
xdr.direction=GwXDRMappingDef::M_FROM2K; xdr.direction=GwXDRMappingDef::M_FROM2K;
xdr.selector=(int)bme280Config.pressureSource; xdr.selector=(int)bme280Config.prSrc;
xdr.instanceId=bme280Config.iid; xdr.instanceId=bme280Config.iid;
xdr.instanceMode=GwXDRMappingDef::IS_SINGLE; xdr.instanceMode=GwXDRMappingDef::IS_SINGLE;
xdr.xdrName=bme280Config.pressXdrName; xdr.xdrName=bme280Config.prNam;
api->addXdrMapping(xdr); api->addXdrMapping(xdr);
} }
if (bme280Config.tempActive){ if (bme280Config.tmAct){
LOG_DEBUG(GwLog::DEBUG,"BME280 temperature active, adding capability and xdr mapping"); LOG_DEBUG(GwLog::DEBUG,"BME280 temperature active, adding capability and xdr mapping");
bme280Active=true; bme280Active=true;
GwXDRMappingDef xdr; GwXDRMappingDef xdr;
xdr.category=GwXDRCategory::XDRTEMP; xdr.category=GwXDRCategory::XDRTEMP;
xdr.direction=GwXDRMappingDef::M_FROM2K; xdr.direction=GwXDRMappingDef::M_FROM2K;
xdr.field=GWXDRFIELD_TEMPERATURE_ACTUALTEMPERATURE; xdr.field=GWXDRFIELD_TEMPERATURE_ACTUALTEMPERATURE;
xdr.selector=(int)bme280Config.tempSource; xdr.selector=(int)bme280Config.tmSrc;
xdr.instanceMode=GwXDRMappingDef::IS_SINGLE; xdr.instanceMode=GwXDRMappingDef::IS_SINGLE;
xdr.instanceId=bme280Config.iid; xdr.instanceId=bme280Config.iid;
xdr.xdrName=bme280Config.tempXdrName; xdr.xdrName=bme280Config.tmNam;
api->addXdrMapping(xdr); api->addXdrMapping(xdr);
} }
if (bme280Config.humidActive){ if (bme280Config.huAct){
LOG_DEBUG(GwLog::DEBUG,"BME280 humidity active, adding capability and xdr mapping"); LOG_DEBUG(GwLog::DEBUG,"BME280 humidity active, adding capability and xdr mapping");
bme280Active=true; bme280Active=true;
GwXDRMappingDef xdr; GwXDRMappingDef xdr;
xdr.category=GwXDRCategory::XDRHUMIDITY; xdr.category=GwXDRCategory::XDRHUMIDITY;
xdr.direction=GwXDRMappingDef::M_FROM2K; xdr.direction=GwXDRMappingDef::M_FROM2K;
xdr.field=GWXDRFIELD_HUMIDITY_ACTUALHUMIDITY; xdr.field=GWXDRFIELD_HUMIDITY_ACTUALHUMIDITY;
xdr.selector=(int)bme280Config.humidSource; xdr.selector=(int)bme280Config.huSrc;
xdr.instanceMode=GwXDRMappingDef::IS_SINGLE; xdr.instanceMode=GwXDRMappingDef::IS_SINGLE;
xdr.instanceId=bme280Config.iid; xdr.instanceId=bme280Config.iid;
xdr.xdrName=bme280Config.humidXdrName; xdr.xdrName=bme280Config.huNam;
api->addXdrMapping(xdr); api->addXdrMapping(xdr);
} }
if (! bme280Active){ if (! bme280Active){
@ -231,12 +242,12 @@ void runIicTask(GwApi *api){
int addr=GWSHT3X; int addr=GWSHT3X;
if (addr < 0) addr=0x44; //default if (addr < 0) addr=0x44; //default
SHT3XConfig sht3xConfig(config); SHT3XConfig sht3xConfig(config);
if (sht3xConfig.humidActive || sht3xConfig.tempActive){ if (sht3xConfig.huAct || sht3xConfig.tmAct){
sht3x=new SHT3X(); sht3x=new SHT3X();
sht3x->init(addr,&Wire); sht3x->init(addr,&Wire);
LOG_DEBUG(GwLog::LOG,"initialized SHT3X at address %d, interval %ld",(int)addr,sht3xConfig.interval); LOG_DEBUG(GwLog::LOG,"initialized SHT3X at address %d, intv %ld",(int)addr,sht3xConfig.intv);
runLoop=true; runLoop=true;
timers.addAction(sht3xConfig.interval,[logger,api,sht3x,sht3xConfig,counterId](){ timers.addAction(sht3xConfig.intv,[logger,api,sht3x,sht3xConfig,counterId](){
int rt=0; int rt=0;
if ((rt=sht3x->get())==0){ if ((rt=sht3x->get())==0){
double temp=sht3x->cTemp; double temp=sht3x->cTemp;
@ -244,13 +255,13 @@ void runIicTask(GwApi *api){
double humid=sht3x->humidity; double humid=sht3x->humidity;
LOG_DEBUG(GwLog::DEBUG,"SHT3X measure temp=%2.1f, humid=%2.0f",(float)temp,(float)humid); LOG_DEBUG(GwLog::DEBUG,"SHT3X measure temp=%2.1f, humid=%2.0f",(float)temp,(float)humid);
tN2kMsg msg; tN2kMsg msg;
if (sht3xConfig.humidActive){ if (sht3xConfig.huAct){
SetN2kHumidity(msg,1,sht3xConfig.iid,sht3xConfig.humiditySource,humid); SetN2kHumidity(msg,1,sht3xConfig.iid,sht3xConfig.huSrc,humid);
api->sendN2kMessage(msg); api->sendN2kMessage(msg);
api->increment(counterId,"SHT3Xhum"); api->increment(counterId,"SHT3Xhum");
} }
if (sht3xConfig.tempActive){ if (sht3xConfig.tmAct){
SetN2kTemperature(msg,1,sht3xConfig.iid,sht3xConfig.tempSource,temp); SetN2kTemperature(msg,1,sht3xConfig.iid,sht3xConfig.tmSrc,temp);
api->sendN2kMessage(msg); api->sendN2kMessage(msg);
api->increment(counterId,"SHT3Xtemp"); api->increment(counterId,"SHT3Xtemp");
} }
@ -266,14 +277,14 @@ void runIicTask(GwApi *api){
if (qaddr < 0) qaddr=0x56; if (qaddr < 0) qaddr=0x56;
QMP6988Config qmp6988Config(api->getConfig()); QMP6988Config qmp6988Config(api->getConfig());
QMP6988 *qmp6988=nullptr; QMP6988 *qmp6988=nullptr;
if (qmp6988Config.active){ if (qmp6988Config.prAct){
runLoop=true; runLoop=true;
qmp6988=new QMP6988(); qmp6988=new QMP6988();
qmp6988->init(qaddr,&Wire); qmp6988->init(qaddr,&Wire);
LOG_DEBUG(GwLog::LOG,"initialized QMP6988 at address %d, interval %ld",qaddr,qmp6988Config.interval); LOG_DEBUG(GwLog::LOG,"initialized QMP6988 at address %d, intv %ld",qaddr,qmp6988Config.intv);
timers.addAction(qmp6988Config.interval,[logger,api,qmp6988,qmp6988Config,counterId](){ timers.addAction(qmp6988Config.intv,[logger,api,qmp6988,qmp6988Config,counterId](){
float pressure=qmp6988->calcPressure(); float pressure=qmp6988->calcPressure();
float computed=pressure+qmp6988Config.offset; float computed=pressure+qmp6988Config.prOff;
LOG_DEBUG(GwLog::DEBUG,"qmp6988 measure %2.0fPa, computed %2.0fPa",pressure,computed); LOG_DEBUG(GwLog::DEBUG,"qmp6988 measure %2.0fPa, computed %2.0fPa",pressure,computed);
tN2kMsg msg; tN2kMsg msg;
SetN2kPressure(msg,1,qmp6988Config.iid,tN2kPressureSource::N2kps_Atmospheric,computed); SetN2kPressure(msg,1,qmp6988Config.iid,tN2kPressureSource::N2kps_Atmospheric,computed);
@ -286,41 +297,41 @@ void runIicTask(GwApi *api){
int baddr=GWBME280; int baddr=GWBME280;
if (baddr < 0) baddr=0x76; if (baddr < 0) baddr=0x76;
BME280Config bme280Config(api->getConfig()); BME280Config bme280Config(api->getConfig());
if (bme280Config.tempActive || bme280Config.pressureActive|| bme280Config.humidActive){ if (bme280Config.tmAct || bme280Config.prAct|| bme280Config.huAct){
Adafruit_BME280 *bme280=new Adafruit_BME280(); Adafruit_BME280 *bme280=new Adafruit_BME280();
if (bme280->begin(baddr,&Wire)){ if (bme280->begin(baddr,&Wire)){
uint32_t sensorId=bme280->sensorID(); uint32_t sensorId=bme280->sensorID();
bool hasHumidity=sensorId == 0x60; //BME280, else BMP280 bool hasHumidity=sensorId == 0x60; //BME280, else BMP280
if (bme280Config.tempOffset != 0){ if (bme280Config.tmOff != 0){
bme280->setTemperatureCompensation(bme280Config.tempOffset); bme280->setTemperatureCompensation(bme280Config.tmOff);
} }
if (hasHumidity || bme280Config.tempActive || bme280Config.pressureActive) if (hasHumidity || bme280Config.tmAct || bme280Config.prAct)
{ {
LOG_DEBUG(GwLog::LOG, "initialized BME280 at %d, sensorId 0x%x", baddr, sensorId); LOG_DEBUG(GwLog::LOG, "initialized BME280 at %d, sensorId 0x%x", baddr, sensorId);
timers.addAction(bme280Config.interval, [logger, api, bme280, bme280Config, counterId, hasHumidity](){ timers.addAction(bme280Config.intv, [logger, api, bme280, bme280Config, counterId, hasHumidity](){
if (bme280Config.pressureActive){ if (bme280Config.prAct){
float pressure=bme280->readPressure(); float pressure=bme280->readPressure();
float computed=pressure+bme280Config.pressureOffset; float computed=pressure+bme280Config.prOff;
LOG_DEBUG(GwLog::DEBUG,"BME280 measure %2.0fPa, computed %2.0fPa",pressure,computed); LOG_DEBUG(GwLog::DEBUG,"BME280 measure %2.0fPa, computed %2.0fPa",pressure,computed);
tN2kMsg msg; tN2kMsg msg;
SetN2kPressure(msg,1,bme280Config.iid,bme280Config.pressureSource,computed); SetN2kPressure(msg,1,bme280Config.iid,bme280Config.prSrc,computed);
api->sendN2kMessage(msg); api->sendN2kMessage(msg);
api->increment(counterId,"BME280press"); api->increment(counterId,"BME280press");
} }
if (bme280Config.tempActive){ if (bme280Config.tmAct){
float temperature=bme280->readTemperature(); //offset is handled internally float temperature=bme280->readTemperature(); //offset is handled internally
temperature=CToKelvin(temperature); temperature=CToKelvin(temperature);
LOG_DEBUG(GwLog::DEBUG,"BME280 measure temp=%2.1f",temperature); LOG_DEBUG(GwLog::DEBUG,"BME280 measure temp=%2.1f",temperature);
tN2kMsg msg; tN2kMsg msg;
SetN2kTemperature(msg,1,bme280Config.iid,bme280Config.tempSource,temperature); SetN2kTemperature(msg,1,bme280Config.iid,bme280Config.tmSrc,temperature);
api->sendN2kMessage(msg); api->sendN2kMessage(msg);
api->increment(counterId,"BME280temp"); api->increment(counterId,"BME280temp");
} }
if (bme280Config.humidActive && hasHumidity){ if (bme280Config.huAct && hasHumidity){
float humidity=bme280->readHumidity(); float humidity=bme280->readHumidity();
LOG_DEBUG(GwLog::DEBUG,"BME280 read humid=%02.0f",humidity); LOG_DEBUG(GwLog::DEBUG,"BME280 read humid=%02.0f",humidity);
tN2kMsg msg; tN2kMsg msg;
SetN2kHumidity(msg,1,bme280Config.iid,bme280Config.humidSource,humidity); SetN2kHumidity(msg,1,bme280Config.iid,bme280Config.huSrc,humidity);
api->sendN2kMessage(msg); api->sendN2kMessage(msg);
api->increment(counterId,"BME280hum"); api->increment(counterId,"BME280hum");
} }

View File

@ -1,6 +1,6 @@
[ [
{ {
"name": "iicSHT3XTemp", "name": "SHT3XtmAct",
"label": "SHT3X Temp", "label": "SHT3X Temp",
"type": "boolean", "type": "boolean",
"default": "true", "default": "true",
@ -11,7 +11,7 @@
} }
}, },
{ {
"name": "SHT3XTempSource", "name": "SHT3XtmSrc",
"label": "SHT3X Temp Type", "label": "SHT3X Temp Type",
"type": "list", "type": "list",
"default": "2", "default": "2",
@ -88,7 +88,7 @@
} }
}, },
{ {
"name": "iicSHT3XHumid", "name": "SHT3XhuAct",
"label": "SHT3X Humidity", "label": "SHT3X Humidity",
"type": "boolean", "type": "boolean",
"default": "true", "default": "true",
@ -99,13 +99,9 @@
} }
}, },
{ {
"name": "SHT3XHumSource", "name": "SHT3XhuSrc",
"label": "SHT3X Humid Type", "label": "SHT3X Humid Type",
"type": "list",
"description": "the NMEA2000 source type for the humidity",
"default": "0",
"list":[ "list":[
{"l":"InsideHumidity","v":"0"},
{"l":"OutsideHumidity","v":"1"}, {"l":"OutsideHumidity","v":"1"},
{"l":"Undef","v":"0xff"} {"l":"Undef","v":"0xff"}
], ],
@ -129,7 +125,7 @@
} }
}, },
{ {
"name": "SHT3Xinterval", "name": "SHT3Xintv",
"label": "SHT3X Interval", "label": "SHT3X Interval",
"type": "number", "type": "number",
"default": 2, "default": 2,
@ -143,7 +139,7 @@
} }
}, },
{ {
"name": "SHT3XTempName", "name": "SHT3XtmNam",
"label": "SHT3X Temp XDR", "label": "SHT3X Temp XDR",
"type": "String", "type": "String",
"default": "Temp", "default": "Temp",
@ -154,7 +150,7 @@
} }
}, },
{ {
"name": "SHT3XHumidName", "name": "SHT3XhuNam",
"label": "SHT3X Humid XDR", "label": "SHT3X Humid XDR",
"type": "String", "type": "String",
"default": "Humidity", "default": "Humidity",
@ -165,7 +161,7 @@
} }
}, },
{ {
"name": "QMP6988act", "name": "QMP6988prAct",
"label": "QMP6988 pressure", "label": "QMP6988 pressure",
"description": "activate the QMP6988 pressure measurement", "description": "activate the QMP6988 pressure measurement",
"type":"boolean", "type":"boolean",
@ -190,7 +186,7 @@
} }
}, },
{ {
"name": "QMP6988interval", "name": "QMP6988intv",
"label": "QMP6988 Interval", "label": "QMP6988 Interval",
"type": "number", "type": "number",
"default": 2, "default": 2,
@ -204,7 +200,7 @@
} }
}, },
{ {
"name": "QMP6988PName", "name": "QMP6988prNam",
"label": "QMP6988 Pressure XDR", "label": "QMP6988 Pressure XDR",
"type": "String", "type": "String",
"default": "Pressure", "default": "Pressure",
@ -215,7 +211,7 @@
} }
}, },
{ {
"name":"QMP6988POffset", "name":"QMP6988prOff",
"label":"QMP6988 Pressure Offset", "label":"QMP6988 Pressure Offset",
"type": "number", "type": "number",
"description": "offset (in pa) to be added to the QMP6988 pressure measurements", "description": "offset (in pa) to be added to the QMP6988 pressure measurements",
@ -226,7 +222,7 @@
} }
}, },
{ {
"name": "iicBME280Temp", "name": "BME280tmAct",
"label": "BME280 Temp", "label": "BME280 Temp",
"type": "boolean", "type": "boolean",
"default": "true", "default": "true",
@ -237,7 +233,7 @@
} }
}, },
{ {
"name": "BME280TSource", "name": "BME280tmSrc",
"label": "BME280 Temp Type", "label": "BME280 Temp Type",
"type": "list", "type": "list",
"default": "2", "default": "2",
@ -314,7 +310,7 @@
} }
}, },
{ {
"name":"BME280TOffset", "name":"BME280tmOff",
"label":"BME280 Temperature Offset", "label":"BME280 Temperature Offset",
"type": "number", "type": "number",
"description": "offset (in °) to be added to the BME280 temperature measurements", "description": "offset (in °) to be added to the BME280 temperature measurements",
@ -325,7 +321,7 @@
} }
}, },
{ {
"name": "iicBME280Humid", "name": "BME280huAct",
"label": "BME280 Humidity", "label": "BME280 Humidity",
"type": "boolean", "type": "boolean",
"default": "true", "default": "true",
@ -336,7 +332,7 @@
} }
}, },
{ {
"name": "BME280HumSource", "name": "BME280huSrc",
"label": "BME280 Humid Type", "label": "BME280 Humid Type",
"type": "list", "type": "list",
"description": "the NMEA2000 source type for the humidity", "description": "the NMEA2000 source type for the humidity",
@ -352,7 +348,7 @@
} }
}, },
{ {
"name": "iicBME280Press", "name": "BME280prAct",
"label": "BME280 Pressure", "label": "BME280 Pressure",
"type": "boolean", "type": "boolean",
"default": "true", "default": "true",
@ -363,7 +359,7 @@
} }
}, },
{ {
"name":"BME280POffset", "name":"BME280prOff",
"label":"BME280 Pressure Offset", "label":"BME280 Pressure Offset",
"type": "number", "type": "number",
"description": "offset (in pa) to be added to the BME280 pressure measurements", "description": "offset (in pa) to be added to the BME280 pressure measurements",
@ -388,7 +384,7 @@
} }
}, },
{ {
"name": "BME280interval", "name": "BME280intv",
"label": "BME280 Interval", "label": "BME280 Interval",
"type": "number", "type": "number",
"default": 2, "default": 2,
@ -402,7 +398,7 @@
} }
}, },
{ {
"name": "BME280TempName", "name": "BME280tmNam",
"label": "BME280 Temp XDR", "label": "BME280 Temp XDR",
"type": "String", "type": "String",
"default": "Temp", "default": "Temp",
@ -413,7 +409,7 @@
} }
}, },
{ {
"name": "BME280HumidName", "name": "BME280huNam",
"label": "BME280 Humid XDR", "label": "BME280 Humid XDR",
"type": "String", "type": "String",
"default": "Humidity", "default": "Humidity",
@ -424,7 +420,7 @@
} }
}, },
{ {
"name": "BME280PressName", "name": "BME280prNam",
"label": "BME280 Pressure XDR", "label": "BME280 Pressure XDR",
"type": "String", "type": "String",
"default": "Pressure", "default": "Pressure",