upd AnalogADC, fix asyncWiFi UDP

This commit is contained in:
Mit4el
2025-02-17 20:49:33 +03:00
parent e988481404
commit 9cbf5f0b38
2 changed files with 69 additions and 28 deletions

View File

@@ -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

View File

@@ -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;
} }
} }