запустил первый сенсор в прошивке 4 той версии

This commit is contained in:
Dmitry Borisenko
2022-01-15 02:01:22 +01:00
parent 2f4a280dcf
commit b6c714bec8
8 changed files with 65 additions and 6 deletions

View File

@@ -52,8 +52,19 @@
"widget": "anydata", "widget": "anydata",
"page": "Сенсоры", "page": "Сенсоры",
"descr": "Температура", "descr": "Температура",
"pin": 0,
"int": 10 "int": 10
}, },
{
"type": "Reading",
"subtype": "analog-adc",
"id": "t",
"widget": "anydata",
"page": "Сенсоры",
"descr": "Температура",
"pin": 0,
"int": 15
},
{ {
"type": "Reading", "type": "Reading",
"subtype": "bme280", "subtype": "bme280",

View File

@@ -4,4 +4,4 @@
extern std::vector<IoTSensor*> iotSensors; // вектор ссылок базового класса IoTSensor - список всех запущенных сенсоров extern std::vector<IoTSensor*> iotSensors; // вектор ссылок базового класса IoTSensor - список всех запущенных сенсоров
extern void configure(String& path); extern void configure(String path);

View File

@@ -7,3 +7,4 @@
#include "StandWebServer.h" #include "StandWebServer.h"
#include "classes/SendJson.h" #include "classes/SendJson.h"
#include "classes/NotAsync.h" #include "classes/NotAsync.h"
#include "Configuration.h"

View File

@@ -0,0 +1,16 @@
#pragma once
#include "Global.h"
#include "Classes/IoTSensor.h"
class IoTSensorA : public IoTSensor {
public:
IoTSensorA(String parameters);
~IoTSensorA();
void doByInterval();
private:
unsigned int _pin;
};
extern IoTSensorA* mySensorAnalog;

View File

@@ -1,9 +1,16 @@
#include "Configuration.h" #include "Configuration.h"
#include "modules/IoTSensorA.h"
void configure(String& path) { std::vector<IoTSensor*> iotSensors;
void configure(String path) {
File file = seekFile(path); File file = seekFile(path);
file.find("[");
while (file.available()) { while (file.available()) {
String jsonArrayElement = file.readStringUntil('}') + "}"; String jsonArrayElement = file.readStringUntil('}') + "}";
if (jsonArrayElement.startsWith(",")) {
jsonArrayElement = jsonArrayElement.substring(1, jsonArrayElement.length()); //это нужно оптимизировать в последствии
}
String subtype; String subtype;
if (jsonRead(jsonArrayElement, F("subtype"), subtype)) { if (jsonRead(jsonArrayElement, F("subtype"), subtype)) {
if (subtype == F("button-out")) { if (subtype == F("button-out")) {
@@ -11,12 +18,13 @@ void configure(String& path) {
} else if (subtype == F("pwm-out")) { } else if (subtype == F("pwm-out")) {
//============================= //=============================
} else if (subtype == F("analog-adc")) { } else if (subtype == F("analog-adc")) {
// iotSensors.push_back(new IoTSensorAnalog(jsonArrayElement)); mySensorAnalog = new IoTSensorA(jsonArrayElement);
iotSensors.push_back(mySensorAnalog);
} else { } else {
SerialPrint(F("E"), F("Config"), F("config.json error, type not exist")); SerialPrint(F("E"), F("Config"), "type not exist " + subtype);
} }
} else { } else {
SerialPrint(F("E"), F("Config"), F("config.json error, type wrong or missing")); SerialPrint(F("E"), F("Config"), F("json error"));
} }
} }
file.close(); file.close();

View File

@@ -37,6 +37,8 @@ void setup() {
//создаем объект класса выгружающего json массив из файла //создаем объект класса выгружающего json массив из файла
mySendJson = new SendJson; mySendJson = new SendJson;
configure("/config.json");
//выводим остаток оперативной памяти после старта //выводим остаток оперативной памяти после старта
// 22.12.21 пустой код без wifi остаток = 50.28 kB // 22.12.21 пустой код без wifi остаток = 50.28 kB
// 22.12.21 запустил wifi остаток = 48.59 kB // 22.12.21 запустил wifi остаток = 48.59 kB
@@ -67,4 +69,8 @@ void loop() {
//обработка web сокетов //обработка web сокетов
standWebSocket.loop(); standWebSocket.loop();
#endif #endif
for (unsigned int i = 0; i < iotSensors.size(); i++) {
iotSensors[i]->loop();
}
} }

View File

@@ -0,0 +1,17 @@
#include "modules/IoTSensorA.h"
IoTSensorA::IoTSensorA(String parameters) {
init(jsonReadStr(parameters, "key"), jsonReadStr(parameters, "id"), jsonReadInt(parameters, "int"));
_pin = jsonReadInt(parameters, "pin");
}
IoTSensorA::~IoTSensorA() {}
void IoTSensorA::doByInterval() {
float value = analogRead(_pin);
regEvent((String)value, "analog"); //обязательный вызов для отправки результата работы
}
IoTSensorA* mySensorAnalog;

View File

@@ -2,7 +2,7 @@
#include "Utils/SerialPrint.h" #include "Utils/SerialPrint.h"
#include "Utils/StringUtils.h" #include "Utils/StringUtils.h"
#include "Classes/IoTSensor.h" #include "Classes/IoTSensor.h"
#include <map>
class IoTSensorAnalog : public IoTSensor { class IoTSensorAnalog : public IoTSensor {
private: private:
//описание переменных экземпляра датчика - аналог глобальных переменных //описание переменных экземпляра датчика - аналог глобальных переменных