рабочая версия с аналоговым сенсором

This commit is contained in:
Dmitry Borisenko
2022-01-15 16:30:34 +01:00
parent b6c714bec8
commit ea68905f4e
8 changed files with 114 additions and 135 deletions

View File

@@ -1,53 +1,7 @@
[
{
"type": "Variable",
"subtype": "button-out",
"id": "btn1",
"widget": "toggle",
"page": "Кнопки",
"descr": "Освещение",
"gpio": 13,
"inv": false
},
{
"type": "Variable",
"subtype": "pwm-out",
"id": "pwm1",
"widget": "range",
"page": "Регуляторы",
"descr": "Освещение",
"gpio": 14,
"inv": false
},
{
"type": "Reading",
"subtype": "button-in",
"id": "btn",
"widget": "toggle",
"page": "Кнопки",
"descr": "Освещение",
"gpio": 12,
"inv": false
},
{
"type": "Reading",
"subtype": "output-value",
"id": "txt",
"widget": "anydata",
"page": "Предупреждения",
"descr": "Статус"
},
{
"type": "Reading",
"subtype": "input-value",
"id": "txt",
"widget": "input",
"page": "Лимиты",
"descr": "Порог"
},
{
"type": "Reading",
"subtype": "analog-adc",
"subtype": "AnalogAdc",
"id": "t",
"widget": "anydata",
"page": "Сенсоры",
@@ -57,7 +11,7 @@
},
{
"type": "Reading",
"subtype": "analog-adc",
"subtype": "AnalogAdc",
"id": "t",
"widget": "anydata",
"page": "Сенсоры",
@@ -65,9 +19,55 @@
"pin": 0,
"int": 15
},
{
"type": "Variable",
"subtype": "ButtonOut",
"id": "btn1",
"widget": "toggle",
"page": "Кнопки",
"descr": "Освещение",
"gpio": 13,
"inv": false
},
{
"type": "Variable",
"subtype": "PwmOut",
"id": "pwm1",
"widget": "range",
"page": "Регуляторы",
"descr": "Освещение",
"gpio": 14,
"inv": false
},
{
"type": "Reading",
"subtype": "bme280",
"subtype": "ButtonIn",
"id": "btn",
"widget": "toggle",
"page": "Кнопки",
"descr": "Освещение",
"gpio": 12,
"inv": false
},
{
"type": "Reading",
"subtype": "OutputValue",
"id": "txt",
"widget": "anydata",
"page": "Предупреждения",
"descr": "Статус"
},
{
"type": "Reading",
"subtype": "InputValue",
"id": "txt",
"widget": "input",
"page": "Лимиты",
"descr": "Порог"
},
{
"type": "Reading",
"subtype": "Bme280",
"id": "t",
"widget": "anydata",
"page": "Сенсоры",
@@ -75,7 +75,7 @@
},
{
"type": "Reading",
"subtype": "bme280",
"subtype": "Bme280",
"id": "p",
"widget": "anydata",
"page": "Сенсоры",
@@ -83,7 +83,7 @@
},
{
"type": "Reading",
"subtype": "bme280",
"subtype": "Bme280",
"id": "h",
"widget": "anydata",
"page": "Сенсоры",

View File

@@ -3,24 +3,26 @@
#include <WString.h>
class IoTSensor {
public:
IoTSensor();
~IoTSensor();
public:
IoTSensor();
~IoTSensor();
void loop();
virtual void doByInterval();
void init(String key, String id, unsigned long interval);
void regEvent(String value, String consoleInfo);
void loop();
virtual void doByInterval();
void init(String key, String id, unsigned long interval);
void regEvent(String value, String consoleInfo);
String getKey();
String getID();
String getKey();
String getID();
unsigned long currentMillis;
unsigned long prevMillis;
unsigned long difference;
protected:
String _key;
String _id;
unsigned long _interval;
};
unsigned long currentMillis;
unsigned long prevMillis;
unsigned long difference;
protected:
String _key;
String _id;
unsigned long _interval;
};
extern IoTSensor* myIoTSensor;

View File

@@ -2,10 +2,10 @@
#include "Global.h"
#include "Classes/IoTSensor.h"
class IoTSensorA : public IoTSensor {
class AnalogAdc : public IoTSensor {
public:
IoTSensorA(String parameters);
~IoTSensorA();
AnalogAdc(String parameters);
~AnalogAdc();
void doByInterval();
@@ -13,4 +13,4 @@ class IoTSensorA : public IoTSensor {
unsigned int _pin;
};
extern IoTSensorA* mySensorAnalog;
extern void* getAPI_AnalogAdc(String params);

View File

@@ -1,5 +1,5 @@
#include "Configuration.h"
#include "modules/IoTSensorA.h"
#include "modules/AnalogAdc.h"
std::vector<IoTSensor*> iotSensors;
@@ -11,20 +11,10 @@ void configure(String path) {
if (jsonArrayElement.startsWith(",")) {
jsonArrayElement = jsonArrayElement.substring(1, jsonArrayElement.length()); //это нужно оптимизировать в последствии
}
String subtype;
if (jsonRead(jsonArrayElement, F("subtype"), subtype)) {
if (subtype == F("button-out")) {
//=============================
} else if (subtype == F("pwm-out")) {
//=============================
} else if (subtype == F("analog-adc")) {
mySensorAnalog = new IoTSensorA(jsonArrayElement);
iotSensors.push_back(mySensorAnalog);
} else {
SerialPrint(F("E"), F("Config"), "type not exist " + subtype);
}
} else {
SerialPrint(F("E"), F("Config"), F("json error"));
myIoTSensor = (IoTSensor*)getAPI_AnalogAdc(jsonArrayElement);
if (myIoTSensor) {
iotSensors.push_back(myIoTSensor);
}
}
file.close();

View File

@@ -36,4 +36,6 @@ void IoTSensor::regEvent(String value, String consoleInfo = "") {
SerialPrint("I", "Sensor", "'" + _id + "' data: " + String(value) + "' " + consoleInfo);
}
void IoTSensor::doByInterval() {}
void IoTSensor::doByInterval() {}
IoTSensor* myIoTSensor;

31
src/modules/AnalogAdc.cpp Normal file
View File

@@ -0,0 +1,31 @@
#include "modules/AnalogAdc.h"
// setup()
AnalogAdc::AnalogAdc(String parameters) {
init(jsonReadStr(parameters, "key"), jsonReadStr(parameters, "id"), jsonReadInt(parameters, "int"));
_pin = jsonReadInt(parameters, "pin");
}
AnalogAdc::~AnalogAdc() {}
// loop()
void AnalogAdc::doByInterval() {
float value = analogRead(_pin);
regEvent((String)value, "analog");
}
void* getAPI_AnalogAdc(String parameters) {
String subtype;
if (!jsonRead(parameters, F("subtype"), subtype)) { //если нет такого ключа в представленном json или он не валидный
SerialPrint(F("E"), F("Config"), F("json error AnalogAdc"));
return nullptr;
} else {
if (subtype == F("AnalogAdc")) {
return new AnalogAdc(parameters);
} else {
return nullptr;
}
}
}

View File

@@ -1,17 +0,0 @@
#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

@@ -1,29 +0,0 @@
#include "Utils/JsonUtils.h"
#include "Utils/SerialPrint.h"
#include "Utils/StringUtils.h"
#include "Classes/IoTSensor.h"
#include <map>
class IoTSensorAnalog : public IoTSensor {
private:
//описание переменных экземпляра датчика - аналог глобальных переменных
//описание параметров передаваемых из настроек датчика из веба
unsigned int _pin;
public:
//аналог setup()
IoTSensorAnalog(String parameters) {
//передаем часть базовых параметров в конструктор базового класса для обеспечения работы его методов
init(jsonReadStr(parameters, "key"), jsonReadStr(parameters, "id"), jsonReadInt(parameters, "int"));
_pin = jsonReadInt(parameters, "pin");
}
//аналог loop()
void doByInterval() {
float value = analogRead(_pin);
regEvent((String)value, "analog"); //обязательный вызов для отправки результата работы
}
~IoTSensorAnalog() {}
};