mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-30 11:59:12 +03:00
upd AnalogADC, fix asyncWiFi UDP
This commit is contained in:
17
src/Main.cpp
17
src/Main.cpp
@@ -236,12 +236,15 @@ void setup() {
|
|||||||
// инициализация задач переодического выполнения
|
// инициализация задач переодического выполнения
|
||||||
periodicTasksInit();
|
periodicTasksInit();
|
||||||
|
|
||||||
|
#if defined(ESP8266)
|
||||||
|
// Перенесли после получения IP, так как теперь работа WiFi асинхронная
|
||||||
// запуск работы udp
|
// запуск работы udp
|
||||||
addThisDeviceToList();
|
addThisDeviceToList();
|
||||||
#ifdef UDP_ENABLED
|
#ifdef UDP_ENABLED
|
||||||
udpListningInit();
|
udpListningInit();
|
||||||
udpBroadcastInit();
|
udpBroadcastInit();
|
||||||
#endif
|
#endif
|
||||||
|
#endif
|
||||||
// создаем событие завершения конфигурирования для возможности выполнения блока кода при загрузке
|
// создаем событие завершения конфигурирования для возможности выполнения блока кода при загрузке
|
||||||
createItemFromNet("onStart", "1", 1);
|
createItemFromNet("onStart", "1", 1);
|
||||||
|
|
||||||
@@ -302,6 +305,20 @@ void setup() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void loop() {
|
void loop() {
|
||||||
|
#if !defined(ESP8266)
|
||||||
|
static bool udpFirstFlag = true;
|
||||||
|
// Перенесли после получения IP, так как теперь работа WiFi асинхронная
|
||||||
|
if (isNetworkActive() && udpFirstFlag) {
|
||||||
|
udpFirstFlag = false;
|
||||||
|
// запуск работы udp
|
||||||
|
addThisDeviceToList();
|
||||||
|
#ifdef UDP_ENABLED
|
||||||
|
udpListningInit();
|
||||||
|
udpBroadcastInit();
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef LOOP_DEBUG
|
#ifdef LOOP_DEBUG
|
||||||
unsigned long st = millis();
|
unsigned long st = millis();
|
||||||
#endif
|
#endif
|
||||||
|
|||||||
@@ -7,33 +7,41 @@ extern IoTGpio IoTgpio;
|
|||||||
// для добавления сенсора вам нужно скопировать этот файл и заменить в нем текст AnalogAdc на название вашего сенсора
|
// для добавления сенсора вам нужно скопировать этот файл и заменить в нем текст AnalogAdc на название вашего сенсора
|
||||||
// Название должно быть уникальным, коротким и отражать суть сенсора.
|
// Название должно быть уникальным, коротким и отражать суть сенсора.
|
||||||
|
|
||||||
//ребенок - родитель
|
// ребенок - родитель
|
||||||
class AnalogAdc : public IoTItem {
|
class AnalogAdc : public IoTItem
|
||||||
private:
|
{
|
||||||
|
private:
|
||||||
//=======================================================================================================
|
//=======================================================================================================
|
||||||
// Секция переменных.
|
// Секция переменных.
|
||||||
// Это секция где Вы можете объявлять переменные и объекты arduino библиотек, что бы
|
// Это секция где Вы можете объявлять переменные и объекты arduino библиотек, что бы
|
||||||
// впоследствии использовать их в loop и setup
|
// впоследствии использовать их в loop и setup
|
||||||
unsigned int _pin;
|
unsigned int _pin;
|
||||||
unsigned int _avgSteps, _avgCount;
|
unsigned int _avgSteps;
|
||||||
unsigned long _avgSumm;
|
unsigned int realSteps;
|
||||||
float adCresult = 0;
|
float _adcAverage = 0;
|
||||||
|
unsigned int _period = 0;
|
||||||
|
unsigned long _lastSoundingMillis = 0;
|
||||||
|
|
||||||
public:
|
public:
|
||||||
//=======================================================================================================
|
//=======================================================================================================
|
||||||
// setup()
|
// setup()
|
||||||
// это аналог setup из arduino. Здесь вы можете выполнять методы инициализации сенсора.
|
// это аналог setup из arduino. Здесь вы можете выполнять методы инициализации сенсора.
|
||||||
// Такие как ...begin и подставлять в них параметры полученные из web интерфейса.
|
// Такие как ...begin и подставлять в них параметры полученные из web интерфейса.
|
||||||
// Все параметры хранятся в перемененной parameters, вы можете прочитать любой параметр используя jsonRead функции:
|
// Все параметры хранятся в перемененной parameters, вы можете прочитать любой параметр используя jsonRead функции:
|
||||||
// jsonReadStr, jsonReadBool, jsonReadInt
|
// jsonReadStr, jsonReadBool, jsonReadInt
|
||||||
AnalogAdc(String parameters) : IoTItem(parameters) {
|
AnalogAdc(String parameters) : IoTItem(parameters)
|
||||||
|
{
|
||||||
_pin = jsonReadInt(parameters, "pin");
|
_pin = jsonReadInt(parameters, "pin");
|
||||||
_avgSteps = jsonReadInt(parameters, "avgSteps");
|
_avgSteps = jsonReadInt(parameters, "avgSteps");
|
||||||
if (!_avgSteps) {
|
if (!_avgSteps)
|
||||||
|
{
|
||||||
jsonRead(parameters, F("int"), _interval, false);
|
jsonRead(parameters, F("int"), _interval, false);
|
||||||
}
|
}
|
||||||
_avgSumm = 0;
|
else
|
||||||
_avgCount = 0;
|
{
|
||||||
|
_period = _interval / _avgSteps;
|
||||||
|
}
|
||||||
|
// Serial.println("_period = " + String(_period));
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================================================
|
//=======================================================================================================
|
||||||
@@ -44,10 +52,19 @@ class AnalogAdc : public IoTItem {
|
|||||||
// если у сенсора несколько величин то делайте несколько regEvent
|
// если у сенсора несколько величин то делайте несколько regEvent
|
||||||
// не используйте delay - помните, что данный loop общий для всех модулей. Если у вас планируется длительная операция, постарайтесь разбить ее на порции
|
// не используйте delay - помните, что данный loop общий для всех модулей. Если у вас планируется длительная операция, постарайтесь разбить ее на порции
|
||||||
// и выполнить за несколько тактов
|
// и выполнить за несколько тактов
|
||||||
void doByInterval() {
|
void doByInterval()
|
||||||
if (_avgSteps <= 1) value.valD = IoTgpio.analogRead(_pin);
|
{
|
||||||
else value.valD = adCresult;///
|
if (_avgSteps <= 1)
|
||||||
regEvent(value.valD, "AnalogAdc"); //обязательный вызов хотяб один
|
value.valD = IoTgpio.analogRead(_pin);
|
||||||
|
else
|
||||||
|
{
|
||||||
|
value.valD = _adcAverage / (float)realSteps;
|
||||||
|
//Serial.print("value= " + String(value.valD) + " \t");
|
||||||
|
//Serial.print("adcAverage = " + String(_adcAverage) + " \t");
|
||||||
|
//Serial.println("realSteps = " + String(realSteps));
|
||||||
|
realSteps = 0;
|
||||||
|
}
|
||||||
|
regEvent(value.valD, "AnalogAdc"); // обязательный вызов хотяб один
|
||||||
}
|
}
|
||||||
|
|
||||||
//=======================================================================================================
|
//=======================================================================================================
|
||||||
@@ -55,17 +72,20 @@ class AnalogAdc : public IoTItem {
|
|||||||
// полный аналог loop() из arduino. Нужно помнить, что все модули имеют равный поочередный доступ к центральному loop(), поэтому, необходимо следить
|
// полный аналог loop() из arduino. Нужно помнить, что все модули имеют равный поочередный доступ к центральному loop(), поэтому, необходимо следить
|
||||||
// за задержками в алгоритме и не создавать пауз. Кроме того, данная версия перегружает родительскую, поэтому doByInterval() отключается, если
|
// за задержками в алгоритме и не создавать пауз. Кроме того, данная версия перегружает родительскую, поэтому doByInterval() отключается, если
|
||||||
// не повторить механизм расчета интервалов.
|
// не повторить механизм расчета интервалов.
|
||||||
void loop() {
|
void loop()
|
||||||
if (_avgSteps > 1) {
|
{
|
||||||
if (_avgCount > _avgSteps) {
|
if (_avgSteps > 1)
|
||||||
// value.valD = _avgSumm / (_avgSteps + 1);
|
{
|
||||||
adCresult = _avgSumm / (_avgSteps + 1);
|
|
||||||
_avgSumm = 0;
|
|
||||||
_avgCount = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
_avgSumm = _avgSumm + IoTgpio.analogRead(_pin);
|
if (millis() > _lastSoundingMillis + _period)
|
||||||
_avgCount++;
|
{
|
||||||
|
realSteps++;
|
||||||
|
int sounding = IoTgpio.analogRead(_pin);
|
||||||
|
_adcAverage = _adcAverage + sounding; // IoTgpio.analogRead(_pin);
|
||||||
|
_lastSoundingMillis = millis();
|
||||||
|
//Serial.print("adc= " + String(sounding) + " \t");
|
||||||
|
//Serial.println("_adcAverage = " + String(_adcAverage));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
IoTItem::loop();
|
IoTItem::loop();
|
||||||
}
|
}
|
||||||
@@ -76,10 +96,14 @@ class AnalogAdc : public IoTItem {
|
|||||||
// после замены названия сенсора, на функцию можно не обращать внимания
|
// после замены названия сенсора, на функцию можно не обращать внимания
|
||||||
// если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть
|
// если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть
|
||||||
// создание и контроль соответствующих глобальных переменных
|
// создание и контроль соответствующих глобальных переменных
|
||||||
void* getAPI_AnalogAdc(String subtype, String param) {
|
void *getAPI_AnalogAdc(String subtype, String param)
|
||||||
if (subtype == F("AnalogAdc")) {
|
{
|
||||||
|
if (subtype == F("AnalogAdc"))
|
||||||
|
{
|
||||||
return new AnalogAdc(param);
|
return new AnalogAdc(param);
|
||||||
} else {
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user