Добавляем механизм глобальных векторов для модулей и сенсоров. Модуль Dallas полностью интегрирован поновому

This commit is contained in:
2021-12-23 09:09:26 +03:00
parent 66f21a5001
commit faa865e78d
12 changed files with 293 additions and 158 deletions

View File

@@ -15,7 +15,6 @@
#include "items/vSensorBme280.h"
#include "items/vSensorBmp280.h"
#include "items/vSensorCcs811.h"
#include "items/vSensorDallas.h"
#include "items/vSensorDht.h"
#include "items/vSensorNode.h"
#include "items/vSensorPzem.h"
@@ -23,6 +22,15 @@
#include "items/vSensorUltrasonic.h"
#include "items/vSensorUptime.h"
#include "Class/LineParsing.h"
#include "Utils/JsonUtils.h"
#include "Class/IoTModule.h"
#include "Class/IoTSensor.h"
extern std::vector<IoTModule*> iotModules; //v3dev: вектор ссылок базового класса IoTModule - интерфейсы для общения со всеми поддерживаемыми системой модулями
extern std::vector<IoTSensor*> iotSensors; //v3dev: вектор ссылок базового класса IoTSensor - список всех запущенных сенсоров
void loopCmdAdd(const String& cmdStr) {
if (cmdStr.endsWith(",")) {
orderBuf += cmdStr;
@@ -73,6 +81,7 @@ void csvCmdExecute(String& cmdStr) {
if (count > 1) {
// SerialPrint("I", "Items", buf);
String order = selectToMarker(buf, " "); //отсечка самой команды
if (order == F("button-out")) {
#ifdef EnableButtonOut
sCmd.addCommand(order.c_str(), buttonOut);
@@ -103,9 +112,9 @@ void csvCmdExecute(String& cmdStr) {
#endif
//ИНТЕГРИРУЮ: Первая интеграция в ядро. Следим за наименованием
} else if (order == F("dallas-temp")) {
#ifdef EnableSensorDallas
sCmd.addCommand(order.c_str(), dallas);
#endif
// #ifdef EnableSensorDallas
// sCmd.addCommand(order.c_str(), dallas);
// #endif
} else if (order == F("dht")) {
#ifdef EnableSensorDht
sCmd.addCommand(order.c_str(), dhtSensor);
@@ -161,6 +170,31 @@ void csvCmdExecute(String& cmdStr) {
}
sCmd.readStr(buf);
//v3dev: инициируем экземпляр модулей в случае необходимости
for (unsigned int i = 0; i < iotModules.size(); i++) {
SerialPrint("I", "Debug iotModules count", "");
ModuleInfo moduleInfo = iotModules[i]->getInfo();
if (moduleInfo.key == order) {
SerialPrint("I", "Debug moduleInfo.parameters", buf);
if (moduleInfo.type == "Sensor") {
myLineParsing.update();
String interval = myLineParsing.gint();
String pin = myLineParsing.gpin();
String index = myLineParsing.gindex();
String addr = myLineParsing.gaddr();
myLineParsing.clear();
String strTmp = "{\"addr\": \"" + addr + "\", \"int\": \"" + interval + "\", \"pin\": \"" + pin + "\", \"index\": \"" + index + "\"}";
iotSensors.push_back((IoTSensor*)iotModules[i]->initInstance(strTmp));
} else if (moduleInfo.type == "Container")
{
//iot.push_back((IoTSensor*)iotModules[i]->initInstance(moduleInfo.parameters));
}
}
}
}
cmdStr = deleteBeforeDelimiter(cmdStr, "\n");
}

6
src/Class/IoTModule.cpp Normal file
View File

@@ -0,0 +1,6 @@
#include "Class/IoTModule.h"
IoTModule::IoTModule() {};
IoTModule::~IoTModule() {};
void* IoTModule::initInstance(String parameters) {};
ModuleInfo IoTModule::getInfo() {};

31
src/Class/IoTSensor.cpp Normal file
View File

@@ -0,0 +1,31 @@
#include "Utils/JsonUtils.h"
#include "Utils/SerialPrint.h"
#include "Class/ScenarioClass3.h"
#include "Class/IoTSensor.h"
void IoTSensor::init(unsigned long interval, String key) {
_interval = interval * 1000;
_key = key;
}
IoTSensor::IoTSensor() {}
IoTSensor::~IoTSensor() {}
void IoTSensor::loop() {
currentMillis = millis();
difference = currentMillis - prevMillis;
if (difference >= _interval) {
prevMillis = millis();
SerialPrint("I", "Sensor", "Вызывается loop");
this->doByInterval();
}
}
void IoTSensor::regEvent(String value, String consoleInfo = "") {
eventGen2(_key, String(value));
jsonWriteStr(configLiveJson, _key, String(value));
publishStatus(_key, String(value));
SerialPrint("I", "Sensor", "'" + _key + "' data: " + String(value) + "' " + consoleInfo);
}
void IoTSensor::doByInterval() {}

View File

@@ -15,7 +15,6 @@
#include "items/vSensorBme280.h"
#include "items/vSensorBmp280.h"
#include "items/vSensorCcs811.h"
#include "items/vSensorDallas.h"
#include "items/vSensorDht.h"
#include "items/vSensorNode.h"
#include "items/vSensorPzem.h"
@@ -161,13 +160,6 @@ void clearVectors() {
}
pwmOut_KeyList = "";
pwmOut_EnterCounter = -1;
#endif
//==================================
//ИНТЕГРИРУЮ: Вторая интеграция в ядро. Следим за наименованием
#ifdef EnableSensorDallas
if (mySensorDallas2 != nullptr) {
mySensorDallas2->clear();
}
#endif
#ifdef EnableSensorUltrasonic
if (mySensorUltrasonic != nullptr) {

View File

@@ -0,0 +1,102 @@
#include "Utils/JsonUtils.h"
#include "Utils/SerialPrint.h"
#include "Utils/StringUtils.h"
#include "Class/IoTSensor.h"
#include "Class/IoTModule.h"
#include "DallasTemperature.h"
#include <OneWire.h>
extern std::vector<IoTModule*> iotModules; //v3dev: вектор ссылок базового класса IoTModule - интерфейсы для общения со всеми поддерживаемыми системой модулями
#define IOTSENSORKEY "dallas-temp"
class IoTSensorDallas: public IoTSensor {
private:
//описание переменных экземпляра датчика - аналог глобальных переменных из Arduino
OneWire* oneWire;
DallasTemperature sensors;
//описание параметров передаваемых из настроек датчика из веба
String _addr;
unsigned int _pin;
unsigned int _index;
public:
//аналог setup() из Arduino
IoTSensorDallas(String parameters) {
init(jsonReadInt(parameters, "int"), IOTSENSORKEY); //передаем часть базовых параметров в конструктор базового класса для обеспечения работы его методов
_pin = jsonReadInt(parameters, "pin");
_index = jsonReadInt(parameters, "index");
_addr = jsonReadStr(parameters, "addr");
oneWire = new OneWire((uint8_t)_pin);
sensors.setOneWire(oneWire);
sensors.begin();
sensors.setResolution(12);
}
~IoTSensorDallas() {}
//аналог loop() из Arduino но квотируемый по времени параметром interval
void doByInterval() {
SerialPrint("I", "Sensor", "Вызывается doByInterval");
sensors.requestTemperatures();
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)); //обязательный вызов для отправки результата работы
}
};
// void dallas() {
// myLineParsing.update();
// String interval = myLineParsing.gint();
// String pin = myLineParsing.gpin();
// String index = myLineParsing.gindex();
// String key = myLineParsing.gkey();
// String addr = myLineParsing.gaddr();
// myLineParsing.clear();
// static bool firstTime = true;
// if (firstTime) mySensorDallas2 = new MySensorDallasVector();
// firstTime = false;
// }
class IoTModuleDallasTemp: public IoTModule {
void* initInstance(String parameters) {
SerialPrint("I", "Debug", "Вызывается initInstance из IoTModuleDallasTemp");
return new IoTSensorDallas(parameters);
};
ModuleInfo getInfo() {
ModuleInfo MI;
MI.key = IOTSENSORKEY;
MI.name = "Датчик температуры Ds18b20";
MI.parameters = "{\"addr\": \"\", \"int\": \"10\", \"pin\": \"18\", \"index\": \"0\"}";
MI.type = "Sensor";
return MI;
};
};
void getApiIoTSensorDallasTemp() {
SerialPrint("I", "Debug", "call getApiIoTSensorDallasTemp");
iotModules.push_back(new IoTModuleDallasTemp());
return;
}

7
src/Modules/api.cpp Normal file
View File

@@ -0,0 +1,7 @@
#include "Utils/SerialPrint.h"
void getApiIoTSensorDallasTemp();
int InitModulesApi() {
SerialPrint("I", "Debug", "call InitModulesApi");
getApiIoTSensorDallasTemp();
}

View File

@@ -1,96 +0,0 @@
#include "Consts.h"
#ifdef EnableSensorDallas
#include "items/vSensorDallas.h"
#include "BufferExecute.h"
#include "Class/LineParsing.h"
#include "Global.h"
#include "DallasTemperature.h"
#include "Utils/StringUtils.h"
#include <Arduino.h>
//ИНТЕГРИРУЮ: переменные необходимые для работы интегрируемой библиотеки. Аналог Arduino
OneWire* oneWire;
DallasTemperature sensors;
//ИНТЕГРИРУЮ:
//Для каждого датчика указанного в конфигурации вызывается конструктор для настройки перед запуском. Аналог функции setup() в Arduino.
//В параметрах передаются дополнительные настройки, указанные все в той же таблице настройки устройства.
SensorDallas::SensorDallas(unsigned long interval, unsigned int pin, unsigned int index, String addr, String key) {
//все особые параметры сливаем в локальные переменные экземпляра для будущего доступа
_interval = interval * 1000;
_key = key;
_pin = pin;
_index = index;
_addr = addr;
//ИНТЕГРИРУЮ:
//вызываем необходимые инициирующие функции интегрируемой библиотеки
oneWire = new OneWire((uint8_t)_pin);
sensors.setOneWire(oneWire);
sensors.begin();
sensors.setResolution(12);
}
//ИНТЕГРИРУЮ: оставляем как есть или развиваем, если нужно правильно завершить работу с интегрируемой библиотекой после отключения датчика
SensorDallas::~SensorDallas() {}
//ИНТЕГРИРУЮ: аналог loop() в Arduino. Требуется изменить, если интегрируемая библиотека нуждается в другом алгоритме квотирования времени.
void SensorDallas::loop() {
currentMillis = millis();
difference = currentMillis - prevMillis;
if (difference >= _interval) {
prevMillis = millis();
readDallas();
}
}
//ИНТЕГРИРУЮ: вызывается из цикла loop каждый установленный временно интервал в параметрах датчика. Необходимо изменить для чтения данных из датчика.
void SensorDallas::readDallas() {
//запускаем опрос измерений у всех датчиков на линии
sensors.requestTemperatures();
//Определяем адрес. Если парамтер addr не установлен, то узнаем адрес по индексу
DeviceAddress deviceAddress;
if (_addr == "") {
sensors.getAddress(deviceAddress, _index);
} else {
string2hex(_addr.c_str(), deviceAddress);
}
//получаем температуру по адресу
float value = sensors.getTempC(deviceAddress);
//ИНТЕГРИРУЮ: блок генерации уведомлений в ядре системы. Стоит обратить внимание только на формат выводимого сообщения в консоли.
eventGen2(_key, String(value));
jsonWriteStr(configLiveJson, _key, String(value));
publishStatus(_key, String(value));
char addrStr[20] = "";
hex2string(deviceAddress, 8, addrStr);
SerialPrint("I", "Sensor", "'" + _key + "' data: " + String(value) + "' addr: " + String(addrStr));
}
//ИНТЕГРИРУЮ: глобальная переменная необходима для интеграции в ядро. Следим за наименованием.
MySensorDallasVector* mySensorDallas2 = nullptr;
//ИНТЕГРИРУЮ: функция вызывается ядром для каждой записи в таблице настроки для создания экземпляров датчиков
//некоторые датчики записаны в таблице в виде нескольких строк, поэтому необходимо контролировать итерации обращения к данной функции
void dallas() {
//ИНТЕГРИРУЮ: не меняем
myLineParsing.update();
//ИНТЕГРИРУЮ: устанавливаем в соответствии с параметрами таблицы
String interval = myLineParsing.gint();
String pin = myLineParsing.gpin();
String index = myLineParsing.gindex();
String key = myLineParsing.gkey();
String addr = myLineParsing.gaddr();
//ИНТЕГРИРУЮ: не меняем
myLineParsing.clear();
//ИНТЕГРИРУЮ: блок создания экземпляров датчиков. Обратить внимание на наименования и передаваемые параметры в конструктор
static bool firstTime = true;
if (firstTime) mySensorDallas2 = new MySensorDallasVector();
firstTime = false;
mySensorDallas2->push_back(SensorDallas(interval.toInt(), pin.toInt(), index.toInt(), addr, key));
}
#endif

View File

@@ -28,7 +28,6 @@
#include "items/vSensorBme280.h"
#include "items/vSensorBmp280.h"
#include "items/vSensorCcs811.h"
#include "items/vSensorDallas.h"
#include "items/vSensorDht.h"
#include "items/vSensorNode.h"
#include "items/vSensorPzem.h"
@@ -36,6 +35,17 @@
#include "items/vSensorUltrasonic.h"
#include "items/vSensorUptime.h"
//#include "WebServer.h"
#include <vector>
#include "Class/IoTSensor.h"
#include "Class/IoTModule.h"
std::vector<IoTModule*> iotModules; //v3dev: вектор ссылок базового класса IoTModule - интерфейсы для общения со всеми поддерживаемыми системой модулями
std::vector<IoTSensor*> iotSensors; //v3dev: вектор ссылок базового класса IoTSensor - список всех запущенных сенсоров
int InitModulesApi(); //v3dev: инициализация модуля при первом вызове .
void not_async_actions();
Timings metric;
@@ -60,6 +70,10 @@ void setup() {
clockInit();
timeInit();
itemsListInit();
SerialPrint("I", "Debug", "call setup");
InitModulesApi(); //v3dev: инициализация модуля при первом вызове .
espInit();
routerConnect();
#ifdef EnableTelegram
@@ -146,13 +160,7 @@ void loop() {
}
}
#endif
#ifdef EnableSensorDallas
if (mySensorDallas2 != nullptr) {
for (unsigned int i = 0; i < mySensorDallas2->size(); i++) {
mySensorDallas2->at(i).loop();
}
}
#endif
#ifdef EnableSensorUltrasonic
if (mySensorUltrasonic != nullptr) {
for (unsigned int i = 0; i < mySensorUltrasonic->size(); i++) {
@@ -234,4 +242,12 @@ void loop() {
#ifdef EnableButtonIn
myButtonIn.loop();
#endif
//v3dev: перебираем все экземпляры сенсоров должно заменить в v4 все вызовы сенсоров выше
for (unsigned int i = 0; i < iotSensors.size(); i++) {
iotSensors[i]->loop();
}
}