From b938cbdcf0a2fb84c5bfe8ee54b3d17b5d933e03 Mon Sep 17 00:00:00 2001 From: biver Date: Tue, 22 Feb 2022 23:58:35 +0300 Subject: [PATCH 1/2] =?UTF-8?q?=D0=A1=D0=B2=D1=8F=D0=B7=D1=8B=D0=B2=D0=B0?= =?UTF-8?q?=D0=B5=D0=BC=20=D0=BE=D1=87=D0=B5=D1=80=D0=B5=D0=B4=D1=8C=20?= =?UTF-8?q?=D0=BF=D1=80=D1=8F=D0=BC=D1=8B=D1=85=20=D0=BA=D0=BE=D0=BC=D0=B0?= =?UTF-8?q?=D0=BD=D0=B4=20=D1=81=20=D1=8D=D0=BB=D0=B5=D0=BC=D0=B5=D0=BD?= =?UTF-8?q?=D1=82=D0=B0=D0=BC=D0=B8=20=D0=BA=D0=BE=D0=BD=D1=84=D0=B8=D0=B3?= =?UTF-8?q?=D1=83=D1=80=D0=B0=D1=86=D0=B8=D0=B8.=20=D0=9F=D0=BE=D0=BA?= =?UTF-8?q?=D0=B0=20=D1=82=D0=BE=D0=BB=D1=8C=D0=BA=D0=BE=20=D0=BF=D0=BE=20?= =?UTF-8?q?=D1=83=D1=81=D1=82=D0=B0=D0=BD=D0=BE=D0=B2=D0=BA=D0=B5=20=D0=B7?= =?UTF-8?q?=D0=BD=D0=B0=D1=87=D0=B5=D0=BD=D0=B8=D1=8F.?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/EventsAndOrders.cpp | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/src/EventsAndOrders.cpp b/src/EventsAndOrders.cpp index 6ca7e08e..4fde9600 100644 --- a/src/EventsAndOrders.cpp +++ b/src/EventsAndOrders.cpp @@ -7,6 +7,8 @@ //его главное отличие от orderBuf в том что события в нем не для выполнения, а для проверки в условиях сценариев //события в нем лишь вызывают другие команды, помещенные в блоке сценария, если условие совпало. + + //эта функция будет вызываться: // 1.на приеме сообщений в mqtt (см mqttCallback строку 142 в mqttClient.cpp) // 2.на приеме сообщений в ws @@ -21,7 +23,17 @@ void handleOrder() { if (orderBuf.length()) { String order = selectToMarker(orderBuf, ","); Serial.println("order: " + order); + //здесь нужно перебрать все методы execute всех векторов и выполнить те id которых совпали с id события + IoTItem* item = findIoTItem(selectToMarker(order, " ")); + if (item) { + String valStr = selectToMarkerLast(order, " "); + IoTValue value; + if (value.isDecimal = isDigitStr(valStr)) value.valD = valStr.toFloat(); + else value.valS = valStr; + item->setValue(value); + } + orderBuf = deleteBeforeDelimiter(orderBuf, ","); } } From f8356a9e2908eb41c92cfe443ff489eccbb8715b Mon Sep 17 00:00:00 2001 From: biver Date: Wed, 23 Feb 2022 00:37:37 +0300 Subject: [PATCH 2/2] =?UTF-8?q?=D0=A1=D0=B2=D1=8F=D0=B7=D1=8B=D0=B2=D0=B0?= =?UTF-8?q?=D0=B5=D0=BC=20=D1=81=D0=BE=D0=B1=D1=8B=D1=82=D0=B8=D1=8F=20?= =?UTF-8?q?=D0=B8=20=D1=81=D1=86=D0=B5=D0=BD=D0=B0=D1=80=D0=B8=D0=B8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- data_svelte/items.json | 2 +- data_svelte/scenario.txt | 7 ++++--- src/EventsAndOrders.cpp | 6 ++++++ 3 files changed, 11 insertions(+), 4 deletions(-) diff --git a/data_svelte/items.json b/data_svelte/items.json index 61a235e0..6560cb13 100644 --- a/data_svelte/items.json +++ b/data_svelte/items.json @@ -317,7 +317,7 @@ "type": "Writing", "subtype": "ButtonOut", "id": "btn", - "widget": "button", + "widget": "toggle", "page": "Кнопки", "descr": "", "int": 0, diff --git a/data_svelte/scenario.txt b/data_svelte/scenario.txt index 0e22c536..1ea6a563 100644 --- a/data_svelte/scenario.txt +++ b/data_svelte/scenario.txt @@ -1,4 +1,4 @@ -if x > 3 then 1 else x()/2 * x+2; #обратите внимание на приоритет операций +#if x > 3 then 1 else x()/2 * x+2; #обратите внимание на приоритет операций #if 1 < 3 then 1 else 2-1*1+2; #if 5 < 3 then 1+4 else 2*1*1+2; #if btn1=1 then rel2 = 1 else rel2 = 0; @@ -8,6 +8,7 @@ if x > 3 then 1 else x()/2 * x+2; #обратите внимание на пр #if rel3.run() > 30 then rel2.run(3, 45.1, "wert") else 3*1*1+2 #if rel2 == 24 then "true" else "false" -if rel2 != 1 then {rel2 = 12 + 12; rel2 = rel2 + 10;} -if rel2 != 24 then tablo.run("ddd") else "2222222222222" +#if rel2 != 1 then {rel2 = 12 + 12; rel2 = rel2 + 10;} +#if rel2 != 24 then tablo.run("ddd") else "2222222222222" +if t22 > 10 then btn.change() diff --git a/src/EventsAndOrders.cpp b/src/EventsAndOrders.cpp index 4fde9600..4a38122d 100644 --- a/src/EventsAndOrders.cpp +++ b/src/EventsAndOrders.cpp @@ -1,4 +1,7 @@ #include "EventsAndOrders.h" +#include "classes/IoTScenario.h" + +extern IoTScenario iotScen; // объект управления сценарием // orderBuf - буфер прямых команд, которые нужно выпонить сразу, нажали на кнопку в приложении, сработало условие сценария //необходимо тут же изменить параметр, записать новое значение @@ -50,10 +53,13 @@ void handleEvent() { if (eventBuf.length()) { String event = selectToMarker(eventBuf, ","); Serial.println("event: " + event); + //здесь нужно пропускать данное событие через условия сценариев //и если оно есть в условии сценария и совподает //то нужно поместить все команды этого блока сценария в generateOrder(order1, order2, ....) //который в свою очередь их выполнит + iotScen.ExecScenario(); + eventBuf = deleteBeforeDelimiter(eventBuf, ","); } } \ No newline at end of file