Add BMP280 Sensor and deprecated PGN 130311 for Raymarine
This commit is contained in:
parent
0bb6898d6e
commit
dd13dd0418
|
@ -143,3 +143,22 @@
|
||||||
#error "both serial devices already in use"
|
#error "both serial devices already in use"
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#GROVE
|
||||||
|
#ifdef GWBMP280G1$GS$
|
||||||
|
#ifndef M5_GROOVEIIC$GS$
|
||||||
|
#define M5_GROOVEIIC$GS$
|
||||||
|
#endif
|
||||||
|
GROOVE_IIC(BMP280,$Z$,1)
|
||||||
|
#define _GWBMP280
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#GROVE
|
||||||
|
#ifdef GWBMP280G2$GS$
|
||||||
|
#ifndef M5_GROOVEIIC$GS$
|
||||||
|
#define M5_GROOVEIIC$GS$
|
||||||
|
#endif
|
||||||
|
GROOVE_IIC(BMP280,$Z$,2)
|
||||||
|
#define _GWBMP280
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -68,16 +68,20 @@ class BME280Config : public IICSensorBase{
|
||||||
if (!device)
|
if (!device)
|
||||||
return;
|
return;
|
||||||
GwLog *logger = api->getLogger();
|
GwLog *logger = api->getLogger();
|
||||||
|
float pressure = N2kDoubleNA;
|
||||||
|
float temperature = N2kDoubleNA;
|
||||||
|
float humidity = N2kDoubleNA;
|
||||||
|
float computed = N2kDoubleNA;
|
||||||
if (prAct)
|
if (prAct)
|
||||||
{
|
{
|
||||||
float pressure = device->readPressure();
|
pressure = device->readPressure();
|
||||||
float computed = pressure + prOff;
|
computed = pressure + prOff;
|
||||||
LOG_DEBUG(GwLog::DEBUG, "%s measure %2.0fPa, computed %2.0fPa", prefix.c_str(), pressure, computed);
|
LOG_DEBUG(GwLog::DEBUG, "%s measure %2.0fPa, computed %2.0fPa", prefix.c_str(), pressure, computed);
|
||||||
sendN2kPressure(api, *this, computed, counterId);
|
sendN2kPressure(api, *this, computed, counterId);
|
||||||
}
|
}
|
||||||
if (tmAct)
|
if (tmAct)
|
||||||
{
|
{
|
||||||
float temperature = device->readTemperature(); // offset is handled internally
|
temperature = device->readTemperature(); // offset is handled internally
|
||||||
temperature = CToKelvin(temperature);
|
temperature = CToKelvin(temperature);
|
||||||
LOG_DEBUG(GwLog::DEBUG, "%s measure temp=%2.1f", prefix.c_str(), temperature);
|
LOG_DEBUG(GwLog::DEBUG, "%s measure temp=%2.1f", prefix.c_str(), temperature);
|
||||||
sendN2kTemperature(api, *this, temperature, counterId);
|
sendN2kTemperature(api, *this, temperature, counterId);
|
||||||
|
@ -88,6 +92,10 @@ class BME280Config : public IICSensorBase{
|
||||||
LOG_DEBUG(GwLog::DEBUG, "%s read humid=%02.0f", prefix.c_str(), humidity);
|
LOG_DEBUG(GwLog::DEBUG, "%s read humid=%02.0f", prefix.c_str(), humidity);
|
||||||
sendN2kHumidity(api, *this, humidity, counterId);
|
sendN2kHumidity(api, *this, humidity, counterId);
|
||||||
}
|
}
|
||||||
|
if (tmAct || prAct || (huAct && sensorId == 0x60))
|
||||||
|
{
|
||||||
|
sendN2kEnvironmentalParameters(api, *this, temperature, humidity, computed,counterId);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
#define CFG280(prefix) \
|
#define CFG280(prefix) \
|
||||||
CFG_GET(prAct,prefix); \
|
CFG_GET(prAct,prefix); \
|
||||||
|
|
|
@ -0,0 +1,184 @@
|
||||||
|
#include "GwBMP280.h"
|
||||||
|
#ifdef _GWIIC
|
||||||
|
#if defined(GWBMP280) || defined(GWBMP28011) || defined(GWBMP28012)|| defined(GWBMP28021)|| defined(GWBMP28022)
|
||||||
|
#define _GWBMP280
|
||||||
|
#else
|
||||||
|
#undef _GWBMP280
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#undef _GWBMP280
|
||||||
|
#undef GWBMP280
|
||||||
|
#undef GWBMP28011
|
||||||
|
#undef GWBMP28012
|
||||||
|
#undef GWBMP28021
|
||||||
|
#undef GWBMP28022
|
||||||
|
#endif
|
||||||
|
#ifdef _GWBMP280
|
||||||
|
#include <Adafruit_BMP280.h>
|
||||||
|
#endif
|
||||||
|
#ifdef _GWBMP280
|
||||||
|
#define TYPE "BMP280"
|
||||||
|
#define PRFX1 TYPE "11"
|
||||||
|
#define PRFX2 TYPE "12"
|
||||||
|
#define PRFX3 TYPE "21"
|
||||||
|
#define PRFX4 TYPE "22"
|
||||||
|
class BMP280Config : public IICSensorBase{
|
||||||
|
public:
|
||||||
|
bool prAct=true;
|
||||||
|
bool tmAct=true;
|
||||||
|
tN2kTempSource tmSrc=tN2kTempSource::N2kts_InsideTemperature;
|
||||||
|
tN2kPressureSource prSrc=tN2kPressureSource::N2kps_Atmospheric;
|
||||||
|
tN2kHumiditySource huSrc=tN2kHumiditySource::N2khs_Undef;
|
||||||
|
String tmNam="Temperature";
|
||||||
|
String prNam="Pressure";
|
||||||
|
float tmOff=0;
|
||||||
|
float prOff=0;
|
||||||
|
Adafruit_BMP280 *device=nullptr;
|
||||||
|
uint32_t sensorId=-1;
|
||||||
|
BMP280Config(GwApi * api, const String &prfx):SensorBase(TYPE,api,prfx){
|
||||||
|
}
|
||||||
|
virtual bool isActive(){return prAct||tmAct;}
|
||||||
|
virtual bool initDevice(GwApi *api,TwoWire *wire){
|
||||||
|
GwLog *logger=api->getLogger();
|
||||||
|
//Wire.begin(GWIIC_SDA,GWIIC_SCL);
|
||||||
|
device= new Adafruit_BMP280(wire);
|
||||||
|
if (! device->begin(addr)){
|
||||||
|
LOG_DEBUG(GwLog::ERROR,"unable to initialize %s at %d",prefix.c_str(),addr);
|
||||||
|
delete device;
|
||||||
|
device=nullptr;
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
sensorId=device->sensorID();
|
||||||
|
LOG_DEBUG(GwLog::LOG, "initialized %s at %d, sensorId 0x%x", prefix.c_str(), addr, sensorId);
|
||||||
|
return (sensorId == 0x56 || sensorId == 0x57 || sensorId == 0x58)?true:false;
|
||||||
|
}
|
||||||
|
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);
|
||||||
|
return isActive();
|
||||||
|
}
|
||||||
|
virtual void measure(GwApi *api, TwoWire *wire, int counterId)
|
||||||
|
{
|
||||||
|
if (!device)
|
||||||
|
return;
|
||||||
|
GwLog *logger = api->getLogger();
|
||||||
|
float pressure = N2kDoubleNA;
|
||||||
|
float temperature = N2kDoubleNA;
|
||||||
|
float humidity = N2kDoubleNA;
|
||||||
|
float computed = N2kDoubleNA;
|
||||||
|
if (prAct)
|
||||||
|
{
|
||||||
|
pressure = device->readPressure();
|
||||||
|
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)
|
||||||
|
{
|
||||||
|
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 (tmAct || prAct )
|
||||||
|
{
|
||||||
|
sendN2kEnvironmentalParameters(api, *this, temperature, humidity, computed,counterId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#define CFGBMP280(prefix) \
|
||||||
|
CFG_GET(prAct,prefix); \
|
||||||
|
CFG_GET(tmAct,prefix);\
|
||||||
|
CFG_GET(tmSrc,prefix);\
|
||||||
|
CFG_GET(iid,prefix);\
|
||||||
|
CFG_GET(intv,prefix);\
|
||||||
|
CFG_GET(tmNam,prefix);\
|
||||||
|
CFG_GET(prNam,prefix);\
|
||||||
|
CFG_GET(tmOff,prefix);\
|
||||||
|
CFG_GET(prOff,prefix);
|
||||||
|
|
||||||
|
virtual void readConfig(GwConfigHandler *cfg) override
|
||||||
|
{
|
||||||
|
if (prefix == PRFX1)
|
||||||
|
{
|
||||||
|
busId = 1;
|
||||||
|
addr = 0x76;
|
||||||
|
CFGBMP280(BMP28011);
|
||||||
|
ok=true;
|
||||||
|
}
|
||||||
|
if (prefix == PRFX2)
|
||||||
|
{
|
||||||
|
busId = 1;
|
||||||
|
addr = 0x77;
|
||||||
|
CFGBMP280(BMP28012);
|
||||||
|
ok=true;
|
||||||
|
}
|
||||||
|
if (prefix == PRFX3)
|
||||||
|
{
|
||||||
|
busId = 2;
|
||||||
|
addr = 0x76;
|
||||||
|
CFGBMP280(BMP28021);
|
||||||
|
ok=true;
|
||||||
|
}
|
||||||
|
if (prefix == PRFX4)
|
||||||
|
{
|
||||||
|
busId = 2;
|
||||||
|
addr = 0x77;
|
||||||
|
CFGBMP280(BMP28022);
|
||||||
|
}
|
||||||
|
intv *= 1000;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
static IICSensorBase::Creator creator([](GwApi *api, const String &prfx){
|
||||||
|
return new BMP280Config(api,prfx);
|
||||||
|
});
|
||||||
|
IICSensorBase::Creator registerBMP280(GwApi *api,IICSensorList &sensors){
|
||||||
|
#if defined(GWBMP280) || defined(GWBMP28011)
|
||||||
|
{
|
||||||
|
auto *cfg=creator(api,PRFX1);
|
||||||
|
//BMP280Config *cfg=new BMP280Config(api,PRFX1);
|
||||||
|
sensors.add(api,cfg);
|
||||||
|
CHECK_IIC1();
|
||||||
|
#pragma message "GWBMP28011 defined"
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#if defined(GWBMP28012)
|
||||||
|
{
|
||||||
|
auto *cfg=creator(api,PRFX2);
|
||||||
|
//BMP280Config *cfg=new BMP280Config(api,PRFX2);
|
||||||
|
sensors.add(api,cfg);
|
||||||
|
CHECK_IIC1();
|
||||||
|
#pragma message "GWBMP28012 defined"
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#if defined(GWBMP28021)
|
||||||
|
{
|
||||||
|
auto *cfg=creator(api,PRFX3);
|
||||||
|
//BMP280Config *cfg=new BMP280Config(api,PRFX3);
|
||||||
|
sensors.add(api,cfg);
|
||||||
|
CHECK_IIC2();
|
||||||
|
#pragma message "GWBMP28021 defined"
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
#if defined(GWBMP28022)
|
||||||
|
{
|
||||||
|
auto *cfg=creator(api,PRFX4);
|
||||||
|
//BMP280Config *cfg=new BMP280Config(api,PRFX4);
|
||||||
|
sensors.add(api,cfg);
|
||||||
|
CHECK_IIC1();
|
||||||
|
#pragma message "GWBMP28022 defined"
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
return creator;
|
||||||
|
}
|
||||||
|
#else
|
||||||
|
IICSensorBase::Creator registerBMP280(GwApi *api,IICSensorList &sensors){
|
||||||
|
return IICSensorBase::Creator();
|
||||||
|
}
|
||||||
|
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,6 @@
|
||||||
|
#ifndef _GWBMP280_H
|
||||||
|
#define _GWBMP280_H
|
||||||
|
#include "GwIicSensors.h"
|
||||||
|
IICSensorBase::Creator registerBMP280(GwApi *api,IICSensorList &sensors);
|
||||||
|
#endif
|
||||||
|
|
|
@ -102,6 +102,15 @@ void sendN2kTemperature(GwApi *api,CFG &cfg,double value, int counterId){
|
||||||
api->increment(counterId,cfg.prefix+String("temp"));
|
api->increment(counterId,cfg.prefix+String("temp"));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
template <class CFG>
|
||||||
|
void sendN2kEnvironmentalParameters(GwApi *api,CFG &cfg,double tmValue, double huValue, double prValue, int counterId){
|
||||||
|
tN2kMsg msg;
|
||||||
|
SetN2kEnvironmentalParameters(msg,1,cfg.tmSrc,tmValue,cfg.huSrc,huValue,prValue);
|
||||||
|
api->sendN2kMessage(msg);
|
||||||
|
api->increment(counterId,cfg.prefix+String("hum"));
|
||||||
|
api->increment(counterId,cfg.prefix+String("press"));
|
||||||
|
api->increment(counterId,cfg.prefix+String("temp"));
|
||||||
|
}
|
||||||
|
|
||||||
#ifndef _GWI_IIC1
|
#ifndef _GWI_IIC1
|
||||||
#define CHECK_IIC1() checkDef(GWIIC_SCL,GWIIC_SDA)
|
#define CHECK_IIC1() checkDef(GWIIC_SCL,GWIIC_SDA)
|
||||||
|
@ -114,4 +123,4 @@ void sendN2kTemperature(GwApi *api,CFG &cfg,double value, int counterId){
|
||||||
#define CHECK_IIC2()
|
#define CHECK_IIC2()
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -21,6 +21,7 @@ static std::vector<IICGrove> iicGroveList;
|
||||||
#include "GwIicSensors.h"
|
#include "GwIicSensors.h"
|
||||||
#include "GwHardware.h"
|
#include "GwHardware.h"
|
||||||
#include "GwBME280.h"
|
#include "GwBME280.h"
|
||||||
|
#include "GwBMP280.h"
|
||||||
#include "GwQMP6988.h"
|
#include "GwQMP6988.h"
|
||||||
#include "GwSHT3X.h"
|
#include "GwSHT3X.h"
|
||||||
#include <map>
|
#include <map>
|
||||||
|
@ -92,6 +93,7 @@ void initIicTask(GwApi *api){
|
||||||
creators.push_back(registerSHT3X(api,sensors));
|
creators.push_back(registerSHT3X(api,sensors));
|
||||||
creators.push_back(registerQMP6988(api,sensors));
|
creators.push_back(registerQMP6988(api,sensors));
|
||||||
creators.push_back(registerBME280(api,sensors));
|
creators.push_back(registerBME280(api,sensors));
|
||||||
|
creators.push_back(registerBMP280(api,sensors));
|
||||||
#ifdef _GWI_IIC1
|
#ifdef _GWI_IIC1
|
||||||
addGroveItems(creators,api,sensors,"1",_GWI_IIC1);
|
addGroveItems(creators,api,sensors,"1",_GWI_IIC1);
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -530,5 +530,204 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"type": "array",
|
||||||
|
"name": "BMP280",
|
||||||
|
"replace": [
|
||||||
|
{
|
||||||
|
"b": "1",
|
||||||
|
"i": "11",
|
||||||
|
"n": "93"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"b": "1",
|
||||||
|
"i": "12",
|
||||||
|
"n": "92"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"b": "2",
|
||||||
|
"i": "21",
|
||||||
|
"n": "103"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"b": "2",
|
||||||
|
"i": "22",
|
||||||
|
"n": "102"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"children": [
|
||||||
|
{
|
||||||
|
"name": "BMP280$itmAct",
|
||||||
|
"label": "BMP280-$i Temp",
|
||||||
|
"type": "boolean",
|
||||||
|
"default": "true",
|
||||||
|
"description": "Enable the $i. I2C BMP280 temp sensor (bus $b)",
|
||||||
|
"category": "iicsensors$b",
|
||||||
|
"capabilities": {
|
||||||
|
"BMP280$i": "true"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "BMP280$itmSrc",
|
||||||
|
"label": "BMP280-$i Temp Type",
|
||||||
|
"type": "list",
|
||||||
|
"default": "2",
|
||||||
|
"description": "the NMEA2000 source type for the temperature",
|
||||||
|
"list": [
|
||||||
|
{
|
||||||
|
"l": "SeaTemperature",
|
||||||
|
"v": "0"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "OutsideTemperature",
|
||||||
|
"v": "1"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "InsideTemperature",
|
||||||
|
"v": "2"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "EngineRoomTemperature",
|
||||||
|
"v": "3"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "MainCabinTemperature",
|
||||||
|
"v": "4"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "LiveWellTemperature",
|
||||||
|
"v": "5"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "BaitWellTemperature",
|
||||||
|
"v": "6"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "RefridgerationTemperature",
|
||||||
|
"v": "7"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "HeatingSystemTemperature",
|
||||||
|
"v": "8"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "DewPointTemperature",
|
||||||
|
"v": "9"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "ApparentWindChillTemperature",
|
||||||
|
"v": "10"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "TheoreticalWindChillTemperature",
|
||||||
|
"v": "11"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "HeatIndexTemperature",
|
||||||
|
"v": "12"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "FreezerTemperature",
|
||||||
|
"v": "13"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "ExhaustGasTemperature",
|
||||||
|
"v": "14"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"l": "ShaftSealTemperature",
|
||||||
|
"v": "15"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"category": "iicsensors$b",
|
||||||
|
"capabilities": {
|
||||||
|
"BMP280$i": "true"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "BMP280$itmOff",
|
||||||
|
"label": "BMP280-$i Temperature Offset",
|
||||||
|
"type": "number",
|
||||||
|
"description": "offset (in °) to be added to the BMP280 temperature measurements",
|
||||||
|
"default": "0",
|
||||||
|
"category": "iicsensors$b",
|
||||||
|
"capabilities": {
|
||||||
|
"BMP280$i": "true"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "BMP280$iprAct",
|
||||||
|
"label": "BMP280-$i Pressure",
|
||||||
|
"type": "boolean",
|
||||||
|
"default": "true",
|
||||||
|
"description": "Enable the $i. I2C BMP280 pressure sensor (bus $b)",
|
||||||
|
"category": "iicsensors$b",
|
||||||
|
"capabilities": {
|
||||||
|
"BMP280$i": "true"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "BMP280$iprOff",
|
||||||
|
"label": "BMP280 Pressure Offset",
|
||||||
|
"type": "number",
|
||||||
|
"description": "offset (in pa) to be added to the BMP280 pressure measurements",
|
||||||
|
"default": "0",
|
||||||
|
"category": "iicsensors$b",
|
||||||
|
"capabilities": {
|
||||||
|
"BMP280$i": "true"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "BMP280$iiid",
|
||||||
|
"label": "BMP280-$i N2K iid",
|
||||||
|
"type": "number",
|
||||||
|
"default": "$n",
|
||||||
|
"description": "the N2K instance id for the BMP280 Temperature",
|
||||||
|
"category": "iicsensors$b",
|
||||||
|
"min": 0,
|
||||||
|
"max": 253,
|
||||||
|
"check": "checkMinMax",
|
||||||
|
"capabilities": {
|
||||||
|
"BMP280$i": "true"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "BMP280$iintv",
|
||||||
|
"label": "BMP280-$i Interval",
|
||||||
|
"type": "number",
|
||||||
|
"default": 2,
|
||||||
|
"description": "Interval(s) to query BME280 Temperature (1...300)",
|
||||||
|
"category": "iicsensors$b",
|
||||||
|
"min": 1,
|
||||||
|
"max": 300,
|
||||||
|
"check": "checkMinMax",
|
||||||
|
"capabilities": {
|
||||||
|
"BMP280$i": "true"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "BMP280$itmNam",
|
||||||
|
"label": "BMP280-$i Temp XDR",
|
||||||
|
"type": "String",
|
||||||
|
"default": "BTemp$i",
|
||||||
|
"description": "set the XDR transducer name for the BMP280 Temperature, leave empty to disable NMEA0183 XDR ",
|
||||||
|
"category": "iicsensors$b",
|
||||||
|
"capabilities": {
|
||||||
|
"BMP280$i": "true"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "BMP280$iprNam",
|
||||||
|
"label": "BMP280-$i Pressure XDR",
|
||||||
|
"type": "String",
|
||||||
|
"default": "BPressure$i",
|
||||||
|
"description": "set the XDR transducer name for the BMP280 Pressure, leave empty to disable NMEA0183 XDR",
|
||||||
|
"category": "iicsensors$b",
|
||||||
|
"capabilities": {
|
||||||
|
"BMP280$i": "true"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|
|
@ -35,3 +35,16 @@ build_flags=
|
||||||
-D M5_GROOVEIIC
|
-D M5_GROOVEIIC
|
||||||
-D M5_CAN_KIT
|
-D M5_CAN_KIT
|
||||||
${env.build_flags}
|
${env.build_flags}
|
||||||
|
|
||||||
|
[env:m5stack-atom-envbps]
|
||||||
|
extends = sensors
|
||||||
|
board = m5stack-atom
|
||||||
|
lib_deps =
|
||||||
|
${env.lib_deps}
|
||||||
|
${sensors.lib_deps}
|
||||||
|
build_flags=
|
||||||
|
#-D M5_ENVBPS
|
||||||
|
-D GWBMP280
|
||||||
|
-D M5_GROOVEIIC
|
||||||
|
-D M5_CAN_KIT
|
||||||
|
${env.build_flags}
|
||||||
|
|
|
@ -60,8 +60,9 @@ lib_deps =
|
||||||
Wire
|
Wire
|
||||||
SPI
|
SPI
|
||||||
adafruit/Adafruit BME280 Library @ 2.2.2
|
adafruit/Adafruit BME280 Library @ 2.2.2
|
||||||
|
adafruit/Adafruit BMP280 Library@^2.6.8
|
||||||
adafruit/Adafruit BusIO @ 1.14.5
|
adafruit/Adafruit BusIO @ 1.14.5
|
||||||
adafruit/Adafruit Unified Sensor @ 1.1.13
|
adafruit/Adafruit Unified Sensor @ 1.1.13
|
||||||
|
|
||||||
[env:m5stack-atom]
|
[env:m5stack-atom]
|
||||||
board = m5stack-atom
|
board = m5stack-atom
|
||||||
|
|
Loading…
Reference in New Issue