mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-30 20:09:14 +03:00
Добавляем возможность получения первичной настройки из модуля
This commit is contained in:
@@ -25,5 +25,11 @@ class IoTSensor {
|
|||||||
unsigned long _interval;
|
unsigned long _interval;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct ModuleInfo
|
||||||
|
{
|
||||||
|
void* apiToComponent;
|
||||||
|
String defConfig;
|
||||||
|
};
|
||||||
|
|
||||||
//extern IoTSensor* myIoTSensor;
|
//extern IoTSensor* myIoTSensor;
|
||||||
//модулям не нужно знать эту переменную
|
//модулям не нужно знать эту переменную
|
||||||
@@ -1,12 +1,7 @@
|
|||||||
#include "ESPConfiguration.h"
|
#include "ESPConfiguration.h"
|
||||||
|
|
||||||
std::vector<IoTSensor*> iotSensors;
|
std::vector<IoTSensor*> iotSensors;
|
||||||
void* getAPI(String subtype, String params);
|
ModuleInfo getAPI(String subtype, String params);
|
||||||
|
|
||||||
//============================================================================================
|
|
||||||
//здесь скопируйте строку и вставьте ниже, заменив имя AnalogAdc на название вашего сенсора
|
|
||||||
extern void* getAPI_AnalogAdc(String params);
|
|
||||||
//============================================================================================
|
|
||||||
|
|
||||||
void configure(String path) {
|
void configure(String path) {
|
||||||
File file = seekFile(path);
|
File file = seekFile(path);
|
||||||
@@ -22,7 +17,7 @@ void configure(String path) {
|
|||||||
SerialPrint(F("E"), F("Config"), "json error " + subtype);
|
SerialPrint(F("E"), F("Config"), "json error " + subtype);
|
||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
myIoTSensor = (IoTSensor*)getAPI(subtype, jsonArrayElement);
|
myIoTSensor = (IoTSensor*)getAPI(subtype, jsonArrayElement).apiToComponent;
|
||||||
if (myIoTSensor) {
|
if (myIoTSensor) {
|
||||||
iotSensors.push_back(myIoTSensor);
|
iotSensors.push_back(myIoTSensor);
|
||||||
createWidget(jsonArrayElement);
|
createWidget(jsonArrayElement);
|
||||||
|
|||||||
@@ -2,18 +2,22 @@
|
|||||||
|
|
||||||
//============================================================================================
|
//============================================================================================
|
||||||
//здесь скопируйте строку и вставьте ниже, заменив имя AnalogAdc на название вашего сенсора
|
//здесь скопируйте строку и вставьте ниже, заменив имя AnalogAdc на название вашего сенсора
|
||||||
void* getAPI_AnalogAdc(String subtype, String params);
|
ModuleInfo getAPI_AnalogAdc(String subtype, String params);
|
||||||
void* getAPI_ds18b20(String subtype, String params);
|
ModuleInfo getAPI_ds18b20(String subtype, String params);
|
||||||
//============================================================================================
|
//============================================================================================
|
||||||
|
|
||||||
void* getAPI(String subtype, String params) {
|
ModuleInfo getAPI(String subtype, String params) {
|
||||||
void* tmpAPI;
|
ModuleInfo tmpMi;
|
||||||
|
String defConfig = "";
|
||||||
//===============================================================================================================
|
//===============================================================================================================
|
||||||
//здесь нужно скопировать строку еще раз и вставить ее ниже, переименовав AnalogAdc на название вашего сенсора
|
//здесь нужно скопировать строку еще раз и вставить ее ниже, переименовав AnalogAdc на название вашего сенсора
|
||||||
if ((tmpAPI = getAPI_AnalogAdc(subtype, params)) != nullptr) return tmpAPI;
|
if ((tmpMi = getAPI_AnalogAdc(subtype, params)).apiToComponent != nullptr) return tmpMi; else defConfig += tmpMi.defConfig;
|
||||||
//================================================================================================================
|
//================================================================================================================
|
||||||
|
|
||||||
if ((tmpAPI = getAPI_ds18b20(subtype, params)) != nullptr) return tmpAPI;
|
if ((tmpMi = getAPI_ds18b20(subtype, params)).apiToComponent != nullptr) return tmpMi; else defConfig += tmpMi.defConfig;
|
||||||
|
|
||||||
return nullptr;
|
|
||||||
|
|
||||||
|
tmpMi.defConfig = defConfig;
|
||||||
|
return tmpMi;
|
||||||
}
|
}
|
||||||
@@ -46,10 +46,13 @@ class AnalogAdc : public IoTSensor {
|
|||||||
//после замены названия сенсора, на функцию можно не обращать внимания
|
//после замены названия сенсора, на функцию можно не обращать внимания
|
||||||
//если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть
|
//если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть
|
||||||
//создание и контроль соответствующих глобальных переменных (см. пример реализации сенсора ds18b20)
|
//создание и контроль соответствующих глобальных переменных (см. пример реализации сенсора ds18b20)
|
||||||
void* getAPI_AnalogAdc(String subtype, String param) {
|
ModuleInfo getAPI_AnalogAdc(String subtype, String param) {
|
||||||
|
ModuleInfo mi;
|
||||||
|
mi.apiToComponent = nullptr;
|
||||||
|
mi.defConfig = "конфин такой вот джисон";
|
||||||
if (subtype == F("AnalogAdc")) {
|
if (subtype == F("AnalogAdc")) {
|
||||||
return new AnalogAdc(param);
|
mi.apiToComponent = new AnalogAdc(param);
|
||||||
} else {
|
|
||||||
return nullptr;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return mi;
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -82,10 +82,13 @@ class ds18b20 : public IoTSensor {
|
|||||||
//после замены названия сенсора, на функцию можно не обращать внимания
|
//после замены названия сенсора, на функцию можно не обращать внимания
|
||||||
//если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть
|
//если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть
|
||||||
//создание и контроль соответствующих глобальных переменных (см. пример реализации сенсора ds18b20)
|
//создание и контроль соответствующих глобальных переменных (см. пример реализации сенсора ds18b20)
|
||||||
void* getAPI_ds18b20(String subtype, String param) {
|
ModuleInfo getAPI_ds18b20(String subtype, String param) {
|
||||||
if (subtype == F("ds18b20")) {
|
ModuleInfo mi;
|
||||||
return new ds18b20(param);
|
mi.apiToComponent = nullptr;
|
||||||
} else {
|
mi.defConfig = "конфин такой вот джисон";
|
||||||
return nullptr;
|
if (subtype == F("AnalogAdc")) {
|
||||||
|
mi.apiToComponent = new ds18b20(param);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return mi;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user