mirror of
https://github.com/IoTManagerProject/IoTManager.git
synced 2026-03-26 22:22:16 +03:00
Меняем алгоритм чтения Ds18b20 для ускорения и стабилизации работы
Изменяем способ вывода адреса датчика. Не указан адрес, значит определяем по index и выводим при старте в консоль
This commit is contained in:
@@ -5,88 +5,84 @@
|
|||||||
#include <OneWire.h>
|
#include <OneWire.h>
|
||||||
#include <map>
|
#include <map>
|
||||||
|
|
||||||
//глобальные списки необходимы для хранения объектов об активных линиях 1-wire используемых разными датчиками из модуля. Ключ - номер пина
|
// глобальные списки необходимы для хранения объектов об активных линиях 1-wire используемых разными датчиками из модуля. Ключ - номер пина
|
||||||
std::map<int, OneWire*> oneWireTemperatureArray;
|
std::map<int, OneWire*> oneWireTemperatureArray;
|
||||||
std::map<int, DallasTemperature*> sensorsTemperatureArray;
|
|
||||||
|
|
||||||
class Ds18b20 : public IoTItem {
|
class Ds18b20 : public IoTItem {
|
||||||
private:
|
private:
|
||||||
//для работы библиотеки с несколькими линиями необходимо обеспечить каждый экземпляр класса ссылками на объекты настроенные на эти линии
|
//для работы библиотеки с несколькими линиями необходимо обеспечить каждый экземпляр класса ссылками на объекты настроенные на эти линии
|
||||||
OneWire* oneWire;
|
OneWire* _oneWire;
|
||||||
DallasTemperature* sensors;
|
DallasTemperature* _sensor;
|
||||||
|
DeviceAddress _deviceAddress;
|
||||||
//описание параметров передаваемых из настроек датчика из веба
|
|
||||||
String _addr;
|
|
||||||
int _pin;
|
|
||||||
int _index;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
//=======================================================================================================
|
//=======================================================================================================
|
||||||
// setup()
|
// setup()
|
||||||
//это аналог setup из arduino. Здесь вы можете выполнять методы инициализации сенсора.
|
// это аналог setup из arduino. Здесь вы можете выполнять методы инициализации сенсора.
|
||||||
//Такие как ...begin и подставлять в них параметры полученные из web интерфейса.
|
// Такие как ...begin и подставлять в них параметры полученные из web интерфейса.
|
||||||
//Все параметры хранятся в перемененной parameters, вы можете прочитать любой параметр используя jsonRead функции:
|
// Все параметры хранятся в перемененной parameters, вы можете прочитать любой параметр используя jsonRead функции:
|
||||||
// jsonReadStr, jsonReadBool, jsonReadInt
|
// jsonReadStr, jsonReadBool, jsonReadInt
|
||||||
Ds18b20(String parameters) : IoTItem(parameters) {
|
Ds18b20(String parameters) : IoTItem(parameters) {
|
||||||
jsonRead(parameters, "pin", _pin);
|
int index, pin;
|
||||||
jsonRead(parameters, "index", _index, false);
|
String addr;
|
||||||
jsonRead(parameters, "addr", _addr, false);
|
|
||||||
|
jsonRead(parameters, "pin", pin);
|
||||||
|
jsonRead(parameters, "index", index, false);
|
||||||
|
jsonRead(parameters, "addr", addr, false);
|
||||||
|
|
||||||
//учитываем, что библиотека может работать с несколькими линиями на разных пинах, поэтому инициируем библиотеку, если линия ранее не использовалась
|
//учитываем, что библиотека может работать с несколькими линиями на разных пинах, поэтому инициируем библиотеку, если линия ранее не использовалась
|
||||||
if (oneWireTemperatureArray.find(_pin) == oneWireTemperatureArray.end()) {
|
if (oneWireTemperatureArray.find(pin) == oneWireTemperatureArray.end()) {
|
||||||
oneWire = new OneWire((uint8_t)_pin);
|
_oneWire = new OneWire((uint8_t)pin);
|
||||||
sensors = new DallasTemperature();
|
oneWireTemperatureArray[pin] = _oneWire;
|
||||||
sensors->setOneWire(oneWire);
|
|
||||||
sensors->begin();
|
|
||||||
sensors->setResolution(12);
|
|
||||||
|
|
||||||
oneWireTemperatureArray[_pin] = oneWire;
|
|
||||||
sensorsTemperatureArray[_pin] = sensors;
|
|
||||||
} else {
|
} else {
|
||||||
oneWire = oneWireTemperatureArray[_pin];
|
_oneWire = oneWireTemperatureArray[pin];
|
||||||
sensors = sensorsTemperatureArray[_pin];
|
}
|
||||||
|
|
||||||
|
_sensor = new DallasTemperature(_oneWire);
|
||||||
|
_sensor->begin();
|
||||||
|
//sensors->setResolution(12);
|
||||||
|
|
||||||
|
//Определяем адрес. Если параметр addr не установлен, то узнаем адрес по индексу
|
||||||
|
if (addr == "") {
|
||||||
|
_sensor->getAddress(_deviceAddress, index);
|
||||||
|
char addrStr[20] = "";
|
||||||
|
hex2string(_deviceAddress, 8, addrStr);
|
||||||
|
SerialPrint("I", "Sensor " + (String)_id, "index: " + (String)index + " addr: " + String(addrStr));
|
||||||
|
} else {
|
||||||
|
string2hex(addr.c_str(), _deviceAddress);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
//=======================================================================================================
|
//=======================================================================================================
|
||||||
// doByInterval()
|
// doByInterval()
|
||||||
//это аналог loop из arduino, но вызываемый каждые int секунд, заданные в настройках. Здесь вы должны выполнить чтение вашего сенсора
|
// это аналог loop из arduino, но вызываемый каждые int секунд, заданные в настройках. Здесь вы должны выполнить чтение вашего сенсора
|
||||||
//а затем выполнить regEvent - это регистрация произошедшего события чтения
|
// а затем выполнить regEvent - это регистрация произошедшего события чтения
|
||||||
//здесь так же доступны все переменные из секции переменных, и полученные в setup
|
// здесь так же доступны все переменные из секции переменных, и полученные в setup
|
||||||
//если у сенсора несколько величин то делайте несколько regEvent
|
// если у сенсора несколько величин то делайте несколько regEvent
|
||||||
//не используйте delay - помните, что данный loop общий для всех модулей. Если у вас планируется длительная операция, постарайтесь разбить ее на порции
|
// не используйте delay - помните, что данный loop общий для всех модулей. Если у вас планируется длительная операция, постарайтесь разбить ее на порции
|
||||||
//и выполнить за несколько тактов
|
// и выполнить за несколько тактов
|
||||||
void doByInterval() {
|
void doByInterval() {
|
||||||
//запускаем опрос измерений у всех датчиков на линии
|
//запускаем опрос измерений у всех датчиков на линии
|
||||||
sensors->requestTemperatures();
|
_sensor->requestTemperatures();
|
||||||
|
|
||||||
//Определяем адрес. Если парамтер addr не установлен, то узнаем адрес по индексу
|
|
||||||
// TODO: понять как лучше. в текущей реализации адрес вычисляется каждый раз при опросе шины, это хорошо при отладке,
|
|
||||||
// но при постоянном контакте и использовании правильнее генерировать адрес при инициализации модуля. Но тогда нужно перезагружать устройство при новом датчике
|
|
||||||
DeviceAddress deviceAddress;
|
|
||||||
if (_addr == "") {
|
|
||||||
sensors->getAddress(deviceAddress, _index);
|
|
||||||
} else {
|
|
||||||
string2hex(_addr.c_str(), deviceAddress);
|
|
||||||
}
|
|
||||||
//получаем температуру по адресу
|
//получаем температуру по адресу
|
||||||
value.valD = sensors->getTempC(deviceAddress);
|
value.valD = _sensor->getTempC(_deviceAddress);
|
||||||
|
|
||||||
char addrStr[20] = "";
|
if (value.valD != DEVICE_DISCONNECTED_C)
|
||||||
hex2string(deviceAddress, 8, addrStr);
|
regEvent(value.valD, ""); //обязательный вызов для отправки результата работы
|
||||||
|
|
||||||
if (value.valD != -127)
|
|
||||||
regEvent(value.valD, "addr: " + String(addrStr)); //обязательный вызов для отправки результата работы
|
|
||||||
else
|
else
|
||||||
SerialPrint("E", "Sensor Ds18b20", "Error");
|
SerialPrint("E", "Sensor Ds18b20", "Error");
|
||||||
}
|
}
|
||||||
//=======================================================================================================
|
//=======================================================================================================
|
||||||
|
|
||||||
~Ds18b20() {};
|
~Ds18b20() {
|
||||||
|
if (_sensor) delete _sensor;
|
||||||
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
//после замены названия сенсора, на функцию можно не обращать внимания
|
// после замены названия сенсора, на функцию можно не обращать внимания
|
||||||
//если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть
|
// если сенсор предполагает использование общего объекта библиотеки для нескольких экземпляров сенсора, то в данной функции необходимо предусмотреть
|
||||||
//создание и контроль соответствующих глобальных переменных
|
// создание и контроль соответствующих глобальных переменных
|
||||||
void* getAPI_Ds18b20(String subtype, String param) {
|
void* getAPI_Ds18b20(String subtype, String param) {
|
||||||
if (subtype == F("Ds18b20")) {
|
if (subtype == F("Ds18b20")) {
|
||||||
return new Ds18b20(param);
|
return new Ds18b20(param);
|
||||||
|
|||||||
Reference in New Issue
Block a user