From 02436d53d5ee039bad8ab3953c88caae78746ad2 Mon Sep 17 00:00:00 2001 From: biver Date: Sun, 16 Jan 2022 13:11:04 +0500 Subject: [PATCH 1/3] =?UTF-8?q?=D0=9F=D0=BE=D1=80=D1=82=D0=B8=D1=80=D1=83?= =?UTF-8?q?=D0=B5=D0=BC=20DS18B20?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/modules/ds18b20.cpp | 91 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 91 insertions(+) create mode 100644 src/modules/ds18b20.cpp diff --git a/src/modules/ds18b20.cpp b/src/modules/ds18b20.cpp new file mode 100644 index 00000000..74fb434f --- /dev/null +++ b/src/modules/ds18b20.cpp @@ -0,0 +1,91 @@ +#include "Global.h" +#include "Classes/IoTSensor.h" + +#include "DallasTemperature.h" +#include +#include + +//глобальные списки необходимы для хранения объектов об активных линиях 1-wire используемых разными датчиками из модуля. Ключ - номер пина +std::map oneWireTemperatureArray; +std::map 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) +void* getAPI_ds18b20(String subtype, String param) { + if (subtype == F("ds18b20")) { + return new ds18b20(param); + } else { + return nullptr; + } +} From b79233d6fb7195799414a183300df1370e051a73 Mon Sep 17 00:00:00 2001 From: biver Date: Sun, 16 Jan 2022 13:13:01 +0500 Subject: [PATCH 2/3] =?UTF-8?q?=D0=9F=D0=BE=D0=B4=D0=BA=D0=BB=D1=8E=D1=87?= =?UTF-8?q?=D0=B0=D0=B5=D0=BC=20DS18B20?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/modules/API.cpp | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/modules/API.cpp b/src/modules/API.cpp index 8d077ad4..be4fe2d4 100644 --- a/src/modules/API.cpp +++ b/src/modules/API.cpp @@ -3,6 +3,7 @@ //============================================================================================ //здесь скопируйте строку и вставьте ниже, заменив имя AnalogAdc на название вашего сенсора void* getAPI_AnalogAdc(String subtype, String params); +void* getAPI_ds18b20(String subtype, String params); //============================================================================================ void* getAPI(String subtype, String params) { @@ -12,5 +13,7 @@ void* getAPI(String subtype, String params) { if ((tmpAPI = getAPI_AnalogAdc(subtype, params)) != nullptr) return tmpAPI; //================================================================================================================ + if ((tmpAPI = getAPI_ds18b20(subtype, params)) != nullptr) return tmpAPI; + return nullptr; } \ No newline at end of file From c8bd073cf82af8fa5e51062b37bb126d46e97503 Mon Sep 17 00:00:00 2001 From: biver Date: Sun, 16 Jan 2022 12:03:02 +0300 Subject: [PATCH 3/3] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D1=8F?= =?UTF-8?q?=D0=B5=D0=BC=20=D0=B2=D0=BE=D0=B7=D0=BC=D0=BE=D0=B6=D0=BD=D0=BE?= =?UTF-8?q?=D1=81=D1=82=D1=8C=20=D0=BF=D0=BE=D0=BB=D1=83=D1=87=D0=B5=D0=BD?= =?UTF-8?q?=D0=B8=D1=8F=20=D0=BF=D0=B5=D1=80=D0=B2=D0=B8=D1=87=D0=BD=D0=BE?= =?UTF-8?q?=D0=B9=20=D0=BD=D0=B0=D1=81=D1=82=D1=80=D0=BE=D0=B9=D0=BA=D0=B8?= =?UTF-8?q?=20=D0=B8=D0=B7=20=D0=BC=D0=BE=D0=B4=D1=83=D0=BB=D1=8F?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- include/classes/IoTSensor.h | 6 ++++++ src/ESPConfiguration.cpp | 9 ++------- src/modules/API.cpp | 18 +++++++++++------- src/modules/AnalogAdc.cpp | 11 +++++++---- src/modules/ds18b20.cpp | 15 +++++++++------ 5 files changed, 35 insertions(+), 24 deletions(-) diff --git a/include/classes/IoTSensor.h b/include/classes/IoTSensor.h index 34d6969e..e790cff5 100644 --- a/include/classes/IoTSensor.h +++ b/include/classes/IoTSensor.h @@ -25,5 +25,11 @@ class IoTSensor { unsigned long _interval; }; +struct ModuleInfo +{ + void* apiToComponent; + String defConfig; +}; + //extern IoTSensor* myIoTSensor; //модулям не нужно знать эту переменную \ No newline at end of file diff --git a/src/ESPConfiguration.cpp b/src/ESPConfiguration.cpp index a6891696..7564c4cd 100644 --- a/src/ESPConfiguration.cpp +++ b/src/ESPConfiguration.cpp @@ -1,12 +1,7 @@ #include "ESPConfiguration.h" std::vector 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); diff --git a/src/modules/API.cpp b/src/modules/API.cpp index be4fe2d4..5eb53404 100644 --- a/src/modules/API.cpp +++ b/src/modules/API.cpp @@ -2,18 +2,22 @@ //============================================================================================ //здесь скопируйте строку и вставьте ниже, заменив имя AnalogAdc на название вашего сенсора -void* getAPI_AnalogAdc(String subtype, String params); -void* getAPI_ds18b20(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; //================================================================================================================ - if ((tmpAPI = getAPI_ds18b20(subtype, params)) != nullptr) return tmpAPI; + if ((tmpMi = getAPI_ds18b20(subtype, params)).apiToComponent != nullptr) return tmpMi; else defConfig += tmpMi.defConfig; - return nullptr; + + + tmpMi.defConfig = defConfig; + return tmpMi; } \ No newline at end of file diff --git a/src/modules/AnalogAdc.cpp b/src/modules/AnalogAdc.cpp index df806dd8..0766751d 100644 --- a/src/modules/AnalogAdc.cpp +++ b/src/modules/AnalogAdc.cpp @@ -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; } diff --git a/src/modules/ds18b20.cpp b/src/modules/ds18b20.cpp index 74fb434f..fe5d19cb 100644 --- a/src/modules/ds18b20.cpp +++ b/src/modules/ds18b20.cpp @@ -82,10 +82,13 @@ class ds18b20 : public IoTSensor { //после замены названия сенсора, на функцию можно не обращать внимания //если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть //создание и контроль соответствующих глобальных переменных (см. пример реализации сенсора ds18b20) -void* getAPI_ds18b20(String subtype, String param) { - if (subtype == F("ds18b20")) { - return new ds18b20(param); - } else { - return nullptr; - } +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; }