mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-31 04:19:15 +03:00
добавление графиков дневного расхода
This commit is contained in:
3
.vscode/settings.json
vendored
3
.vscode/settings.json
vendored
@@ -8,6 +8,7 @@
|
|||||||
"vector": "cpp",
|
"vector": "cpp",
|
||||||
"string_view": "cpp",
|
"string_view": "cpp",
|
||||||
"initializer_list": "cpp",
|
"initializer_list": "cpp",
|
||||||
"ranges": "cpp"
|
"ranges": "cpp",
|
||||||
|
"thread": "cpp"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
Binary file not shown.
Binary file not shown.
@@ -4,12 +4,12 @@
|
|||||||
<meta charset="utf-8" />
|
<meta charset="utf-8" />
|
||||||
<meta name="viewport" content="width=device-width,initial-scale=1" />
|
<meta name="viewport" content="width=device-width,initial-scale=1" />
|
||||||
|
|
||||||
<title>IoT Manager 4.3.4</title>
|
<title>IoT Manager 4.3.5</title>
|
||||||
|
|
||||||
<link rel="icon" type="image/png" href="/favicon.ico" />
|
<link rel="icon" type="image/png" href="/favicon.ico" />
|
||||||
<link rel="stylesheet" href="/build/bundle.css?434" />
|
<link rel="stylesheet" href="/build/bundle.css?435" />
|
||||||
|
|
||||||
<script defer src="/build/bundle.js?434"></script>
|
<script defer src="/build/bundle.js?435"></script>
|
||||||
</head>
|
</head>
|
||||||
|
|
||||||
<body></body>
|
<body></body>
|
||||||
|
|||||||
@@ -7,7 +7,7 @@
|
|||||||
"header": "Виртуальные элементы"
|
"header": "Виртуальные элементы"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "1. Логирование в график",
|
"name": "1. График",
|
||||||
"type": "Writing",
|
"type": "Writing",
|
||||||
"subtype": "Loging",
|
"subtype": "Loging",
|
||||||
"id": "log",
|
"id": "log",
|
||||||
@@ -20,7 +20,20 @@
|
|||||||
"points": 300
|
"points": 300
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "2. Таймер",
|
"name": "2. График дневного расхода",
|
||||||
|
"type": "Writing",
|
||||||
|
"subtype": "LogingDaily",
|
||||||
|
"id": "log",
|
||||||
|
"widget": "chart3",
|
||||||
|
"page": "Графики",
|
||||||
|
"descr": "Температура",
|
||||||
|
"num": 2,
|
||||||
|
"int": 1,
|
||||||
|
"logid": "t",
|
||||||
|
"points": 365
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "3. Таймер",
|
||||||
"type": "Writing",
|
"type": "Writing",
|
||||||
"subtype": "Timer",
|
"subtype": "Timer",
|
||||||
"id": "timer",
|
"id": "timer",
|
||||||
@@ -32,10 +45,10 @@
|
|||||||
"ticker": 1,
|
"ticker": 1,
|
||||||
"repeat": 1,
|
"repeat": 1,
|
||||||
"needSave": 0,
|
"needSave": 0,
|
||||||
"num": 2
|
"num": 3
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "3. Окно ввода числа (переменная)",
|
"name": "4. Окно ввода числа (переменная)",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Variable",
|
"subtype": "Variable",
|
||||||
"id": "value",
|
"id": "value",
|
||||||
@@ -44,10 +57,10 @@
|
|||||||
"descr": "Введите число",
|
"descr": "Введите число",
|
||||||
"int": "0",
|
"int": "0",
|
||||||
"val": "0.0",
|
"val": "0.0",
|
||||||
"num": 3
|
"num": 4
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "4. Окно ввода времени",
|
"name": "5. Окно ввода времени",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Variable",
|
"subtype": "Variable",
|
||||||
"id": "time",
|
"id": "time",
|
||||||
@@ -56,10 +69,10 @@
|
|||||||
"descr": "Введите время",
|
"descr": "Введите время",
|
||||||
"int": "0",
|
"int": "0",
|
||||||
"val": "02:00",
|
"val": "02:00",
|
||||||
"num": 4
|
"num": 5
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "5. Окно ввода даты",
|
"name": "6. Окно ввода даты",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Variable",
|
"subtype": "Variable",
|
||||||
"id": "time",
|
"id": "time",
|
||||||
@@ -68,10 +81,10 @@
|
|||||||
"descr": "Введите дату",
|
"descr": "Введите дату",
|
||||||
"int": "0",
|
"int": "0",
|
||||||
"val": "24.05.2022",
|
"val": "24.05.2022",
|
||||||
"num": 5
|
"num": 6
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "6. Окно ввода текста",
|
"name": "7. Окно ввода текста",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Variable",
|
"subtype": "Variable",
|
||||||
"id": "txt",
|
"id": "txt",
|
||||||
@@ -80,10 +93,10 @@
|
|||||||
"descr": "Введите текст",
|
"descr": "Введите текст",
|
||||||
"int": "0",
|
"int": "0",
|
||||||
"val": "текст",
|
"val": "текст",
|
||||||
"num": 6
|
"num": 7
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "7. Виртуальная кнопка",
|
"name": "8. Виртуальная кнопка",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "VButton",
|
"subtype": "VButton",
|
||||||
"id": "vbtn",
|
"id": "vbtn",
|
||||||
@@ -92,13 +105,13 @@
|
|||||||
"descr": "Кнопка",
|
"descr": "Кнопка",
|
||||||
"int": "0",
|
"int": "0",
|
||||||
"val": "0",
|
"val": "0",
|
||||||
"num": 7
|
"num": 8
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"header": "Сенсоры"
|
"header": "Сенсоры"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "8. Acs712 Ток",
|
"name": "9. Acs712 Ток",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Acs712",
|
"subtype": "Acs712",
|
||||||
"id": "amp",
|
"id": "amp",
|
||||||
@@ -108,10 +121,10 @@
|
|||||||
"round": 3,
|
"round": 3,
|
||||||
"pin": 39,
|
"pin": 39,
|
||||||
"int": 5,
|
"int": 5,
|
||||||
"num": 8
|
"num": 9
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "9. AHT20 Температура",
|
"name": "10. AHT20 Температура",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Aht20t",
|
"subtype": "Aht20t",
|
||||||
"id": "Temp20",
|
"id": "Temp20",
|
||||||
@@ -121,10 +134,10 @@
|
|||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0x38",
|
"addr": "0x38",
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 9
|
"num": 10
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "10. AHT20 Влажность",
|
"name": "11. AHT20 Влажность",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Aht20h",
|
"subtype": "Aht20h",
|
||||||
"id": "Hum20",
|
"id": "Hum20",
|
||||||
@@ -134,10 +147,10 @@
|
|||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0x38",
|
"addr": "0x38",
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 10
|
"num": 11
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "11. Аналоговый сенсор",
|
"name": "12. Аналоговый сенсор",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "AnalogAdc",
|
"subtype": "AnalogAdc",
|
||||||
"id": "t",
|
"id": "t",
|
||||||
@@ -151,10 +164,10 @@
|
|||||||
"pin": 0,
|
"pin": 0,
|
||||||
"int": 15,
|
"int": 15,
|
||||||
"avgSteps": 1,
|
"avgSteps": 1,
|
||||||
"num": 11
|
"num": 12
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "12. BME280 Температура",
|
"name": "13. BME280 Температура",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Bme280t",
|
"subtype": "Bme280t",
|
||||||
"id": "tmp3",
|
"id": "tmp3",
|
||||||
@@ -164,10 +177,10 @@
|
|||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0x77",
|
"addr": "0x77",
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 12
|
"num": 13
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "13. BME280 Давление",
|
"name": "14. BME280 Давление",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Bme280p",
|
"subtype": "Bme280p",
|
||||||
"id": "Press3",
|
"id": "Press3",
|
||||||
@@ -177,10 +190,10 @@
|
|||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0x77",
|
"addr": "0x77",
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 13
|
"num": 14
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "14. BME280 Влажность",
|
"name": "15. BME280 Влажность",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Bme280h",
|
"subtype": "Bme280h",
|
||||||
"id": "Hum3",
|
"id": "Hum3",
|
||||||
@@ -190,10 +203,10 @@
|
|||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0x77",
|
"addr": "0x77",
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 14
|
"num": 15
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "15. BMP280 Температура",
|
"name": "16. BMP280 Температура",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Bmp280t",
|
"subtype": "Bmp280t",
|
||||||
"id": "tmp3",
|
"id": "tmp3",
|
||||||
@@ -203,10 +216,10 @@
|
|||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0x77",
|
"addr": "0x77",
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 15
|
"num": 16
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "16. BMP280 Давление",
|
"name": "17. BMP280 Давление",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Bmp280p",
|
"subtype": "Bmp280p",
|
||||||
"id": "Press3",
|
"id": "Press3",
|
||||||
@@ -216,10 +229,10 @@
|
|||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0x77",
|
"addr": "0x77",
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 16
|
"num": 17
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "17. DHT11 Температура",
|
"name": "18. DHT11 Температура",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Dht1122t",
|
"subtype": "Dht1122t",
|
||||||
"id": "tmp3",
|
"id": "tmp3",
|
||||||
@@ -229,10 +242,10 @@
|
|||||||
"int": 15,
|
"int": 15,
|
||||||
"pin": 0,
|
"pin": 0,
|
||||||
"senstype": "dht11",
|
"senstype": "dht11",
|
||||||
"num": 17
|
"num": 18
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "18. DHT11 Влажность",
|
"name": "19. DHT11 Влажность",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Dht1122h",
|
"subtype": "Dht1122h",
|
||||||
"id": "Hum3",
|
"id": "Hum3",
|
||||||
@@ -242,10 +255,10 @@
|
|||||||
"int": 15,
|
"int": 15,
|
||||||
"pin": 0,
|
"pin": 0,
|
||||||
"senstype": "dht11",
|
"senstype": "dht11",
|
||||||
"num": 18
|
"num": 19
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "19. DS18B20 Температура",
|
"name": "20. DS18B20 Температура",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Ds18b20",
|
"subtype": "Ds18b20",
|
||||||
"id": "dstmp",
|
"id": "dstmp",
|
||||||
@@ -257,10 +270,10 @@
|
|||||||
"index": 0,
|
"index": 0,
|
||||||
"addr": "",
|
"addr": "",
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 19
|
"num": 20
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "20. GY21 Температура",
|
"name": "21. GY21 Температура",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "GY21t",
|
"subtype": "GY21t",
|
||||||
"id": "tmp4",
|
"id": "tmp4",
|
||||||
@@ -269,10 +282,10 @@
|
|||||||
"descr": "Температура",
|
"descr": "Температура",
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"int": 15,
|
"int": 15,
|
||||||
"num": 20
|
"num": 21
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "21. GY21 Влажность",
|
"name": "22. GY21 Влажность",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "GY21h",
|
"subtype": "GY21h",
|
||||||
"id": "Hum4",
|
"id": "Hum4",
|
||||||
@@ -281,10 +294,10 @@
|
|||||||
"descr": "Влажность",
|
"descr": "Влажность",
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"int": 15,
|
"int": 15,
|
||||||
"num": 21
|
"num": 22
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "22. HDC1080 Температура",
|
"name": "23. HDC1080 Температура",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Hdc1080t",
|
"subtype": "Hdc1080t",
|
||||||
"id": "Temp1080",
|
"id": "Temp1080",
|
||||||
@@ -294,10 +307,10 @@
|
|||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0x40",
|
"addr": "0x40",
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 22
|
"num": 23
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "23. HDC1080 Влажность",
|
"name": "24. HDC1080 Влажность",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Hdc1080h",
|
"subtype": "Hdc1080h",
|
||||||
"id": "Hum1080",
|
"id": "Hum1080",
|
||||||
@@ -307,10 +320,10 @@
|
|||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0x40",
|
"addr": "0x40",
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 23
|
"num": 24
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "24. MAX6675 Температура",
|
"name": "25. MAX6675 Температура",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Max6675t",
|
"subtype": "Max6675t",
|
||||||
"id": "maxtmp",
|
"id": "maxtmp",
|
||||||
@@ -321,10 +334,10 @@
|
|||||||
"DO": 12,
|
"DO": 12,
|
||||||
"CS": 13,
|
"CS": 13,
|
||||||
"CLK": 14,
|
"CLK": 14,
|
||||||
"num": 24
|
"num": 25
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "25. PZEM 004t Напряжение",
|
"name": "26. PZEM 004t Напряжение",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Pzem004v",
|
"subtype": "Pzem004v",
|
||||||
"id": "v",
|
"id": "v",
|
||||||
@@ -333,10 +346,10 @@
|
|||||||
"descr": "Напряжение",
|
"descr": "Напряжение",
|
||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0xF8",
|
"addr": "0xF8",
|
||||||
"num": 25
|
"num": 26
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "26. PZEM 004t Сила тока",
|
"name": "27. PZEM 004t Сила тока",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Pzem004a",
|
"subtype": "Pzem004a",
|
||||||
"id": "a",
|
"id": "a",
|
||||||
@@ -345,10 +358,10 @@
|
|||||||
"descr": "Сила тока",
|
"descr": "Сила тока",
|
||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0xF8",
|
"addr": "0xF8",
|
||||||
"num": 26
|
"num": 27
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "27. PZEM 004t Мощность",
|
"name": "28. PZEM 004t Мощность",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Pzem004w",
|
"subtype": "Pzem004w",
|
||||||
"id": "w",
|
"id": "w",
|
||||||
@@ -357,10 +370,10 @@
|
|||||||
"descr": "Мощность",
|
"descr": "Мощность",
|
||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0xF8",
|
"addr": "0xF8",
|
||||||
"num": 27
|
"num": 28
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "28. PZEM 004t Энергия",
|
"name": "29. PZEM 004t Энергия",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Pzem004wh",
|
"subtype": "Pzem004wh",
|
||||||
"id": "wh",
|
"id": "wh",
|
||||||
@@ -369,10 +382,10 @@
|
|||||||
"descr": "Энергия",
|
"descr": "Энергия",
|
||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0xF8",
|
"addr": "0xF8",
|
||||||
"num": 28
|
"num": 29
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "29. PZEM 004t Частота",
|
"name": "30. PZEM 004t Частота",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Pzem004hz",
|
"subtype": "Pzem004hz",
|
||||||
"id": "hz",
|
"id": "hz",
|
||||||
@@ -381,11 +394,11 @@
|
|||||||
"descr": "Частота",
|
"descr": "Частота",
|
||||||
"int": 15,
|
"int": 15,
|
||||||
"addr": "0xF8",
|
"addr": "0xF8",
|
||||||
"num": 29
|
"num": 30
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "30. Сканер кнопок 433 MHz",
|
"name": "31. Сканер кнопок 433 MHz",
|
||||||
"num": 30,
|
"num": 31,
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "RCswitch",
|
"subtype": "RCswitch",
|
||||||
"id": "rsw",
|
"id": "rsw",
|
||||||
@@ -394,7 +407,7 @@
|
|||||||
"pinTx": 12
|
"pinTx": 12
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "31. Sht20 Температура",
|
"name": "32. Sht20 Температура",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Sht20t",
|
"subtype": "Sht20t",
|
||||||
"id": "tmp2",
|
"id": "tmp2",
|
||||||
@@ -403,10 +416,10 @@
|
|||||||
"descr": "Температура",
|
"descr": "Температура",
|
||||||
"int": 15,
|
"int": 15,
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 31
|
"num": 32
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "32. Sht20 Влажность",
|
"name": "33. Sht20 Влажность",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Sht20h",
|
"subtype": "Sht20h",
|
||||||
"id": "Hum2",
|
"id": "Hum2",
|
||||||
@@ -415,10 +428,10 @@
|
|||||||
"descr": "Влажность",
|
"descr": "Влажность",
|
||||||
"int": 15,
|
"int": 15,
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 32
|
"num": 33
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "33. Sht30 Температура",
|
"name": "34. Sht30 Температура",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Sht30t",
|
"subtype": "Sht30t",
|
||||||
"id": "tmp30",
|
"id": "tmp30",
|
||||||
@@ -427,10 +440,10 @@
|
|||||||
"descr": "SHT30 Температура",
|
"descr": "SHT30 Температура",
|
||||||
"int": 15,
|
"int": 15,
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 33
|
"num": 34
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "34. Sht30 Влажность",
|
"name": "35. Sht30 Влажность",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Sht30h",
|
"subtype": "Sht30h",
|
||||||
"id": "Hum30",
|
"id": "Hum30",
|
||||||
@@ -439,11 +452,11 @@
|
|||||||
"descr": "SHT30 Влажность",
|
"descr": "SHT30 Влажность",
|
||||||
"int": 15,
|
"int": 15,
|
||||||
"round": 1,
|
"round": 1,
|
||||||
"num": 34
|
"num": 35
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "35. HC-SR04 Ультразвуковой дальномер",
|
"name": "36. HC-SR04 Ультразвуковой дальномер",
|
||||||
"num": 35,
|
"num": 36,
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Sonar",
|
"subtype": "Sonar",
|
||||||
"id": "sonar",
|
"id": "sonar",
|
||||||
@@ -455,7 +468,7 @@
|
|||||||
"int": 5
|
"int": 5
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "36. UART",
|
"name": "37. UART",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "UART",
|
"subtype": "UART",
|
||||||
"page": "",
|
"page": "",
|
||||||
@@ -465,13 +478,13 @@
|
|||||||
"tx": 12,
|
"tx": 12,
|
||||||
"rx": 13,
|
"rx": 13,
|
||||||
"speed": 9600,
|
"speed": 9600,
|
||||||
"num": 36
|
"num": 37
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"header": "Исполнительные устройства"
|
"header": "Исполнительные устройства"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "37. Кнопка подключенная к пину",
|
"name": "38. Кнопка подключенная к пину",
|
||||||
"type": "Writing",
|
"type": "Writing",
|
||||||
"subtype": "ButtonIn",
|
"subtype": "ButtonIn",
|
||||||
"id": "btn",
|
"id": "btn",
|
||||||
@@ -484,10 +497,10 @@
|
|||||||
"pinMode": "INPUT",
|
"pinMode": "INPUT",
|
||||||
"debounceDelay": 50,
|
"debounceDelay": 50,
|
||||||
"fixState": 0,
|
"fixState": 0,
|
||||||
"num": 37
|
"num": 38
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "38. Управление пином",
|
"name": "39. Управление пином",
|
||||||
"type": "Writing",
|
"type": "Writing",
|
||||||
"subtype": "ButtonOut",
|
"subtype": "ButtonOut",
|
||||||
"id": "btn",
|
"id": "btn",
|
||||||
@@ -497,10 +510,10 @@
|
|||||||
"int": 0,
|
"int": 0,
|
||||||
"inv": 0,
|
"inv": 0,
|
||||||
"pin": 2,
|
"pin": 2,
|
||||||
"num": 38
|
"num": 39
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "39. Сервопривод",
|
"name": "40. Сервопривод",
|
||||||
"type": "Writing",
|
"type": "Writing",
|
||||||
"subtype": "IoTServo",
|
"subtype": "IoTServo",
|
||||||
"id": "servo",
|
"id": "servo",
|
||||||
@@ -511,10 +524,10 @@
|
|||||||
"pin": 12,
|
"pin": 12,
|
||||||
"apin": -1,
|
"apin": -1,
|
||||||
"amap": "0, 4096, 0, 180",
|
"amap": "0, 4096, 0, 180",
|
||||||
"num": 39
|
"num": 40
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "40. Расширитель портов Mcp23017",
|
"name": "41. Расширитель портов Mcp23017",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Mcp23017",
|
"subtype": "Mcp23017",
|
||||||
"id": "Mcp",
|
"id": "Mcp",
|
||||||
@@ -524,10 +537,10 @@
|
|||||||
"int": "0",
|
"int": "0",
|
||||||
"addr": "0x20",
|
"addr": "0x20",
|
||||||
"index": 1,
|
"index": 1,
|
||||||
"num": 40
|
"num": 41
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "41. MP3 плеер",
|
"name": "42. MP3 плеер",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Mp3",
|
"subtype": "Mp3",
|
||||||
"id": "mp3",
|
"id": "mp3",
|
||||||
@@ -537,10 +550,10 @@
|
|||||||
"int": 1,
|
"int": 1,
|
||||||
"pins": "14,12",
|
"pins": "14,12",
|
||||||
"volume": 20,
|
"volume": 20,
|
||||||
"num": 41
|
"num": 42
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "42. PWM ESP8266",
|
"name": "43. PWM ESP8266",
|
||||||
"type": "Writing",
|
"type": "Writing",
|
||||||
"subtype": "Pwm8266",
|
"subtype": "Pwm8266",
|
||||||
"id": "pwm",
|
"id": "pwm",
|
||||||
@@ -552,10 +565,10 @@
|
|||||||
"freq": 5000,
|
"freq": 5000,
|
||||||
"val": 0,
|
"val": 0,
|
||||||
"apin": -1,
|
"apin": -1,
|
||||||
"num": 42
|
"num": 43
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "43. Телеграм-Лайт",
|
"name": "44. Телеграм-Лайт",
|
||||||
"type": "Writing",
|
"type": "Writing",
|
||||||
"subtype": "TelegramLT",
|
"subtype": "TelegramLT",
|
||||||
"id": "tg",
|
"id": "tg",
|
||||||
@@ -564,13 +577,13 @@
|
|||||||
"descr": "",
|
"descr": "",
|
||||||
"token": "",
|
"token": "",
|
||||||
"chatID": "",
|
"chatID": "",
|
||||||
"num": 43
|
"num": 44
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"header": "Экраны"
|
"header": "Экраны"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "44. LCD экран 2004",
|
"name": "45. LCD экран 2004",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Lcd2004",
|
"subtype": "Lcd2004",
|
||||||
"id": "Lcd",
|
"id": "Lcd",
|
||||||
@@ -582,10 +595,10 @@
|
|||||||
"size": "20,4",
|
"size": "20,4",
|
||||||
"coord": "0,0",
|
"coord": "0,0",
|
||||||
"id2show": "id датчика",
|
"id2show": "id датчика",
|
||||||
"num": 44
|
"num": 45
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "45. LCD экран 1602",
|
"name": "46. LCD экран 1602",
|
||||||
"type": "Reading",
|
"type": "Reading",
|
||||||
"subtype": "Lcd2004",
|
"subtype": "Lcd2004",
|
||||||
"id": "Lcd",
|
"id": "Lcd",
|
||||||
@@ -597,6 +610,6 @@
|
|||||||
"size": "16,2",
|
"size": "16,2",
|
||||||
"coord": "0,0",
|
"coord": "0,0",
|
||||||
"id2show": "id датчика",
|
"id2show": "id датчика",
|
||||||
"num": 45
|
"num": 46
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
@@ -47,7 +47,7 @@
|
|||||||
"name": "anydataWth",
|
"name": "anydataWth",
|
||||||
"label": "Энергия",
|
"label": "Энергия",
|
||||||
"widget": "anydata",
|
"widget": "anydata",
|
||||||
"after": "Wt/Hr",
|
"after": "kWt/Hr",
|
||||||
"icon": "speedometer"
|
"icon": "speedometer"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
@@ -103,34 +103,27 @@
|
|||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "chart1",
|
"name": "chart1",
|
||||||
"label": "График1",
|
"label": "График без точек",
|
||||||
"widget": "chart",
|
"widget": "chart",
|
||||||
"dateFormat": "HH:mm",
|
"dateFormat": "HH:mm",
|
||||||
"maxCount": 255,
|
"maxCount": 86400,
|
||||||
"pointRadius": 0
|
"pointRadius": 0
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "chart2",
|
"name": "chart2",
|
||||||
"label": "График2",
|
"label": "График с точками",
|
||||||
"widget": "chart",
|
"widget": "chart",
|
||||||
"maxCount": 255,
|
"maxCount": 86400,
|
||||||
"dateFormat": "HH:mm"
|
"dateFormat": "HH:mm"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "chart3",
|
"name": "chart3",
|
||||||
"label": "График3",
|
"label": "График Дневной",
|
||||||
"widget": "chart",
|
"widget": "chart",
|
||||||
"dateFormat": "DD.MM.YYYY",
|
"dateFormat": "DD.MM.YYYY",
|
||||||
"maxCount": 255,
|
"maxCount": 86400,
|
||||||
"type": "bar"
|
"type": "bar"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"name": "chart4",
|
|
||||||
"label": "График4",
|
|
||||||
"widget": "chart",
|
|
||||||
"maxCount": 255,
|
|
||||||
"dateFormat": "DD.MM.YYYY"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"name": "fillgauge",
|
"name": "fillgauge",
|
||||||
"label": "Бочка",
|
"label": "Бочка",
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
//Версия прошивки
|
//Версия прошивки
|
||||||
#define FIRMWARE_VERSION 426
|
#define FIRMWARE_VERSION 427
|
||||||
|
|
||||||
#ifdef esp8266_4mb
|
#ifdef esp8266_4mb
|
||||||
#define FIRMWARE_NAME "esp8266_4mb"
|
#define FIRMWARE_NAME "esp8266_4mb"
|
||||||
|
|||||||
@@ -28,7 +28,11 @@
|
|||||||
"modules": {
|
"modules": {
|
||||||
"Виртуальные элементы": [
|
"Виртуальные элементы": [
|
||||||
{
|
{
|
||||||
"path": "src\\modules\\virtual\\Logging",
|
"path": "src\\modules\\virtual\\Loging",
|
||||||
|
"active": true
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"path": "src\\modules\\virtual\\LogingDaily",
|
||||||
"active": true
|
"active": true
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -71,7 +71,8 @@ lib_deps =
|
|||||||
dfrobot/DFRobotDFPlayerMini @ ^1.0.5
|
dfrobot/DFRobotDFPlayerMini @ ^1.0.5
|
||||||
marcoschwartz/LiquidCrystal_I2C@^1.1.4
|
marcoschwartz/LiquidCrystal_I2C@^1.1.4
|
||||||
build_src_filter =
|
build_src_filter =
|
||||||
+<modules\virtual\Logging>
|
+<modules\virtual\Loging>
|
||||||
|
+<modules\virtual\LogingDaily>
|
||||||
+<modules\virtual\Timer>
|
+<modules\virtual\Timer>
|
||||||
+<modules\virtual\Variable>
|
+<modules\virtual\Variable>
|
||||||
+<modules\virtual\VButton>
|
+<modules\virtual\VButton>
|
||||||
|
|||||||
@@ -134,9 +134,10 @@ void mqttCallback(char* topic, uint8_t* payload, size_t length) {
|
|||||||
publishWidgets();
|
publishWidgets();
|
||||||
publishState();
|
publishState();
|
||||||
|
|
||||||
|
//обращение к логированию из ядра
|
||||||
//отправка данных графиков
|
//отправка данных графиков
|
||||||
for (std::list<IoTItem*>::iterator it = IoTItems.begin(); it != IoTItems.end(); ++it) {
|
for (std::list<IoTItem*>::iterator it = IoTItems.begin(); it != IoTItems.end(); ++it) {
|
||||||
if ((*it)->getSubtype() == "Loging") {
|
if ((*it)->getSubtype() == "Loging" || "LogingDaily") {
|
||||||
(*it)->setPublishDestination(TO_MQTT);
|
(*it)->setPublishDestination(TO_MQTT);
|
||||||
(*it)->publishValue();
|
(*it)->publishValue();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -73,13 +73,14 @@ void webSocketEvent(uint8_t num, WStype_t type, uint8_t* payload, size_t length)
|
|||||||
|
|
||||||
//отвечаем на запрос графиков
|
//отвечаем на запрос графиков
|
||||||
if (headerStr == "/charts|") {
|
if (headerStr == "/charts|") {
|
||||||
|
//обращение к логированию из ядра
|
||||||
//отправка данных графиков только в выбранный сокет
|
//отправка данных графиков только в выбранный сокет
|
||||||
for (std::list<IoTItem*>::iterator it = IoTItems.begin(); it != IoTItems.end(); ++it) {
|
for (std::list<IoTItem*>::iterator it = IoTItems.begin(); it != IoTItems.end(); ++it) {
|
||||||
//сбрасываем даты графиков
|
//сбрасываем даты графиков
|
||||||
// if ((*it)->getID().endsWith("-date")) {
|
// if ((*it)->getID().endsWith("-date")) {
|
||||||
// (*it)->setTodayDate();
|
// (*it)->setTodayDate();
|
||||||
//}
|
//}
|
||||||
if ((*it)->getSubtype() == "Loging") {
|
if ((*it)->getSubtype() == "Loging" || "LogingDaily") {
|
||||||
(*it)->setPublishDestination(TO_WS, num);
|
(*it)->setPublishDestination(TO_WS, num);
|
||||||
(*it)->publishValue();
|
(*it)->publishValue();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
#include "ESPConfiguration.h"
|
#include "ESPConfiguration.h"
|
||||||
|
|
||||||
void* getAPI_Loging(String subtype, String params);
|
void* getAPI_Loging(String subtype, String params);
|
||||||
|
void* getAPI_LogingDaily(String subtype, String params);
|
||||||
void* getAPI_Timer(String subtype, String params);
|
void* getAPI_Timer(String subtype, String params);
|
||||||
void* getAPI_Variable(String subtype, String params);
|
void* getAPI_Variable(String subtype, String params);
|
||||||
void* getAPI_VButton(String subtype, String params);
|
void* getAPI_VButton(String subtype, String params);
|
||||||
@@ -32,6 +33,7 @@ void* getAPI_Lcd2004(String subtype, String params);
|
|||||||
void* getAPI(String subtype, String params) {
|
void* getAPI(String subtype, String params) {
|
||||||
void* tmpAPI;
|
void* tmpAPI;
|
||||||
if ((tmpAPI = getAPI_Loging(subtype, params)) != nullptr) return tmpAPI;
|
if ((tmpAPI = getAPI_Loging(subtype, params)) != nullptr) return tmpAPI;
|
||||||
|
if ((tmpAPI = getAPI_LogingDaily(subtype, params)) != nullptr) return tmpAPI;
|
||||||
if ((tmpAPI = getAPI_Timer(subtype, params)) != nullptr) return tmpAPI;
|
if ((tmpAPI = getAPI_Timer(subtype, params)) != nullptr) return tmpAPI;
|
||||||
if ((tmpAPI = getAPI_Variable(subtype, params)) != nullptr) return tmpAPI;
|
if ((tmpAPI = getAPI_Variable(subtype, params)) != nullptr) return tmpAPI;
|
||||||
if ((tmpAPI = getAPI_VButton(subtype, params)) != nullptr) return tmpAPI;
|
if ((tmpAPI = getAPI_VButton(subtype, params)) != nullptr) return tmpAPI;
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
"menuSection": "Виртуальные элементы",
|
"menuSection": "Виртуальные элементы",
|
||||||
"configItem": [
|
"configItem": [
|
||||||
{
|
{
|
||||||
"name": "Логирование в график",
|
"name": "График",
|
||||||
"type": "Writing",
|
"type": "Writing",
|
||||||
"subtype": "Loging",
|
"subtype": "Loging",
|
||||||
"id": "log",
|
"id": "log",
|
||||||
@@ -24,7 +24,7 @@
|
|||||||
"moduleVersion": "3.0",
|
"moduleVersion": "3.0",
|
||||||
"usedRam": 15,
|
"usedRam": 15,
|
||||||
"title": "Логирование в график",
|
"title": "Логирование в график",
|
||||||
"moduleDesc": "Расширение позволяющее логировать любую величину в график. Графики доступны в мобильном приложении и в веб интерфейсе. Данные графиков хранятся в встроенной памяти esp. В окне ввода даты нужно выбрать день, историю которого вы хотите посмотреть. Старые файлы будут удаляться автоматически после того как объем оставшейся flesh памяти устройства будет менее 20 процентов",
|
"moduleDesc": "Расширение позволяющее логировать любую величину в график. Графики доступны в мобильном приложении и в веб интерфейсе. Данные графиков хранятся в встроенной памяти esp. В окне ввода даты можно выбирать день, историю которого вы хотите посмотреть. Старые файлы будут удаляться автоматически после того как объем оставшейся flesh памяти устройства будет менее 20 процентов",
|
||||||
"propInfo": {
|
"propInfo": {
|
||||||
"int": "Интервал логирования в мнутах, рекомендуется для esp8266 использоать интервал не менее 5-ти минут",
|
"int": "Интервал логирования в мнутах, рекомендуется для esp8266 использоать интервал не менее 5-ти минут",
|
||||||
"logid": "ID величины которую будем логировать",
|
"logid": "ID величины которую будем логировать",
|
||||||
282
src/modules/virtual/LogingDaily/LogingDaily.cpp
Normal file
282
src/modules/virtual/LogingDaily/LogingDaily.cpp
Normal file
@@ -0,0 +1,282 @@
|
|||||||
|
#include "Global.h"
|
||||||
|
#include "classes/IoTItem.h"
|
||||||
|
#include "ESPConfiguration.h"
|
||||||
|
#include "NTP.h"
|
||||||
|
|
||||||
|
class LogingDaily : public IoTItem {
|
||||||
|
private:
|
||||||
|
String logid;
|
||||||
|
String id;
|
||||||
|
String filesList = "";
|
||||||
|
|
||||||
|
int _publishType = -2;
|
||||||
|
int _wsNum = -1;
|
||||||
|
|
||||||
|
int points;
|
||||||
|
|
||||||
|
IoTItem *dateIoTItem;
|
||||||
|
|
||||||
|
String prevDate = "";
|
||||||
|
bool firstTimeDate = true;
|
||||||
|
|
||||||
|
unsigned long interval;
|
||||||
|
|
||||||
|
public:
|
||||||
|
LogingDaily(String parameters) : IoTItem(parameters) {
|
||||||
|
jsonRead(parameters, F("logid"), logid);
|
||||||
|
jsonRead(parameters, F("id"), id);
|
||||||
|
jsonRead(parameters, F("points"), points);
|
||||||
|
|
||||||
|
if (points > 365) {
|
||||||
|
points = 365;
|
||||||
|
SerialPrint("E", F("LogingDaily"), "'" + id + "' user set more points than allowed, value reset to 365");
|
||||||
|
}
|
||||||
|
jsonRead(parameters, F("int"), interval);
|
||||||
|
interval = interval * 1000 * 60; //приводим к милисекундам
|
||||||
|
}
|
||||||
|
|
||||||
|
void doByInterval() {
|
||||||
|
if (hasDayChanged()) {
|
||||||
|
execute();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void execute() {
|
||||||
|
//если объект логгирования не был создан
|
||||||
|
if (!isItemExist(logid)) {
|
||||||
|
SerialPrint("E", F("LogingDaily"), "'" + id + "' LogingDaily object not exist, return");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
String value = getItemValue(logid);
|
||||||
|
|
||||||
|
//если значение логгирования пустое
|
||||||
|
if (value == "") {
|
||||||
|
SerialPrint("E", F("LogingDaily"), "'" + id + "' LogingDaily value is empty, return");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
//если время не было получено из интернета
|
||||||
|
if (!isTimeSynch) {
|
||||||
|
SerialPrint("E", F("LogingDaily"), "'" + id + "' Сant LogingDaily - time not synchronized, return");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
String logData;
|
||||||
|
|
||||||
|
float currentValue = value.toFloat();
|
||||||
|
//прочитаем предудущее значение
|
||||||
|
float prevValue = readDataDB(id + "-v").toFloat();
|
||||||
|
//сохраним в базу данных текущее значение, понадобится в следующие сутки
|
||||||
|
saveDataDB(id + "-v", value);
|
||||||
|
|
||||||
|
float difference = currentValue - prevValue;
|
||||||
|
|
||||||
|
jsonWriteInt(logData, "x", unixTime);
|
||||||
|
jsonWriteFloat(logData, "y1", difference);
|
||||||
|
|
||||||
|
//прочитаем путь к файлу последнего сохранения
|
||||||
|
String filePath = readDataDB(id);
|
||||||
|
|
||||||
|
//если данные о файле отсутствуют, создадим новый
|
||||||
|
if (filePath == "failed" || filePath == "") {
|
||||||
|
SerialPrint("E", F("LogingDaily"), "'" + id + "' file path not found, start create new file");
|
||||||
|
createNewFileWithData(logData);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
//считаем количество строк и определяем размер файла
|
||||||
|
size_t size = 0;
|
||||||
|
int lines = countJsonObj(filePath, size);
|
||||||
|
SerialPrint("i", F("LogingDaily"), "'" + id + "' " + "lines = " + String(lines) + ", size = " + String(size));
|
||||||
|
|
||||||
|
//если количество строк до заданной величины и дата не менялась
|
||||||
|
if (lines <= points && !hasDayChanged()) {
|
||||||
|
//просто добавим в существующий файл новые данные
|
||||||
|
addNewDataToExistingFile(filePath, logData);
|
||||||
|
//если больше или поменялась дата то создадим следующий файл
|
||||||
|
} else {
|
||||||
|
createNewFileWithData(logData);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void createNewFileWithData(String &logData) {
|
||||||
|
logData = logData + ",";
|
||||||
|
|
||||||
|
String path = "/lgd/" + id + "/" + id + ".txt"; //создадим путь вида /lgd/id/id.txt
|
||||||
|
//создадим пустой файл
|
||||||
|
if (writeEmptyFile(path) != "sucсess") {
|
||||||
|
SerialPrint("E", F("LogingDaily"), "'" + id + "' file writing error, return");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
//запишем в него данные
|
||||||
|
if (addFile(path, logData) != "sucсess") {
|
||||||
|
SerialPrint("E", F("LogingDaily"), "'" + id + "' data writing error, return");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
//запишем путь к нему в базу данных
|
||||||
|
if (saveDataDB(id, path) != "sucсess") {
|
||||||
|
SerialPrint("E", F("LogingDaily"), "'" + id + "' db file writing error, return");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
SerialPrint("i", F("LogingDaily"), "'" + id + "' file created http://" + WiFi.localIP().toString() + path);
|
||||||
|
}
|
||||||
|
|
||||||
|
void addNewDataToExistingFile(String &path, String &logData) {
|
||||||
|
logData = logData + ",";
|
||||||
|
if (addFile(path, logData) != "sucсess") {
|
||||||
|
SerialPrint("i", F("LogingDaily"), "'" + id + "' file writing error, return");
|
||||||
|
return;
|
||||||
|
};
|
||||||
|
SerialPrint("i", F("LogingDaily"), "'" + id + "' LogingDaily in file http://" + WiFi.localIP().toString() + path);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool hasDayChanged() {
|
||||||
|
bool changed = false;
|
||||||
|
String currentDate = getTodayDateDotFormated();
|
||||||
|
if (!firstTimeDate) {
|
||||||
|
if (prevDate != currentDate) {
|
||||||
|
changed = true;
|
||||||
|
SerialPrint("i", F("NTP"), "Change day event");
|
||||||
|
#if defined(ESP8266)
|
||||||
|
FileFS.gc();
|
||||||
|
#endif
|
||||||
|
#if defined(ESP32)
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
}
|
||||||
|
firstTimeDate = false;
|
||||||
|
prevDate = currentDate;
|
||||||
|
return changed;
|
||||||
|
}
|
||||||
|
|
||||||
|
void publishValue() {
|
||||||
|
String dir = "/lgd/" + id;
|
||||||
|
filesList = getFilesList(dir);
|
||||||
|
|
||||||
|
SerialPrint("i", F("LogingDaily"), "file list: " + filesList);
|
||||||
|
|
||||||
|
int f = 0;
|
||||||
|
|
||||||
|
while (filesList.length()) {
|
||||||
|
String path = selectToMarker(filesList, ";");
|
||||||
|
|
||||||
|
path = "/lgd/" + id + path;
|
||||||
|
|
||||||
|
f++;
|
||||||
|
|
||||||
|
if (_publishType == TO_MQTT) {
|
||||||
|
publishChartFileToMqtt(path);
|
||||||
|
} else if (_publishType == TO_WS) {
|
||||||
|
publishChartToWs(path, _wsNum, 1000);
|
||||||
|
} else if (_publishType == TO_MQTT_WS) {
|
||||||
|
publishChartFileToMqtt(path);
|
||||||
|
publishChartToWs(path, _wsNum, 1000);
|
||||||
|
}
|
||||||
|
SerialPrint("i", F("LogingDaily"), String(f) + ") " + path + ", sent");
|
||||||
|
|
||||||
|
filesList = deleteBeforeDelimiter(filesList, ";");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void clearHistory() {
|
||||||
|
String dir = "/lgd/" + id;
|
||||||
|
cleanDirectory(dir);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool publishChartFileToMqtt(String path) {
|
||||||
|
File configFile = FileFS.open(path, FILE_READ);
|
||||||
|
if (!configFile) {
|
||||||
|
SerialPrint("E", F("LogingDaily"), path + " file reading error, json not created, return");
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
String oneSingleJson = configFile.readString();
|
||||||
|
configFile.close();
|
||||||
|
String topic = mqttRootDevice + "/" + id;
|
||||||
|
oneSingleJson = "{\"maxCount\":" + String(calculateMaxCount()) + ",\"topic\":\"" + topic + "\",\"status\":[" + oneSingleJson + "]}";
|
||||||
|
oneSingleJson.replace("},]}", "}]}");
|
||||||
|
SerialPrint("i", "LogingDaily", "json size: " + String(oneSingleJson.length()));
|
||||||
|
publishChartMqtt(id, oneSingleJson);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
//особая функция отправки графиков в веб
|
||||||
|
void publishChartToWs(String filename, int num, size_t frameSize) {
|
||||||
|
String json;
|
||||||
|
jsonWriteStr(json, "topic", mqttRootDevice + "/" + id);
|
||||||
|
jsonWriteInt(json, "maxCount", calculateMaxCount());
|
||||||
|
|
||||||
|
String st = "/st/chart.json|";
|
||||||
|
if (num == -1) {
|
||||||
|
standWebSocket.broadcastTXT(st);
|
||||||
|
} else {
|
||||||
|
standWebSocket.sendTXT(num, st);
|
||||||
|
}
|
||||||
|
String path = filepath(filename);
|
||||||
|
auto file = FileFS.open(path, "r");
|
||||||
|
if (!file) {
|
||||||
|
SerialPrint(F("E"), F("FS"), F("reed file error"));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
size_t fileSize = file.size();
|
||||||
|
SerialPrint(F("i"), F("FS"), "Send file '" + String(filename) + "', file size: " + String(fileSize));
|
||||||
|
uint8_t payload[frameSize];
|
||||||
|
int countRead = file.read(payload, sizeof(payload));
|
||||||
|
while (countRead > 0) {
|
||||||
|
if (num == -1) {
|
||||||
|
standWebSocket.broadcastBIN(payload, countRead);
|
||||||
|
} else {
|
||||||
|
standWebSocket.sendBIN(num, payload, countRead);
|
||||||
|
}
|
||||||
|
countRead = file.read(payload, sizeof(payload));
|
||||||
|
}
|
||||||
|
file.close();
|
||||||
|
String end = "/end/chart.json|" + json;
|
||||||
|
if (num == -1) {
|
||||||
|
standWebSocket.broadcastTXT(end);
|
||||||
|
} else {
|
||||||
|
standWebSocket.sendTXT(num, end);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void publishChartToWsSinglePoint(String value) {
|
||||||
|
String topic = mqttRootDevice + "/" + id;
|
||||||
|
String json = "{\"maxCount\":" + String(calculateMaxCount()) + ",\"topic\":\"" + topic + "\",\"status\":[{\"x\":" + String(unixTime) + ",\"y1\":" + value + "}]}";
|
||||||
|
String pk = "/string/chart.json|" + json;
|
||||||
|
standWebSocket.broadcastTXT(pk);
|
||||||
|
}
|
||||||
|
|
||||||
|
void setPublishDestination(int publishType, int wsNum = -1) {
|
||||||
|
_publishType = publishType;
|
||||||
|
_wsNum = wsNum;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getValue() {
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
void loop() {
|
||||||
|
if (enableDoByInt) {
|
||||||
|
currentMillis = millis();
|
||||||
|
difference = currentMillis - prevMillis;
|
||||||
|
if (difference >= interval) {
|
||||||
|
prevMillis = millis();
|
||||||
|
this->doByInterval();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//просто максимальное количество точек
|
||||||
|
int calculateMaxCount() {
|
||||||
|
return 86400;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
void *getAPI_LogingDaily(String subtype, String param) {
|
||||||
|
if (subtype == F("LogingDaily")) {
|
||||||
|
return new LogingDaily(param);
|
||||||
|
} else {
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
}
|
||||||
39
src/modules/virtual/LogingDaily/modinfo.json
Normal file
39
src/modules/virtual/LogingDaily/modinfo.json
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
{
|
||||||
|
"menuSection": "Виртуальные элементы",
|
||||||
|
"configItem": [
|
||||||
|
{
|
||||||
|
"name": "График дневного расхода",
|
||||||
|
"type": "Writing",
|
||||||
|
"subtype": "LogingDaily",
|
||||||
|
"id": "log",
|
||||||
|
"widget": "chart3",
|
||||||
|
"page": "Графики",
|
||||||
|
"descr": "Температура",
|
||||||
|
"num": 1,
|
||||||
|
"int": 1,
|
||||||
|
"logid": "t",
|
||||||
|
"points": 365
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"about": {
|
||||||
|
"authorName": "Dmitry Borisenko",
|
||||||
|
"authorContact": "https://t.me/Dmitry_Borisenko",
|
||||||
|
"authorGit": "https://github.com/DmitryBorisenko33",
|
||||||
|
"specialThanks": "@itsid1 @Valiuhaaa Serg",
|
||||||
|
"moduleName": "LogingDaily",
|
||||||
|
"moduleVersion": "3.0",
|
||||||
|
"usedRam": 15,
|
||||||
|
"title": "График дневного расхода",
|
||||||
|
"moduleDesc": "Расширение позволяющее логировать накопительные величины и видеть их дневное изменение. Графики доступны в мобильном приложении и в веб интерфейсе. Данные графиков хранятся в встроенной памяти esp",
|
||||||
|
"propInfo": {
|
||||||
|
"int": "Интервал логирования в мнутах, частота проверки смены суток в минутах. Не рекомендуется менять",
|
||||||
|
"logid": "ID накопительной величины которую будем логировать",
|
||||||
|
"points": "Максимальное количество точек"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"defActive": true,
|
||||||
|
"devices": {
|
||||||
|
"esp32_4mb": [],
|
||||||
|
"esp8266_4mb": []
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -214,9 +214,10 @@ String readDataDB(String id) {
|
|||||||
void cleanLogs() {
|
void cleanLogs() {
|
||||||
SerialPrint("i", "Files", "cleanLogs");
|
SerialPrint("i", "Files", "cleanLogs");
|
||||||
cleanDirectory("/db");
|
cleanDirectory("/db");
|
||||||
|
//обращение к логированию из ядра
|
||||||
//очистка данных всех экземпляров графиков
|
//очистка данных всех экземпляров графиков
|
||||||
for (std::list<IoTItem*>::iterator it = IoTItems.begin(); it != IoTItems.end(); ++it) {
|
for (std::list<IoTItem*>::iterator it = IoTItems.begin(); it != IoTItems.end(); ++it) {
|
||||||
if ((*it)->getSubtype() == "Loging") {
|
if ((*it)->getSubtype() == "Loging" || "LogingDaily") {
|
||||||
(*it)->clearHistory();
|
(*it)->clearHistory();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user