diff --git a/platformio.ini b/platformio.ini index 37f45400..c0e5c915 100644 --- a/platformio.ini +++ b/platformio.ini @@ -8,7 +8,6 @@ ; Please visit documentation for the other options and examples ; https://docs.platformio.org/page/projectconf.html - [platformio] default_envs = esp8266_4mb data_dir = data_svelte @@ -20,9 +19,6 @@ lib_deps_external = Links2004/WebSockets knolleary/PubSubClient -;lib_deps_internal = - - [env:esp8266_4mb] build_flags = -Desp8266_4mb="esp8266_4mb" framework = arduino @@ -31,6 +27,7 @@ board_build.ldscript = eagle.flash.4m1m.ld platform = espressif8266 @2.6.3 lib_deps = ${common_env_data.lib_deps_external} + milesburton/DallasTemperature@^3.9.1 monitor_filters = esp8266_exception_decoder upload_speed = 921600 monitor_speed = 115200 @@ -40,9 +37,10 @@ board_build.filesystem = littlefs build_flags = -Desp32_4mb="esp32_4mb" framework = arduino board = esp32dev -platform = espressif32 @3.3.0 +platform = espressif32 @3.3.0 lib_deps = ${common_env_data.lib_deps_external} + milesburton/DallasTemperature@^3.9.1 monitor_filters = esp32_exception_decoder upload_speed = 921600 -monitor_speed = 115200 \ No newline at end of file +monitor_speed = 115200 diff --git a/src/modules/API.cpp b/src/modules/API.cpp index d19d10bd..0812e534 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) { @@ -10,6 +11,7 @@ void* getAPI(String subtype, String params) { //=============================================================================================================== //здесь нужно скопировать строку еще раз и вставить ее ниже, переименовав AnalogAdc на название вашего сенсора if ((tmpAPI = getAPI_AnalogAdc(subtype, params)) != nullptr) return tmpAPI; + if ((tmpAPI = getAPI_ds18b20(subtype, params)) != nullptr) return tmpAPI; //================================================================================================================ return nullptr; diff --git a/src/modules/AnalogAdc.cpp b/src/modules/AnalogAdc.cpp index df806dd8..5d2b3e6e 100644 --- a/src/modules/AnalogAdc.cpp +++ b/src/modules/AnalogAdc.cpp @@ -45,7 +45,7 @@ class AnalogAdc : public IoTSensor { //после замены названия сенсора, на функцию можно не обращать внимания //если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть -//создание и контроль соответствующих глобальных переменных (см. пример реализации сенсора ds18b20) +//создание и контроль соответствующих глобальных переменных void* getAPI_AnalogAdc(String subtype, String param) { if (subtype == F("AnalogAdc")) { return new AnalogAdc(param); diff --git a/src/modules/ds18b20.cpp b/src/modules/ds18b20.cpp new file mode 100644 index 00000000..cefd7696 --- /dev/null +++ b/src/modules/ds18b20.cpp @@ -0,0 +1,93 @@ +#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() + //это аналог setup из arduino. Здесь вы можете выполнять методы инициализации сенсора. + //Такие как ...begin и подставлять в них параметры полученные из web интерфейса. + //Все параметры хранятся в перемененной 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; + } +}