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();
#if defined(ESP8266)
// Перенесли после получения IP, так как теперь работа WiFi асинхронная
// запуск работы udp
addThisDeviceToList();
#ifdef UDP_ENABLED
udpListningInit();
udpBroadcastInit();
#endif
#endif
// создаем событие завершения конфигурирования для возможности выполнения блока кода при загрузке
createItemFromNet("onStart", "1", 1);
@@ -302,6 +305,20 @@ void setup() {
}
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
unsigned long st = millis();
#endif

View File

@@ -7,33 +7,41 @@ extern IoTGpio IoTgpio;
// для добавления сенсора вам нужно скопировать этот файл и заменить в нем текст AnalogAdc на название вашего сенсора
// Название должно быть уникальным, коротким и отражать суть сенсора.
//ребенок - родитель
class AnalogAdc : public IoTItem {
private:
// ребенок - родитель
class AnalogAdc : public IoTItem
{
private:
//=======================================================================================================
// Секция переменных.
// Это секция где Вы можете объявлять переменные и объекты arduino библиотек, что бы
// впоследствии использовать их в loop и setup
unsigned int _pin;
unsigned int _avgSteps, _avgCount;
unsigned long _avgSumm;
float adCresult = 0;
unsigned int _avgSteps;
unsigned int realSteps;
float _adcAverage = 0;
unsigned int _period = 0;
unsigned long _lastSoundingMillis = 0;
public:
public:
//=======================================================================================================
// setup()
// это аналог setup из arduino. Здесь вы можете выполнять методы инициализации сенсора.
// Такие как ...begin и подставлять в них параметры полученные из web интерфейса.
// Все параметры хранятся в перемененной parameters, вы можете прочитать любой параметр используя jsonRead функции:
// jsonReadStr, jsonReadBool, jsonReadInt
AnalogAdc(String parameters) : IoTItem(parameters) {
AnalogAdc(String parameters) : IoTItem(parameters)
{
_pin = jsonReadInt(parameters, "pin");
_avgSteps = jsonReadInt(parameters, "avgSteps");
if (!_avgSteps) {
if (!_avgSteps)
{
jsonRead(parameters, F("int"), _interval, false);
}
_avgSumm = 0;
_avgCount = 0;
else
{
_period = _interval / _avgSteps;
}
// Serial.println("_period = " + String(_period));
}
//=======================================================================================================
@@ -44,10 +52,19 @@ class AnalogAdc : public IoTItem {
// если у сенсора несколько величин то делайте несколько regEvent
// не используйте delay - помните, что данный loop общий для всех модулей. Если у вас планируется длительная операция, постарайтесь разбить ее на порции
// и выполнить за несколько тактов
void doByInterval() {
if (_avgSteps <= 1) value.valD = IoTgpio.analogRead(_pin);
else value.valD = adCresult;///
regEvent(value.valD, "AnalogAdc"); //обязательный вызов хотяб один
void doByInterval()
{
if (_avgSteps <= 1)
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(), поэтому, необходимо следить
// за задержками в алгоритме и не создавать пауз. Кроме того, данная версия перегружает родительскую, поэтому doByInterval() отключается, если
// не повторить механизм расчета интервалов.
void loop() {
if (_avgSteps > 1) {
if (_avgCount > _avgSteps) {
// value.valD = _avgSumm / (_avgSteps + 1);
adCresult = _avgSumm / (_avgSteps + 1);
_avgSumm = 0;
_avgCount = 0;
}
void loop()
{
if (_avgSteps > 1)
{
_avgSumm = _avgSumm + IoTgpio.analogRead(_pin);
_avgCount++;
if (millis() > _lastSoundingMillis + _period)
{
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();
}
@@ -76,10 +96,14 @@ class AnalogAdc : public IoTItem {
// после замены названия сенсора, на функцию можно не обращать внимания
// если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть
// создание и контроль соответствующих глобальных переменных
void* getAPI_AnalogAdc(String subtype, String param) {
if (subtype == F("AnalogAdc")) {
void *getAPI_AnalogAdc(String subtype, String param)
{
if (subtype == F("AnalogAdc"))
{
return new AnalogAdc(param);
} else {
}
else
{
return nullptr;
}
}