From fc7eb8acc9ee864beaf30ae738c30cc6388a80bb Mon Sep 17 00:00:00 2001 From: biver Date: Fri, 25 Feb 2022 13:20:03 +0300 Subject: [PATCH] =?UTF-8?q?=D0=94=D0=BE=D0=B1=D0=B0=D0=B2=D0=BB=D1=8F?= =?UTF-8?q?=D0=B5=D0=BC=20externalVariable=20=D0=B4=D0=BB=D1=8F=20=D0=BF?= =?UTF-8?q?=D1=80=D0=B8=D0=B5=D0=BC=D0=B0=20=D0=B8=20=D1=84=D0=B8=D0=BA?= =?UTF-8?q?=D1=81=D0=B0=D1=86=D0=B8=D0=B8=20=D0=BD=D0=B0=20=D0=B2=D1=80?= =?UTF-8?q?=D0=B5=D0=BC=D1=8F=20=D0=B7=D0=BD=D0=B0=D1=87=D0=B5=D0=BD=D0=B8?= =?UTF-8?q?=D1=8F=20=D1=81=D0=BE=D0=B1=D1=8B=D1=82=D0=B8=D1=8F=20=D0=B4?= =?UTF-8?q?=D0=BB=D1=8F=20=D0=B8=D1=81=D0=BF=D0=BE=D0=BB=D1=8C=D0=B7=D0=BE?= =?UTF-8?q?=D0=B2=D0=B0=D0=BD=D0=B8=D1=8F=20=D0=B2=20=D1=81=D1=86=D0=B5?= =?UTF-8?q?=D0=BD=D0=B0=D1=80=D0=B8=D1=8F=D1=85?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- include/classes/IoTItem.h | 12 ++++++++++++ src/classes/IoTItem.cpp | 20 ++++++++++++++++++++ 2 files changed, 32 insertions(+) diff --git a/include/classes/IoTItem.h b/include/classes/IoTItem.h index e15c48e5..1618e850 100644 --- a/include/classes/IoTItem.h +++ b/include/classes/IoTItem.h @@ -27,6 +27,8 @@ class IoTItem { unsigned long difference; IoTValue value; // хранение основного значения, котрое обновляется из сценария, execute(), loop() или doByInterval() + + bool iAmDead = false; // признак необходимости удалить объект из базы virtual IoTGpio* getGpioDriver(); virtual void setValue(IoTValue Value); @@ -46,3 +48,13 @@ class IoTItem { }; IoTItem* findIoTItem(String name); // поиск экземпляра элемента модуля по имени + + +class externalVariable: IoTItem { // объект, создаваемый при получении информации о событии на другом контроллере для хранения информации о событии указанное время + + public: + externalVariable(String parameters); + ~externalVariable(); + void doByInterval(); // для данного класса doByInterval+int выполняет роль счетчика обратного отсчета до уничтожения + +}; \ No newline at end of file diff --git a/src/classes/IoTItem.cpp b/src/classes/IoTItem.cpp index f3d9ac12..017978f9 100644 --- a/src/classes/IoTItem.cpp +++ b/src/classes/IoTItem.cpp @@ -15,6 +15,13 @@ IoTItem::IoTItem(String parameters) { jsonRead(parameters, F("plus"), _plus, false); jsonRead(parameters, F("round"), _round, false); + String valAsStr; + if (jsonRead(parameters, F("val"), valAsStr, false)) // значение переменной или датчика при инициализации если есть в конфигурации + if (value.isDecimal = isDigitDotCommaStr(valAsStr)) + value.valD = valAsStr.toFloat(); + else + value.valS = valAsStr; + String map; jsonRead(parameters, F("map"), map, false); if (map != "") { @@ -96,4 +103,17 @@ void IoTItem::setValue(IoTValue Value) { value = Value; if (value.isDecimal) regEvent(value.valD, ""); else regEvent(value.valS, ""); +} + + +externalVariable::externalVariable(String parameters) : IoTItem(parameters) { + Serial.printf("Call from externalVariable: parameters %s\n", parameters.c_str()); +} + +externalVariable::~externalVariable() { + Serial.printf("Call from ~externalVariable: Im dead\n"); +} + +void externalVariable::doByInterval() { // для данного класса doByInterval+int выполняет роль счетчика обратного отсчета до уничтожения + iAmDead = true; } \ No newline at end of file