mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-26 22:22:16 +03:00
запустил первый сенсор в прошивке 4 той версии
This commit is contained in:
@@ -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",
|
||||||
|
|||||||
@@ -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);
|
||||||
@@ -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"
|
||||||
|
|||||||
16
include/modules/IoTSensorA.h
Normal file
16
include/modules/IoTSensorA.h
Normal 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;
|
||||||
@@ -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();
|
||||||
|
|||||||
@@ -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();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
17
src/modules/IoTSensorA.cpp
Normal file
17
src/modules/IoTSensorA.cpp
Normal 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;
|
||||||
@@ -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:
|
||||||
//описание переменных экземпляра датчика - аналог глобальных переменных
|
//описание переменных экземпляра датчика - аналог глобальных переменных
|
||||||
|
|||||||
Reference in New Issue
Block a user