2022-09-26 21:56:54 +02:00
|
|
|
|
|
|
|
|
|
|
#include "Global.h"
|
2023-11-16 22:36:07 +03:00
|
|
|
|
#include "classes/IoTUart.h"
|
2022-09-26 21:56:54 +02:00
|
|
|
|
#include "classes/IoTItem.h"
|
|
|
|
|
|
#include <Arduino.h>
|
2022-09-27 00:52:53 +02:00
|
|
|
|
|
2022-09-27 01:24:22 +02:00
|
|
|
|
#include "modules/sensors/UART/Uart.h"
|
2022-09-26 21:56:54 +02:00
|
|
|
|
|
|
|
|
|
|
#ifdef ESP8266
|
2022-11-04 17:01:12 +03:00
|
|
|
|
SoftwareSerial* myUART = nullptr;
|
2022-09-26 21:56:54 +02:00
|
|
|
|
#else
|
2022-11-04 17:01:12 +03:00
|
|
|
|
HardwareSerial* myUART = nullptr;
|
2022-09-26 21:56:54 +02:00
|
|
|
|
#endif
|
|
|
|
|
|
|
2023-11-16 22:36:07 +03:00
|
|
|
|
class IoTmUART : public IoTUart {
|
2022-09-26 21:56:54 +02:00
|
|
|
|
private:
|
2022-11-04 17:01:12 +03:00
|
|
|
|
int _eventFormat = 0; // 0 - нет приема, 1 - json IoTM, 2 - Nextion
|
2023-03-26 13:24:30 +03:00
|
|
|
|
char _inc;
|
|
|
|
|
|
String _inStr = ""; // буфер приема строк в режимах 0, 1, 2
|
2022-09-26 21:56:54 +02:00
|
|
|
|
|
|
|
|
|
|
public:
|
2023-11-16 22:36:07 +03:00
|
|
|
|
IoTmUART(String parameters) : IoTUart(parameters) {
|
2022-11-04 17:01:12 +03:00
|
|
|
|
jsonRead(parameters, "eventFormat", _eventFormat);
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// проверяем формат и если событие, то регистрируем его
|
|
|
|
|
|
void analyzeString(const String& msg) {
|
|
|
|
|
|
switch (_eventFormat) {
|
|
|
|
|
|
case 0: // не указан формат, значит все полученные данные воспринимаем как общее значение из UART
|
|
|
|
|
|
setValue(msg);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 1: // формат событий IoTM с использованием json, значит создаем временную копию
|
|
|
|
|
|
analyzeMsgFromNet(msg);
|
|
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 2: // формат команд от Nextion ID=Value
|
2022-11-07 12:03:46 +03:00
|
|
|
|
if (msg.indexOf("=") == -1) { // если входящее сообщение не по формату, то работаем как в режиме 0
|
|
|
|
|
|
setValue(msg);
|
|
|
|
|
|
break;
|
|
|
|
|
|
}
|
2022-11-04 17:01:12 +03:00
|
|
|
|
String id = selectToMarker(msg, "=");
|
|
|
|
|
|
String valStr = selectToMarkerLast(msg, "=");
|
|
|
|
|
|
valStr.replace("\"", "");
|
2022-11-08 19:59:17 +03:00
|
|
|
|
id.replace(".val", "_val");
|
|
|
|
|
|
id.replace(".txt", "_txt");
|
2022-11-04 17:15:59 +03:00
|
|
|
|
generateOrder(id, valStr);
|
2022-11-04 17:01:12 +03:00
|
|
|
|
break;
|
2022-09-26 21:56:54 +02:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void uartHandle() {
|
2022-11-04 17:01:12 +03:00
|
|
|
|
if (!_myUART) return;
|
|
|
|
|
|
if (_myUART->available()) {
|
2023-11-16 22:36:07 +03:00
|
|
|
|
if (_eventFormat == 3) { // третий режим, значит ожидаем бинарный пакет данных от dwin оставлен для совместимости с предыдущей версией модуля
|
|
|
|
|
|
// используйте новый модуль для dwin DwinI
|
2023-03-26 13:24:30 +03:00
|
|
|
|
} else {
|
|
|
|
|
|
_inc = _myUART->read();
|
|
|
|
|
|
if (_inc == 0xFF) {
|
|
|
|
|
|
_inc = _myUART->read();
|
|
|
|
|
|
_inc = _myUART->read();
|
|
|
|
|
|
_inStr = "";
|
|
|
|
|
|
return;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (_inc == '\r') return;
|
|
|
|
|
|
|
|
|
|
|
|
if (_inc == '\n') {
|
|
|
|
|
|
analyzeString(_inStr);
|
|
|
|
|
|
_inStr = "";
|
|
|
|
|
|
} else _inStr += _inc;
|
|
|
|
|
|
}
|
2022-09-26 21:56:54 +02:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2022-11-04 17:01:12 +03:00
|
|
|
|
void onRegEvent(IoTItem* eventItem) {
|
2022-11-07 17:29:45 +03:00
|
|
|
|
if (!_myUART || !eventItem) return;
|
2023-01-30 21:47:05 +03:00
|
|
|
|
int indexOf_;
|
2022-11-04 17:01:12 +03:00
|
|
|
|
String printStr = "";
|
|
|
|
|
|
switch (_eventFormat) {
|
|
|
|
|
|
case 0: return; // не указан формат, значит не следим за событиями
|
|
|
|
|
|
case 1: // формат событий IoTM с использованием json
|
2022-11-07 17:29:45 +03:00
|
|
|
|
if (eventItem->isGlobal()) {
|
|
|
|
|
|
eventItem->getNetEvent(printStr);
|
|
|
|
|
|
_myUART->println(printStr);
|
|
|
|
|
|
}
|
2022-11-04 17:01:12 +03:00
|
|
|
|
break;
|
|
|
|
|
|
|
|
|
|
|
|
case 2: // формат событий для Nextion ID=Value0xFF0xFF0xFF
|
|
|
|
|
|
printStr += eventItem->getID();
|
2023-01-30 21:47:05 +03:00
|
|
|
|
indexOf_ = printStr.indexOf("_");
|
2022-11-14 19:28:14 +03:00
|
|
|
|
if (indexOf_ == -1) return; // пропускаем событие, если нет используемого признака типа данных - _txt или _vol
|
2022-11-13 20:45:10 +05:00
|
|
|
|
|
|
|
|
|
|
if (printStr.indexOf("_txt") > 0) {
|
|
|
|
|
|
printStr.replace("_txt", ".txt=\"");
|
2022-11-07 17:29:45 +03:00
|
|
|
|
printStr += eventItem->getValue();
|
2022-11-04 17:01:12 +03:00
|
|
|
|
printStr += "\"";
|
2022-11-14 19:28:14 +03:00
|
|
|
|
} else if (printStr.indexOf("_val") > 0) {
|
2022-11-15 20:01:59 +03:00
|
|
|
|
printStr += eventItem->getValue();
|
2022-11-14 19:28:14 +03:00
|
|
|
|
printStr.replace(".", "");
|
|
|
|
|
|
printStr.replace("_val", ".val=");
|
2022-11-13 20:45:10 +05:00
|
|
|
|
} else {
|
2022-11-15 20:01:59 +03:00
|
|
|
|
if (indexOf_ == printStr.length()-1) printStr.replace("_", "");
|
2022-11-14 19:28:14 +03:00
|
|
|
|
else printStr.replace("_", ".");
|
2022-11-13 20:45:10 +05:00
|
|
|
|
printStr += "=";
|
2022-11-07 17:29:45 +03:00
|
|
|
|
printStr += eventItem->getValue();
|
2022-11-13 20:45:10 +05:00
|
|
|
|
}
|
|
|
|
|
|
|
2022-11-07 17:29:45 +03:00
|
|
|
|
uartPrintFFF(printStr);
|
2022-11-04 17:01:12 +03:00
|
|
|
|
break;
|
|
|
|
|
|
}
|
2022-09-27 01:07:50 +02:00
|
|
|
|
}
|
2022-11-04 17:01:12 +03:00
|
|
|
|
|
|
|
|
|
|
IoTValue execute(String command, std::vector<IoTValue> ¶m) {
|
2023-11-16 22:36:07 +03:00
|
|
|
|
if (command == "printFFF") {
|
2022-11-07 17:29:45 +03:00
|
|
|
|
if (param.size() == 2) {
|
|
|
|
|
|
String strToUart = "";
|
2022-12-02 13:56:31 +03:00
|
|
|
|
strToUart = param[0].valS;
|
2022-11-07 17:29:45 +03:00
|
|
|
|
|
|
|
|
|
|
if (param[1].valD)
|
|
|
|
|
|
uartPrintFFF("\"" + strToUart + "\"");
|
|
|
|
|
|
else
|
|
|
|
|
|
uartPrintFFF(strToUart);
|
|
|
|
|
|
}
|
2023-11-16 22:36:07 +03:00
|
|
|
|
} else { // не забываем, что переопределяем execute и нужно проверить что в базовом классе проверяется
|
|
|
|
|
|
return IoTUart::execute(command, param);
|
|
|
|
|
|
}
|
2022-11-04 17:01:12 +03:00
|
|
|
|
|
|
|
|
|
|
return {};
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2023-11-16 22:36:07 +03:00
|
|
|
|
void uartPrintFFF(const String& msg) {
|
|
|
|
|
|
if (_myUART) {
|
|
|
|
|
|
_myUART->print(msg);
|
|
|
|
|
|
_myUART->write(0xff);
|
|
|
|
|
|
_myUART->write(0xff);
|
|
|
|
|
|
_myUART->write(0xff);
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
2022-09-26 21:56:54 +02:00
|
|
|
|
};
|
|
|
|
|
|
|
2022-09-27 01:24:22 +02:00
|
|
|
|
void* getAPI_UART(String subtype, String param) {
|
|
|
|
|
|
if (subtype == F("UART")) {
|
2023-03-28 09:14:03 +03:00
|
|
|
|
return new IoTmUART(param);
|
2022-09-26 21:56:54 +02:00
|
|
|
|
} else {
|
|
|
|
|
|
return nullptr;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|