Merge pull request #118 from biveraxe/ver4dev

Портируем DS18B20
This commit is contained in:
IoT Manager
2022-01-16 13:10:36 +01:00
committed by GitHub
5 changed files with 121 additions and 16 deletions

View File

@@ -25,5 +25,11 @@ class IoTSensor {
unsigned long _interval;
};
struct ModuleInfo
{
void* apiToComponent;
String defConfig;
};
//extern IoTSensor* myIoTSensor;
//модулям не нужно знать эту переменную

View File

@@ -1,12 +1,7 @@
#include "ESPConfiguration.h"
std::vector<IoTSensor*> iotSensors;
void* getAPI(String subtype, String params);
//============================================================================================
//здесь скопируйте строку и вставьте ниже, заменив имя AnalogAdc на название вашего сенсора
extern void* getAPI_AnalogAdc(String params);
//============================================================================================
ModuleInfo getAPI(String subtype, String params);
void configure(String path) {
File file = seekFile(path);
@@ -22,7 +17,7 @@ void configure(String path) {
SerialPrint(F("E"), F("Config"), "json error " + subtype);
continue;
} else {
myIoTSensor = (IoTSensor*)getAPI(subtype, jsonArrayElement);
myIoTSensor = (IoTSensor*)getAPI(subtype, jsonArrayElement).apiToComponent;
if (myIoTSensor) {
iotSensors.push_back(myIoTSensor);
createWidget(jsonArrayElement);

View File

@@ -2,15 +2,22 @@
//============================================================================================
//здесь скопируйте строку и вставьте ниже, заменив имя AnalogAdc на название вашего сенсора
void* getAPI_AnalogAdc(String subtype, String params);
ModuleInfo getAPI_AnalogAdc(String subtype, String params);
ModuleInfo getAPI_ds18b20(String subtype, String params);
//============================================================================================
void* getAPI(String subtype, String params) {
void* tmpAPI;
ModuleInfo getAPI(String subtype, String params) {
ModuleInfo tmpMi;
String defConfig = "";
//===============================================================================================================
//здесь нужно скопировать строку еще раз и вставить ее ниже, переименовав AnalogAdc на название вашего сенсора
if ((tmpAPI = getAPI_AnalogAdc(subtype, params)) != nullptr) return tmpAPI;
if ((tmpMi = getAPI_AnalogAdc(subtype, params)).apiToComponent != nullptr) return tmpMi; else defConfig += tmpMi.defConfig;
//================================================================================================================
return nullptr;
if ((tmpMi = getAPI_ds18b20(subtype, params)).apiToComponent != nullptr) return tmpMi; else defConfig += tmpMi.defConfig;
tmpMi.defConfig = defConfig;
return tmpMi;
}

View File

@@ -46,10 +46,13 @@ class AnalogAdc : public IoTSensor {
//после замены названия сенсора, на функцию можно не обращать внимания
//если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть
//создание и контроль соответствующих глобальных переменных (см. пример реализации сенсора ds18b20)
void* getAPI_AnalogAdc(String subtype, String param) {
ModuleInfo getAPI_AnalogAdc(String subtype, String param) {
ModuleInfo mi;
mi.apiToComponent = nullptr;
mi.defConfig = "конфин такой вот джисон";
if (subtype == F("AnalogAdc")) {
return new AnalogAdc(param);
} else {
return nullptr;
mi.apiToComponent = new AnalogAdc(param);
}
return mi;
}

94
src/modules/ds18b20.cpp Normal file
View File

@@ -0,0 +1,94 @@
#include "Global.h"
#include "Classes/IoTSensor.h"
#include "DallasTemperature.h"
#include <OneWire.h>
#include <map>
//глобальные списки необходимы для хранения объектов об активных линиях 1-wire используемых разными датчиками из модуля. Ключ - номер пина
std::map<int, OneWire*> oneWireTemperatureArray;
std::map<int, DallasTemperature*> sensorsTemperatureArray;
class ds18b20 : public IoTSensor {
private:
//для работы библиотеки с несколькими линиями необходимо обеспечить каждый экземпляр класса ссылками на объекты настроенные на эти линии
OneWire* oneWire;
DallasTemperature* sensors;
//описание параметров передаваемых из настроек датчика из веба
String _addr;
unsigned int _pin;
unsigned int _index;
public:
//=======================================================================================================
// setup()
//Все параметры хранятся в перемененной parameters, вы можете прочитать любой параметр используя jsonRead функции:
// jsonReadStr, jsonReadBool, jsonReadInt
ds18b20(String parameters) {
init(jsonReadStr(parameters, "key"), jsonReadStr(parameters, "id"), jsonReadInt(parameters, "int")); //обязательный вызов
_pin = jsonReadInt(parameters, "pin");
_index = jsonReadInt(parameters, "index");
_addr = jsonReadStr(parameters, "addr");
//учитываем, что библиотека может работать с несколькими линиями на разных пинах, поэтому инициируем библиотеку, если линия ранее не использовалась
if (oneWireTemperatureArray.find(_pin) == oneWireTemperatureArray.end()) {
oneWire = new OneWire((uint8_t)_pin);
sensors = new DallasTemperature();
sensors->setOneWire(oneWire);
sensors->begin();
sensors->setResolution(12);
oneWireTemperatureArray[_pin] = oneWire;
sensorsTemperatureArray[_pin] = sensors;
} else {
oneWire = oneWireTemperatureArray[_pin];
sensors = sensorsTemperatureArray[_pin];
}
}
//=======================================================================================================
// doByInterval()
//это аналог loop из arduino, но вызываемый каждые int секунд, заданные в настройках. Здесь вы должны выполнить чтение вашего сенсора
//а затем выполнить regEvent - это регистрация произошедшего события чтения
//здесь так же доступны все переменные из секции переменных, и полученные в setup
//если у сенсора несколько величин то делайте несколько regEvent
//не используйте delay - помните, что данный loop общий для всех модулей. Если у вас планируется длительная операция, постарайтесь разбить ее на порции
//и выполнить за несколько тактов
void doByInterval() {
//запускаем опрос измерений у всех датчиков на линии
sensors->requestTemperatures();
//Определяем адрес. Если парамтер addr не установлен, то узнаем адрес по индексу
DeviceAddress deviceAddress;
if (_addr == "") {
sensors->getAddress(deviceAddress, _index);
} else {
string2hex(_addr.c_str(), deviceAddress);
}
//получаем температуру по адресу
float value = sensors->getTempC(deviceAddress);
char addrStr[20] = "";
hex2string(deviceAddress, 8, addrStr);
regEvent((String)value, "addr: " + String(addrStr)); //обязательный вызов для отправки результата работы
}
//=======================================================================================================
~ds18b20() {};
};
//после замены названия сенсора, на функцию можно не обращать внимания
//если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть
//создание и контроль соответствующих глобальных переменных (см. пример реализации сенсора ds18b20)
ModuleInfo getAPI_ds18b20(String subtype, String param) {
ModuleInfo mi;
mi.apiToComponent = nullptr;
mi.defConfig = "конфин такой вот джисон";
if (subtype == F("AnalogAdc")) {
mi.apiToComponent = new ds18b20(param);
}
return mi;
}