Рівень води MyHomeIoT Water Level призначений для контролю рівня води, та керуванням впускним і випускним клапаном по шині I2C з мікроконтролера. Приєднавши цю плату до Sonoff Basic (TH), або до будь якого пристрою на ESP8266, схемно сумісного з Sonoff basic (TH) та прошитого прошивкою MyHomeIoT починаючи з версії 1.1.4 і вище, до шини I2C, отримуєте контроль рівня води (чотири рівня: пустий, 1/4, 1/2, 3/4 і повний) плюс керування впускним і випускним клапаном зі світлодіодною індикацією і зворотнім зв'язком, як з додатку blynk app, так і з кнопки на самій платі. В додачу два тижневих планувальника для встановлення потрібного рівня води.
Також цей Water Level можна використовувати з будь яким мікроконтролером для своїх поробок автоматики і систем розумного будинку написавши програмну підтримку до свого мікроконтролеру який будете використовувати.
Схема пристрою
Схема рівня води (тицяйте в зображення для збільшення)
Схема складається з мікросхеми PCF8574P, яка є двонаправленим розширювачем портів вводу/виводу з керуванням по I2C шині і має адресу 0x21. Та мікросхеми ULN2803A, яка є масивом транзисторів Дарлінгтона і має 8 транзисторів з загальним емітером та внутрішніми діодами для індуктивних навантажень (реле).
Перші чотири входи IN1 - IN4 мікросхеми ULN2803A використовуються для визначення рівня води. Виходи OUT5 і OUT6 мікросхеми ULN2803A керують впускним і випускним клапаном. А OUT7 керує світлодіодним індикатором режиму роботи. OUT8 не використовується (резерв), тому можна замість мікросхеми ULN2803A застосувати UNL2003.
Мікросхема PCF8574P - двонаправлений розширювач портів вводу/виводу з шиною I2C
Кнопка S1 - встановлення потрібного рівня води.
Світлодіод D2 - для індикації режимів роботи та помилок сенсору.
Реле К1, К2 - керування впускним і випускним клапаном
Транзистор Q1 - захист від переливу води у випадку, якщо мікроконтролер "завис" або не працює з якихось причин. Можна без транзистору, тоді OUT5 мікросхеми ULN2803A з'єднати на пряму з реле К1 (вивід 2 на схемі).
Демонстраційний код
/* Name: pcf8574_water_level.ino Created: 7/16/2018 8:59:19 AM Author: Andriy*/#include <Ticker.h>#include <Wire.h>#include <pcf8574_esp.h>#define ADDRESS_WATER_LEVEL 0x21 // Address PCF8574 on the I2C bus#define SDA 4 // Pin SDA wire #define SCL 5 // Pin SCL wiretypedefenum {
empty =0x00,
quarter =0x40,
half =0x80,
threeQuarters =0xC0,
full =0xFE,
errorSensor =0xFF
}WaterLevelEnum;
typedefenum {
sensor_0,
sensor_1,
sensor_2,
sensor_3,
intake_pump,
outlet_pump,
led_indicator,
button
}WaterLevelPortEnum;
typedefstruct
{
bool triggerInit =false; // трігер чи є такий пристрій в системіbool triggerButton =false; // трігер натискання і відпускання кнопкиbool triggerStart =false; // трігер старту встановлення рівня води bool stateLed =false; // стан світлодіодного індікатора увімк/вимкн bool stateRelay[2] = { false, false }; // стан впускного і випускного реле uint8_t requiredWaterLevel = full;
uint8_t currentWaterLevel = empty;
}WaterLevelTypeDef;
WaterLevelTypeDef waterLevelStruct;
PCF857x waterLevelDevice(ADDRESS_WATER_LEVEL, &Wire, false);
Ticker tickerWaterLevel;
staticvoidwl_Run(bool setOutletPump);
staticuint8_twl_GetWaterLevel(void);
staticvoidwl_SetWaterLevel(uint8_t level);
staticvoidwl_ReadKey(void);
staticvoidwl_Control(bool setOutletPump);
staticvoidwl_ErrorLedStatus(void);
staticvoidwl_Action(bool state, bool stateIntakePump, bool stateOutletPump, String str);
// the setup function runs once when you press reset or power the boardvoidsetup()
{
Serial.begin(115200);
Wire.begin(SDA, SCL);
// ініціалізуємо рівень води
waterLevelDevice.begin(0x8F);
// встановлюємо потрібний рівень
wl_SetWaterLevel(half);
// взнаємо поточний рівень води і заносимо до структури
waterLevelStruct.currentWaterLevel = wl_GetWaterLevel();
if (waterLevelStruct.currentWaterLevel != errorSensor)
{
wl_Action(false, false, false, "Device water level is OK!");
if (tickerWaterLevel.active())
{
tickerWaterLevel.detach();
waterLevelDevice.write(led_indicator, LOW);
}
}
else
{
wl_Action(false, false, false, "Device water level is sensor error!");
if (!tickerWaterLevel.active())
{
tickerWaterLevel.attach(0.2, wl_ErrorLedStatus);
}
}
}
// the loop function runs over and over again until power down or resetvoidloop()
{
wl_Run(true);
}
staticvoidwl_Run(bool setOutletPump)
{
wl_ReadKey();
wl_Control(setOutletPump);
}
staticvoidwl_ReadKey(void)
{
if (!waterLevelDevice.read(button) &&!waterLevelStruct.triggerButton)
{
waterLevelStruct.triggerButton =true;
waterLevelStruct.triggerStart =!waterLevelStruct.triggerStart;
}
elseif (waterLevelDevice.read(button) && waterLevelStruct.triggerButton)
{
waterLevelStruct.triggerButton =false;
}
}
staticvoidwl_Control(bool setOutletPump)
{
if (waterLevelStruct.triggerStart)
{
waterLevelStruct.currentWaterLevel = wl_GetWaterLevel();
if (waterLevelStruct.currentWaterLevel == errorSensor)
{
wl_Action(false, false, false, "Error water sensor");
if (!tickerWaterLevel.active())
{
tickerWaterLevel.attach(0.2, wl_ErrorLedStatus);
}
}
else
{
if (tickerWaterLevel.active())
{
tickerWaterLevel.detach();
waterLevelDevice.write(led_indicator, LOW);
}
if (waterLevelStruct.currentWaterLevel == waterLevelStruct.requiredWaterLevel)
{
wl_Action(false, false, false, "The tank has already reached the required level");
}
elseif (waterLevelStruct.currentWaterLevel < waterLevelStruct.requiredWaterLevel)
{
if (!waterLevelStruct.stateRelay[0])
{
wl_Action(true, true, false, "Intake Pump ON");
}
}
elseif (waterLevelStruct.currentWaterLevel > waterLevelStruct.requiredWaterLevel)
{
if (setOutletPump)
{
if (!waterLevelStruct.stateRelay[1])
{
wl_Action(true, false, true, "Outlet Pump ON");
}
}
}
}
}
else
{
if (waterLevelStruct.stateRelay[0])
{
wl_Action(false, false, false, "Intake Pump OFF");
}
if (waterLevelStruct.stateRelay[1])
{
wl_Action(false, false, false, "Outlet Pump OFF");
}
}
}
staticvoidwl_Action(bool state, bool stateIntakePump, bool stateOutletPump, String str)
{
waterLevelStruct.triggerStart = state;
waterLevelStruct.stateLed = state;
waterLevelStruct.stateRelay[0] = stateIntakePump;
waterLevelStruct.stateRelay[1] = stateOutletPump;
Serial.println(str);
Serial.print("Current water level is ");
switch (waterLevelStruct.currentWaterLevel)
{
case empty:
Serial.println("empty");
break;
case quarter:
Serial.println("1/4");
break;
case half:
Serial.println("1/2");
break;
case threeQuarters:
Serial.println("3/4");
break;
case full:
Serial.println("full");
break;
case errorSensor:
Serial.println("error");
break;
default:break;
}
waterLevelDevice.write(led_indicator, waterLevelStruct.stateLed);
waterLevelDevice.write(intake_pump, waterLevelStruct.stateRelay[0]);
waterLevelDevice.write(outlet_pump, waterLevelStruct.stateRelay[1]);
}
staticvoidwl_ErrorLedStatus(void)
{
waterLevelDevice.toggle(led_indicator);
}
staticuint8_twl_GetWaterLevel(void)
{
uint8_t level = (waterLevelDevice.read8() &0xF) ^0x0F;
if (level !=0b0000 && level !=0b0001 &&\
level !=0b0011 && level !=0b0111 && level !=0b1111)
{
return errorSensor;
}
else
{
if (level ==0b0000)
return empty;
elseif (level ==0b0001)
return quarter;
elseif (level ==0b0011)
return half;
elseif (level ==0b0111)
return threeQuarters;
elseif (level ==0b1111)
return full;
}
}
staticvoidwl_SetWaterLevel(uint8_t level)
{
waterLevelStruct.requiredWaterLevel = level;
}
Розширювач портів MyHomeIoT Expander 4х4 призначений для керування додатковими чотирма реле по шині I2C з мікроконтролера. Приєднавши цю плату до Sonoff Basic (TH), або до будь якого пристрою на ESP8266 схемно сумісного з Sonoff basic (TH) прошитого прошивкою MyHomeIoT починаючи з версії 1.1.1 і вище до шини I2C, отримуєте керування додатковими, чотирма, реле зі світлодіодною індикацією і зворотнім зв'язком, як з додатку blynk app, так і з кнопок на самій платі. В додачу на кожне додаткове реле по одному планувальнику на тиждень.
Схема складається з мікросхеми PCF8574P, яка є двонаправленим розширювачем портів вводу/виводу з керуванням по I2C шині і має адресу 0x20. Та мікросхеми ULN2803A, яка є масивом транзисторів Дарлінгтона і має 8 транзисторів з загальним емітером та внутрішніми діодами для індуктивних навантажень (реле).
Мікросхема U1 (стабілізатор напруги) може бути як на 3.3 вольта, так і на 5 вольт. В залежності від ваших потреб. Якщо поставити перемичку на J2 то мікросхема U2 PCF8574 буде живитись від свого внутрішнього живлення, а також ці 3.3 вольта, або 5 вольт буде подано на роз'єм J5 і можна буде живити плату з мікроконтролером.
Якщо перемичку не ставити, то для мікросхеми U2 PCF8574 живлення 3.3 вольта, або 5 вольт очікується з плати мікроконтролеру. І в такому разі стабілізатор напруги на мікросхемі U1 можна не встановлювати.
Комутувати навантаження на контактах реле можна до 5 ампер. Якщо потрібно комутувати навантаження з більшим струмом, потрібно запаяти на доріжки додаткові дроти.
Печатна плата
Печатна плата з елементами
Плата вид зверху
Плата вид з низу
Плата в зборі
Добре по розміру підходить така коробочка:
107*87*59mm Plastic Electronics Box Project Case DIN Rail PLC Junction Box DIY
Замовити можна, наприклад, тут, або тут, або ще деінде. Отвори в платі під кріплення в цій коробочці прийдеться висвердлити самому.
Варіанти підключення
Плата розширювача з Sonoff basic
Підключення розширювача до Sonoff Basic
Плата розширювача з NodeMCU та іншими ESP8266
Підключення розширювача до NodeMCU
Демонстраційний код
Хто хоче використовувати цей розширювач портів в своїх розробках, то ось для прикладу демонстраційний код для системи Blynk:
/* Name: Blynk_pcf8574_demo.ino Created: 7/11/2018 10:17:12 AM Author: Andriy Honcharenko*//* Comment this out to disable prints and save space */#define BLYNK_PRINT Serial#include <ESP8266WiFi.h>#include <BlynkSimpleEsp8266.h>#include <Wire.h>#include <pcf8574_esp.h>#define ADDRESS_PCF8574 0x20 // Address PCF8574 on the I2C bus#define SDA 4 // Pin SDA wire #define SCL 5 // Pin SCL wire#define BUTTON_1 V1 // Expander I/O 4x4 relay1#define BUTTON_2 V2 // Expander I/O 4x4 relay2#define BUTTON_3 V3 // Expander I/O 4x4 relay3#define BUTTON_4 V4 // Expander I/O 4x4 relay4// Macros to work with bits#define BIT_SET(reg, bit) reg |= 1 << bit#define BIT_RESET(reg, bit) reg &= ~(1 << bit)#define BIT_TOGGLE(reg, bit) reg ^= 1 << bit#define BIT_IS_SET(reg, bit) (reg & (1 << bit)) != 0#define BIT_IS_RESET(reg, bit) (reg & (1 << bit)) == 0//--------------------------// You should get Auth Token in the Blynk App.// Go to the Project Settings (nut icon).char auth[] ="auth";
// Your WiFi credentials.// Set password to "" for open networks.char ssid[] ="ssid";
char pass[] ="pass";
//----------------------------------//PCF8574//----------------------------------typedefstruct {
bool triggerButton[4] = { false, false, false, false };
bool stateButton[4] = { false, false, false, false };
}PCF8574TypeDef;
PCF8574TypeDef pcf8574Struct;
PCF857x pcf8574(ADDRESS_PCF8574, &Wire, false);
// Prototypes of functionsstaticvoidreadExpanderKey(void); // Read the state of the buttonsstaticvoidwriteStateExpanderRelay(void); // Write the state of the relay//-----------------------------------voidsetup()
{
// Debug console
Serial.begin(115200);
Wire.begin(SDA, SCL);
pcf8574.begin(0xF0);
Blynk.begin(auth, ssid, pass);
// You can also specify server://Blynk.begin(auth, ssid, pass, "blynk-cloud.com", 8442);//Blynk.begin(auth, ssid, pass, IPAddress(192,168,1,100), 8442);
}
voidloop()
{
Blynk.run();
// You can inject your own code or combine it with other sketches.// Check other examples on how to communicate with Blynk. Remember// to avoid delay() function!// Read the state of the buttons on the PCF8574
readExpanderKey();
}
BLYNK_CONNECTED()
{
Blynk.notify("Demo PCF8574 online!");
Blynk.syncAll();
}
BLYNK_WRITE(BUTTON_1)
{
pcf8574Struct.stateButton[0] = param.asInt();
//Let's record the state of the relay on PCF8574
writeStateExpanderRelay();
}
BLYNK_WRITE(BUTTON_2)
{
pcf8574Struct.stateButton[1] = param.asInt();
//Let's record the state of the relay on PCF8574
writeStateExpanderRelay();
}
BLYNK_WRITE(BUTTON_3)
{
pcf8574Struct.stateButton[2] = param.asInt();
//Let's record the state of the relay on PCF8574
writeStateExpanderRelay();
}
BLYNK_WRITE(BUTTON_4)
{
pcf8574Struct.stateButton[3] = param.asInt();
//Let's record the state of the relay on PCF8574
writeStateExpanderRelay();
}
staticvoid readExpanderKey(void)
{
// Read all 8 bits at onceuint8_t buff_in = pcf8574.read8();
// We are only interested in 4 high bits (button state)
buff_in >>=4;
// Analyze the state of high bitsfor (int i =0; i <4; i++)
{
if (BIT_IS_RESET(buff_in, (i)) &&!pcf8574Struct.triggerButton[i])
{
pcf8574Struct.triggerButton[i] =true;
pcf8574Struct.stateButton[i] =!pcf8574Struct.stateButton[i];
if (Blynk.connected())
{
switch (i)
{
case0:
Blynk.virtualWrite(BUTTON_1, pcf8574Struct.stateButton[i]);
break;
case1:
Blynk.virtualWrite(BUTTON_2, pcf8574Struct.stateButton[i]);
break;
case2:
Blynk.virtualWrite(BUTTON_3, pcf8574Struct.stateButton[i]);
break;
case3:
Blynk.virtualWrite(BUTTON_4, pcf8574Struct.stateButton[i]);
break;
default:break;
}
}
}
elseif (BIT_IS_SET(buff_in, (i)) && pcf8574Struct.triggerButton[i])
{
pcf8574Struct.triggerButton[i] =false;
}
}
// Let's record the new state of the relay
writeStateExpanderRelay();
}
staticvoid writeStateExpanderRelay(void)
{
uint8_t buff_out =0xFF;
for (int i =0; i <4; i++)
{
if (pcf8574Struct.stateButton[i])
{
BIT_SET(buff_out, i);
}
else
{
BIT_RESET(buff_out, i);
}
}
pcf8574.write8(buff_out);
}
Отримайте "AUTH TOKEN" для свого пристрою, та вставте його в демонстраційний код замість "auth". А також вставте в демокод "SSID" і "PASS" вашої WiFi мережі.
Демонстраційний проект
До проекту Blynk додайте 4 кнопки і назначте їм і'я, колір - за вашим смаком. А також назначте кнопкам віртуальні шпильки: V1, V2, V3, V4. Режим всіх кнопок "SWITCH".
Додайте віджет "Notification".
Або скануйте цей код і отримаєте готовий демо-проект на свій смартфон:
Замовлення
Плата - 3$ (у.о)
Плата + деталі для самостійного збирання - 9$ (у.о)
Опис прошивки не повний, поступово буду додавати інформацію, вона дуже об'ємна. Прошивка повноцінна можна користуватись. Зворотній зв'язок вітається.
update 30.12.2019 - додав прошивку 1.1.7.8 update 01.10.2019 - додав прошивку 1.1.7.3 update 07.11.2018 - додав прошивку 1.1.6 + оновив інформацію щодо оновлення. update 09.10.2018 - додав прошивку 1.1.5 update 26.09.2018 - додав прошивку 1.1.4 + оновив інформацію щодо оновлення. update 14.07.2018 - додав прошивку 1.1.3 update 02.06.2018 - додав прошивку 1.1.1 update 23.04.2018 - додав розділ "Як скинути налаштування" пристрою в початковий стан. Оновив інформацію в розділі "Як налаштувати" - для користувачів локальних blynk серверів тепер порт за замовчуванням: 8080. update 13.04.2018 - додав прошивку 1.1.0 оновив схему датчиків які підключаються до GPIO14. Деякі правки в тексті щоб відповідало поточному стану. update 05.04.2018 - додав прошивку 1.0.9 та схему підключення світлодіодної стрічки для саморобних пристроїв update 30.03.2018 - додав прошивку 1.0.8 update 29.03.2018 - додав розділ "Меню налаштувань Widget TABLE", опис Widget TERMINAL update 28.03.2018 - додав прошивку 1.0.7 і схеми підключення периферії до GPIO14 update 15.03.2018 - додав схему для саморобок. update 14.03.2018 - додав розділи "Планувальник і годинник реального часу", "Оновлення по Web OTA", "Віртуальні шпильки".
Прошивка 1.1.7.8
Додав час і дату до повідомлень про reconnect в термінал blynk і в serial terminal;
Коли GPIO14 в режимі PIR або SECURITY, то при першому підключені до blynk, або при перепідключені до серверу blynk - відправляється на сервер стан піну GPIO14;
І найголовініше!!! Кардинально перероблено логіку конекту і реконекту до мережі WiFi та серверу Blynk. Тепер пристрій в будь якому разі відновить з'єднання при наявності WiFi і мережі інтернет. Пристрій на який перший раз встановили прошивку MyHomeIoT при першому ввімкненні живлення, автоматично входить в режим точки доступу з ім'ям мережі "MyHomeIoT-Sonoff" або "Sonoff Basic, TH, T1". Під'єднавшись до цієї мережі перейдіть з бравзера за адресою 192.168.4.1 та потрапите на сторінку початкового налаштування (так було і раніше). Далі відмінності. Якщо після перебоїв з електрикою подали живлення на пристрій і на роутер WiFi одночасно, то пристрій протягом 1 хвилини намагається з'єднатись з роутером (як правило, за 1 хвилину будь який роутер "підіймає" WiFi мережу). У разі з'єднання пристрій працює в штатному режимі з мережею. У разі невдалого з'єднання, пристрій працює в штатному режимі без мережі. Кожні 2 хвилини намагається відновити з'єднання з WiFi та сервером Blynk. При відновлені мережі WiFi та доступу до серверу blynk з'єднання відновиться автоматично. Щоб скинути налаштування і увійти в режим початкових налаштувань можна, як і раніше, тримати натиснутою кнопку GPIO0 більш ніж 10 секунд. Або в терміналі blynk надіслати на пристрій команду "reset". Після цього пристрій "обнулиться", перезавантажиться, і створить власну мережу WiFi на 180 секунд, під'єднавшись до якої можна зайти з браузера за адресою 192.168.4.1 щоб потрапити на сторінку початкових налаштувань пристрою.
Додав пітримку Sonoff T1 в прошивці тільки для Sonoff. Віртуальні шпильки для керування сенсорними кнопками Sonoff T1 з додатку Blynk - V20, V34, V35;
Додав можливість при надсиланні даних через Webhook регулювати частоту надсилання. Зараз є: disable, 1 minute, 5 minute, 10 minute, 20 minute, 30 minute. Цей параметр можна налаштувати в таблиці налаштувань на V66.
Оновив інформацію щодо віртуальних шпильок по команді "pins" в терміналі на V41
Додав WebHook для сенсору HDC1080 на V74
Для керування RGB LED Strip, додав підтримку 16 канального 12 бітного розширювача широтно-імпульсної модуляції на PCA9685, керування каналами по I2C шині. Тепер у вас є можливість з ESP8266, WeMos, NodeMCU, а також пристроїв Sonoff Basic (TH), керувати 16-ма незалежними каналами, яким можна задавати значення від 0 до 4095, щоб задати як інтенсивність свічення, так і колір свічення RGB світлодіодної стрічки. Схема підключення PCA9685 типова. Адреса PCA9685 на шині I2C має бути 0x50. Можна використовувати готові модулі на PCA9685, які можна купити будь де, наприклад тут, або тут. Виходи каналів підключати до світлодіодних стрічок через MOSFET ключ. Встановлення рівня на каналах PWM 0-15 прив'язані до таких шпильок: V100 - V115. Увімкнути/вимкнути світлодіодні стрічки, кнопка на V33. Два планувальника для кнопки на V33 прив'язані до таких шпильок: V64, V65
Важливо!!! Після оновлення прошивки, налаштування в таблиці-меню, що на V66 скинуться на значення за замовчуванням. Перепрошую за незручності.
Виправив помилку при виборі типу сенсора DHT. Було: при обрані будь якого типу сенсору DHT - оброблявся сенсор DHT22. Зараз: перевірено на DHT22, DHT11 - показники коректні.
Додано обробку ADC на A0. За замовчуванням вимкнено. В таблиці-меню, що на V66, можна обрати: отримувати, або значення у вольтах, або значення ADC від 0 до 1024. За замовчуванням на A0 очікується максимальна напруга 3.3 вольта. Це значення можна змінити через команду в терміналі що на V41. Наприклад, максимальна напруга яку ви будете міряти становить 5.5 вольт. В терміналі вводити таку команду: "maxvoltage=5.5". Замість символу "=" можна вводити як "пробіл", так і "-". Це потрібно для коректного обрахунку виміряної напруги у вольтах. Данні з A0 очікуються на V81. Увага!!! Напряму на A0 чипу ESP8266 можна подавати максимальну напругу - 1 вольт!!! Щоб міряти більшу напругу потрібно вимірювану напругу подавати через резистивний дільник. Наприклад, такі плати, як NodeMCU чи Wemos mini вже мають такий дільник. І на A0 вже можна подавати максимальну напругу 3.3 вольта. Значення резисторів для дільника наруги можна вирахувати по формулі чи скористатись онлайн калькулятором (google.com у допомогу).
Додано підтримку високоточного (14 розрядного) сенсору температури і вологості HDC1080. Значення температури і вологості виводяться, як на дисплей SSD1306, при його наявності, так і на віртуальні шпильки Blynk - V16, V17.
Додав команду до терміналу "name" - повертає ім'я пристрою, яке ви задали при початковому налаштуванні
Додано підтримку плати "Water Level". Чотири рівня води (пустий, 1/4, 1/2, 3/4, повний), впускний і випускний клапан, світлодіодна індикація режимів роботи і помилки сенсору. Захист від переливу води. Керування по шині I2C, адреса пристрою на шині 0x21. Кнопка встановлення, наперед заданого, рівня води - V31. Має два тижневих планувальника - V62, V63. Індикатор рівня води - V15. Сегментний перемикач встановлення потрібного рівня води - V32
Виправив індикацію втрати зв'язку з сервером Blynk і трішки змінив функцію реконекту до мережі WiFi та серверу Blynk
Змінено поведінку світлодіода, що на GPIO13 в режимі "Security". Тепер світлодіод світиться коли порушено охорону (контакт на GPIO14 розімкнуто) і світлодіод вимкнено коли об'єкт під охороною (контакт на GPIO14 замкнуто). Додано повідомлення про зміну стану охорони в віджет термінал V41 (дата, час, стан)
Тепер для всіх підтримуваних датчиків доступний WebHook. За замовчуванням WebHook вимкнено. Увімкнути можна в таблиці-меню, що на V66. Докладно дивись в розділі "WebHook"
В додачу до DHT22 (AM2302, AM2321) додано підтримку датчиків DHT11, DHT21 (АМ2301). За замовчуванням очікується DHT22, інші типи DHT можна обрати в таблиці-меню, що на V66.
І головне оновлення це підтримка плати розширення 4x4 - "Expander I/O 4x4" (чотири реле + чотири кнопки). Керування по шині I2C з адресою пристрою на шині 0x20. Реле "прив'язані" до таких віртуальних шпильок як: V21, V22, V23, V24. До кожного додаткового реле є один тижневий планувальник. Схеми, опис, за ланкою - "Expander I/O 4x4"
Важливо!!! Після оновлення налаштування, в таблиці-налаштувань, що на V66, скинуться на значення за замовчуванням. Потрібно знову налаштувати за вашими вподобаннями чи потребами. Вибачте за незручності, але структура даних для налаштувань змінилась потрібен перезапис даних налаштувань.
Прошивка 1.1.0
Додав режим PIR на GPIO14 (детально в "Меню налаштувань пристрою Widget TABLE")
Покращив роботу сенсору BME280, та BMP180
Додав нову команду до віджету терміналу "altitude". Актуально для пристроїв з сенсором BMP180 і BME280. В рядку для вводу набрати слово "altitude" (без лапок) потім пробіл, або тире, або дорівнює, а вже потім висоту в метрах цілим числом над рівнем моря де встановлено пристрій. Нове значення висоти запам'ятається в EEPROM пристрою. За замовчуванням "altitude=0"
По дрібничкам. Щось оптимізував, щось виправив, щось додав, щось прибрав
Додав до меню режим роботи GPIO12, де знаходиться на Sonoff реле. Тепер на GPIO12 може бути як реле, так і світлодіодна стрічка під'єднана через MOSFET транзисторний ключ. Та керувати світлодіодною стрічкою не тільки увімкнути/вимкнути, а й регулювати яскравість стрічки за допомоги віджета SLIDER якому призначити віртуальну шпильку V20. Скоріше, це оновлення для саморобок, так як під'єднати до Sonoff світлодіодну стрічку, у цьому разі, вимагатиме значних переробок самого Sonoff, та необхідно забезпечити окреме живлення світлодіодної стрічки. Схема додається в розділі нижче.
Спростив режим "Security". Тепер, якщо обрано режим охорони і до GPIO14 під'єднано контакти охоронного сенсора, то працює це так: коли контакти замкнути - на сервер відсилається на віртуальну шпильку V19 значення 255, а коли розімкнути, на сервер на шпильку V19 відсилається значення 0. На V19 в додатку Blynk App можна навішати віджет LED. А необхідні події про надсилання повідомлень, електронних листів, спрацювань реле вже робите по бажанню, самі, через віджет EVENTOR в додатку Blynk App.
Важливо! Після оновлення обов'язково перевірте налаштування в меню, що в таблиці на шпильці V66. Скоріше за все деякі налаштування "злетять".
Виправив помилку пов'язану віджетом TIME_INPUT. Було: як обрати тільки час для Start, а час для Stop не обирати, то подія Stop все одно опівночі відбудеться. Або навпаки коли обрати час для Stop, а час для Start не обирати, то подія Start все одно опівночі відбудеться. Виправлено!
Додав меню налаштувань до віджету "Table". Подробиці в розділі "Меню налаштувань Widget TABLE".
Зміни в командах до віджету "Terminal". Тепер команда "reset" - скидання налаштувань в початковий стан (SSID, PASS і AUTH потрібно вводити заново). А команда "reboot" - це просто перезавантаження пристрою.
Тепер на "GPIO14" можна під'єднати не тільки сенсори DS18B20 або DHT22, а і додаткову кнопку, яка дублює увімкнути/вимкнути реле. В додачу, можна в налаштуваннях GPIO14 виставити режим "Security". Додавши віджет світлодіоду (Widget LED) на віртуальну шпильку V19 можна відстежування стану охоронного датчика, що на GPIO14. Віджет світлодіоду увімкнено, як об'єкт під охороною (замкнуті контакти), віджет світлодіоду вимкнено, як об'єкт знято з охорони (розімкнуті контакти).
Важливо!!! В наступних прошивках не буде підтримки MENU V60 - режим поведінки реле на GPIO12 при подачі живлення на пристрій. Зараз працює і на MENU V60 і на TABLE V66 (пріоритет MENU V60, якщо встановлено обоє віджети). Також не будуть надсилатися дані до віджету LCD V40.
Автоматичнє визначення підтримуваної периферії при увімкнені пристрою
Підтримка WEB OTA (оновлень по повітрю)
Робота з Blynk сервером
Автоматичне перепідключення при втраті з'єднання
В разі відсутності WiFi - автономно на рівні пристрою функціонал зберігається
З версії 1.1.1 і вище підтримка розширювача портів 4x4 "Expander I/O 4x4" для керування додатковими чотирма реле, як з додатку Blynk App так і з кнопок на платі
З версії 1.1.4 і вище підтримує плату "Water Level" для контролю і встановлення рівня води в ємності, як з додатку Blynk App так і з кнопки на платі
Реле GPIO12
Увімкнути/вимкнути реле як з кнопки, так і з додатку на смартфоні Blynk App
Сім планувальників на тиждень увімкнути/вимкнути реле
Зворотній зв'язок. Якщо натиснути кнопку на пристрої, або спрацює планувальник, то стан реле коректно відобразиться в додатку на вашому смартфоні. Ви завжди будете знати увімкнене, чи вимкнене реле на цей час
Три режими реле при увімкнені пристрою On/Off/Keep (увімкнуте, вимкнуте, як було)
Світлодіод GPIO13
Блимання світлодіоду 5 разів на 1 секунду - пристрій в режимі налаштування
Блимання світлодіоду 2 рази на 1 секунду - триває під'єднання до точки WiFi
Блимання світлодіоду 1 раз на 2 секунди - втрачено зв'язок з сервером Blynk
Світлодіод не світиться - все в порядку
OLED дисплей I2C 0x3C
На дисплей виводиться, раз на 2 секунди по черзі, така інформація:
Поточний час (потрібно додати в проект віджет RTC)
Стан реле (On/Off)
Рівень сигналу WiFi у відсотках
Рівень освітленості (при наявності сенсору)
Температура (при наявності сенсору)
Вологість (при наявності сенсору)
Тиск (при наявності сенсору)
Дисплей можна вимикати і вмикати за розкладом, або кнопкою з додатку Blynk App.
Як прошити
Для заливки прошивки підійде будь який прошивач для ESP8266:
Чи будь який інший, це не принципово. Головне щоб в налаштуваннях прошивача було вірно обрано номер порту куди під'єднано пристрій, швидкість порту 115200, вірно обраний розмір флеш-пам'яті, і початок прошивки має починатись з адреси 0x00000.
Для Sonoff та ESP8266 потрібен ще USB2UART конвертер, наприклад такий:
Для плат типу NodeMCU не потрібно. Зазвичай мають на платі такий конвертер і під'єднуються до ПК звичайним usb шнурком.
Після прошивання, як правило, потрібно пересмикнути живлення. Не кнопкою ресет, а повністю зняти живлення, та знову подати на пристрій.
Доопрацювання Sonoff
Пристрої Sonoff мають місце під гребінку для прошивання, як показано на світлині. Потрібно впаяти туди підходящу гребінку на 5 шпильок для під'єднання USB2UART конвертора (прошивача).
В стоковій комплектації Sonoff на борту має memory flash розміром 8Мбіт (1Мбайт). І поки цього достатньо навіть для оновлень по OTA. Але як маєте навички паяти, то краще перепаяти стокову флешку, на флешку більшого об'єму 32Мбіт (4Мбайт). Щоб при подальшому розвитку прошивки ви могли зберегти можливість оновлюватись за технологією OTA. Плюс цієї модифікації ще в тому, що ви зберігаєте стокову прошивку на випаяній мікросхемі, і в разі, як вам захочеться повернутись до eWelink, ви просто впаюєте мікросхему пам'яті назад і все. Так, як стокова прошивка має захист і підходить виключно під ваш конкретний пристрій, то спосіб з заливкою дампу прошивки від іншого пристрою, більш за все, не оживить ваш пристрій.
У всякому разі, впаювання 5-ти шпилькової гребінки для вдалого прошивання, достатньо.
Місце для впаювання гребінки і призначення виводів гребінки
Наявність сенсорів DS18B20 та DHT22 визначається автоматично, коли обрано режим GPIO14 - sensors (за замовчуванням) в меню-таблиця на V66 . Необхідно обов'язково між GPIO14 та +3.3В впаяти резистор на 4.7КОм.
Резистор R1 на 4.7КОм можна впаяти на саму плату Sonoff (ESP8266, NodeMCU) між GPIO14 та живленням +3.3V. А сенсори вже під'єднувати до шпильок роз'єму. Або можна підпаювати резистор на сам сенсор. Та скоріше за все, сенсор DHT22, вже має цей резистор-підтяжку в своєму корпусі і має працювати і так, без додаткового резистора. Спробуйте спочатку без резистора, як не працює, додайте резистор як показоно в схемі.
Додаткова кнопка, сенсор руху і охоронний датчик
Схема підключення сенсорної кнопки, сенсора руху та охоронного датчика
Для додаткової кнопки і охоронного сенсору потрібно впаяти резистор між GPIO14 та GND будь якого номіналу між 3.3КОм та 10КОм.
плата контролю та встановлення рівня води в ємності "Water Level", адреса на шині 0x21
сенсор температури і вологості HDC1080, адреса на шині 0x40
плата розширення сигналів широтно-імпульсної модуляції PWM 16 каналів 12 біт на PCA9685, адреса на шині 0x50
Наявність периферії визначається автоматично. Необхідно обов'язково між SDA, SCL та +3.3В впаяти по резистору на 10КОм.
Як початково налаштувати
При першому увімкнені, або коли змінились налаштування WiFi роутера, пристрій входить в режим налаштувань і створює свою WiFi точку без паролю з ім'ям "MyHomeIoT-Sonoff",або "MyHomeIoT-ESP8266" в залежності від обраної прошивки. Під'єднайтесь до цієї точки і увійдіть через браузер за адресою "192.168.4.1". Відкриється меню налаштувань.
Початкова сторінка налаштувань
Обрати "Configure WiFi", ввести SSID, PASS вашої WiFi мережі. Назначити унікальне ім'я вашому пристрою. Наприклад: "lustre", "lamp-baby-room", "heater-bad-room", "socked-conditioner", тощо. Та ввести AUTH пристрою в системі Blynk (AUTH надається при додаванні пристрою в проект, дивись у розділі "Як користуватись"). Натиснути "зберегти". Пристрій запам'ятає налаштування до флеш-пам'яті, перезавантажиться, підключиться до вашої WiFi мережі і почне працювати.
До уваги користувачів локальних Blynk-server, в налаштуваннях пристрою зазначте порт 8080. Ось ланка на джерело.
Як скинути налаштування
Налаштування пристрою зберігаються окремо від самої прошивки, тому просте перепрошивання чи оновлення прошивки не зачепить самих налаштувань і вони збережуться. Тому, щоб скинути налаштування у початковий стан, є декілька способів:
Потримайте натиснутою кнопку на пристрої, що на GPIO0, 5-10 секунд і відпустіть її, це призведе до скидання налаштувань у початковий стан, перезавантаження пристрою, створення точки доступу і вхід пристрою в режим налаштувань. На Sonoff це єдина кнопка, а на NodeMCU і подібних пристроях вона теж на GPIO0 і називається "flash".
В віджеті терміналу на смартфоні (Blynk App) введіть команду "reset" - маленькими літерами без лапок. Пристрій так само скине налаштування в початковий стан, перезавантажиться і створить точку доступу. Можна підключитись до цієї ТД і знову ввести потрібні налаштування.
Як користуватись
Перш за все потрібно мати на смартфоні додаток Blynk. Є як для Android, так і для iOS. Встановіть його і запустіть на своєму смартфоні. Зареєструйтесь і створіть новий проект, дайте йому ім'я та оберіть пристрій:
Отримаєте на пошту повідомлення з AUTH для вашого пристрою.
Кнопка керування реле
Додайте в свій проект віджет кнопки, зайдіть в налаштування кнопки і дайте їй ім'я "Relay", оберіть колір на свій розсуд, оберіть віртуальну шпильку "V20", режим кнопки "SWITCH", як на малюнку:
Запустіть проект. Спробуйте понатискати кнопку на смартфоні - реле вмикається і вимикається. Понатискайте кнопкуGPIO0 на пристрої - реле вмикається і вимикається і стан реле видно у вашому смартфоні.
Планувальник і годинник реального часу
Увімкнення і вимкнення реле можна запланувати. Для цього є аж сім планувальників на тиждень. Це віджет "TIME INPUT". Для правильної роботи планувальника потрібен віджет "RTC". Додайте його до свого проекту. Тепер можна додати до проекту віджет "TIME INPUT".
Планувальникам відповідають такі віртуальні шпильки:
Time Input 0 - V50 - реле на GPIO12
Time Input 1 - V51 - реле на GPIO12
Time Input 2 - V52 - реле на GPIO12
Time Input 3 - V53 - реле на GPIO12
Time Input 4 - V54 - реле на GPIO12
Time Input 5 - V55 - реле на GPIO12
Time Input 6 - V56 - реле на GPIO12
Time Input 7 - V57 - реле на GPIO12
Time Input 8 - V58 - реле 1 розширювача 4х4
Time Input 9 - V59 - реле 2 розширювача 4х4
Time Input 10 - V60 - реле 3 розширювача 4х4
Time Input 11 - V61 - реле 4 розширювача 4х4
Time Input 12 - V62 - встановлення рівня води
Time Input 13 - V63 - встановлення рівня води
Time Input 14 - V64 - RGB Led стрічка
Time Input 15 - V65 - RGB Led стрічка
Меню налаштувань пристрою Widget TABLE
Щоб отримати доступ до меню налаштувань свого пристрою. Зупиніть проект. Додайте в проект віджет "Table". В налаштуваннях віджету назначте віртуальну шпильку V66, "ALLOW REORDERING - NO", "CLICKABLE ROWS - YES". Запустіть проект та перезавантажте пристрій утриманням кнопки протягом 3 - 4 секунд, або в терміналі введіть команду "reboot".
Після перезавантаження пристрою віджет таблиця заповниться пунктами меню.з початковими налаштуваннями:
Display flip (з'являється як під'єднано дисплей)
Disabled - зображення за замовчуванням.
Enabled - зображення перевертається по горизонталі. Потрібне перезавантаження пристрою.
Web OTA
Enabled (за замовчуванням) - режим Web OTA увімкнено і за адресою http://ip_device/update доступна сторінка для оновлення прошивки.
Disabled - вимикає цю функцію. Корисно вимикати цю функцію, щоб розвантажити мікроконтролер, як немає потреби в оновленні прошивки. А вмикати вже перед оновленням прошивки. Потрібне перезавантаження пристрою.
Notifications - enable
Enable (за замовчуванням) - на смартфон відправляються сповіщення з пристрою
Disable - сповіщення вимкнуто
WebHook - disable
disable (за замовчуванням) - дані до віджету WebHook не надсилаються
1 minutes - надсилаються дані з сенсорів до віджету WebHook з періодичністю в 1 хвилину
5 minutes - надсилаються дані з сенсорів до віджету WebHook з періодичністю в 5 хвилин
10 minutes - надсилаються дані з сенсорів до віджету WebHook з періодичністю в 10 хвилин
20 minutes - надсилаються дані з сенсорів до віджету WebHook з періодичністю в 20 хвилин
30 minutes - надсилаються дані з сенсорів до віджету WebHook з періодичністю в 30 хвилин
Power - OFF
OFF (за замовчуванням) - коли на пристрій подати живлення, то реле буде вимкеним.
ON - коли на пристрій подати живлення, то реле увімкнеться.
KEEP - коли на пристрій подати живлення, то реле прийме стан, в якому знаходилось до відключення живлення (сінхронізується з додатком на смартфоні).
GPIO14 - Sensors (за замовчуванням).
Sensors - при подачі живлення пристрій шукає на GPIO14 цифрові сенсори DS18B20, DHT22 і при наявності сенсорів збирає дані з них і відправляє їх на сервер Blynk.
Button - додаткова кнопка яка дублює системну кнопку що на GPIO0. Наприклад, підключити таку сенсорну кнопку і вивести її окремо від пристрою, або вмонтувати в середину корпусу і легким дотиком вмикати чи вимикати реле. Або ж підключити звичайну кнопку дзвінкового типу і вивести її в зручне місце. Ця кнопка тільки вмикає і вимикає реле. Щоб кнопкою перезавантажити пристрій чи скинути налаштування користуйтесь системною кнопкою що на GPIO0.
PIR - це режим сенсору руху. До GPIO14 можна під'єднати такий сенсор і на V19 "відловлювати" стан "0" або "1". А вже через віджет "Eventor" створити події які будуть відбуватись при зміні стану. Наприклад створити подію в "Eventor": якщо на V19 - "0", то шлемо до V20 - "0", якщо на V19 - "1", то шлемо до V20 - "1". То отримуємо таку логіку роботи. Коли повз датчику руху проходить людина, то датчик встановлює стійку логічну "1" на GPIO14, спрацьовує подія і надсилається "1" до V20, де в нас "прикріплене" реле, а реле вмикає, наприклад, світло. Коли вийшов час, заданий в налаштуваннях PIR sensor, датчик руху встановлює стійкий "0" на GPIO14, а "eventor" надсилає до V20 - "0" і реле вимикається, контактами розриває ланцюг живлення світла. Світло вимкнулось. Або замість V20 в "подіях" встановити в V30 і тоді коли до пристрою підійде людина увімкнеться дисплей, а коли людина відійде, то через деякий час (задається налаштуваннями самого PIR sensor) дисплей вимкнеться. Цей режим аналогічний режиму Security, з різницею, що на V19 в режимі PIR надсилається 0 або 1 та не змінює свій стан світлодіод, який на пристрої, а в режимі Security надсилається 0 або 255, та змінюється стан світлодіода на пристрої (увімкнутий - коли під охороною, вимкнутий - коли охорону порушено) .
Security - це режим охоронної кнопки (геркон, кінцевик, контакти, тощо). До GPIO14 під'єднати, наприклад, датчик типу геркон (що комутується магнітом) і на V19 "відловлювати" стан "0" або "255". Наприклад, на V19 в додатку Blynk App можна навішати віджет "LED". І наочно бачити стан охорони. Також за допомоги віджету "Eventor" створити події які будуть відбуватись при зміні стану охорони. Наприклад створити подію в "Eventor": якщо на V19 - "0", то шлемо сповіщення "Notification" з повідомленням "Security - OFF", якщо на V19 - "1", то шлемо сповіщення "Notification" з повідомленням "Security - ON". То отримуємо таку логіку роботи. Коли, наприклад, відкриваються двері і геркон розмикає контакти, то датчик встановлює стійкий логічний "0" на GPIO14, спрацьовує подія і надсилається сповіщення "Security - OFF" на ваш смартфон. Коли закрити двері, в герконі замкнуться контакти і на GPIO14 отримуємо стійку "1", а "eventor" надсилає до сповіщення "Security - ON". Так ви зможете контролювати стан дверей, вікон, тощо. Цей режим аналогічний режиму PIR, з різницею, що на V19 в режимі PIR надсилається 0 або 1 та не змінює свій стан світлодіод, який на пристрої, а в режимі Security надсилається 0 або 255, та змінюється стан світлодіода на пристрої (увімкнутий - коли під охороною, вимкнутий - коли охорону порушено).
Nothing - до шпильки GPIO14 нічого не під'єднано. Корисний режим для люстри чи іншого освітлювального пристрою. Швидке увімкнення світла при подачі живлення на пристрій (не скануються сенсори на GPIO14).
DHT Type - DHT22 (з'являється цей пункт при наявності датчику DHT на GPIO14)
DHT22 (за замовчуванням) - тип датчику DHT 22, AM2302, AM2321
DHT11 - тип датчику DHT11
DHT21 - тип датчику DHT 21, AM2301
Outlet pump (з'являється цей пункт коли під'єднано плату "Water Level" до шини I2C)
Disable (за замовчуванням) - випускний клапан не встановлено
Enable - випускний клапан встановлено
ADC (вимірювання напруги на A0)
Off (за замовчуванням) - вимірювання не відбувається і на сервер нічого не надсилається
Voltage - виміряні значення будуть надсилатись у вольтах
Value - виміряні значення (0 - 1024) будуть надсилатись без перетворень
Setting - unchanged за замовчуванням unchanged і цей рядок не підсвічується.
Settings save - Apply. Коли ви робите зміни в налаштуваннях з'явиться цей пункт меню. За допомоги цього пункту можна зберегти налаштування до EEPROM пристрою.
Device reboot - Apply. Якщо буде потрібне перезавантаження пристрою, то з'явиться цей пункт меню. Натиснувши ще раз, ваш пристрій перезавантажиться з новими налаштуваннями.
Віджет Terminal
Зупиніть проект. Додайте до проекту Widget TERMINAL, та встановіть такі налаштування:
INPUT - V41
INPUT LINE - ON
AUTOSCROLL - ON
Тепер в вікні терміналу ви зможете бачити інформацію, що надсилає ваш пристрій, для вас. А також вводити команди в термінал (команди вводяться маленькими літерами):
ip - повертає IP адресу вашого пристрою в мережі
mac - повертає mac адресу вашого пристрою
version - повертає версію прошивки
name - повертає ім'я пристрою
reset - скидає налаштування пристрою до початкового стану
reboot - перезавантажує пристрій
pins - пам'ятка по віртуальним шпилькам
altitude - (за замовчуванням 0 (нуль)) команда вводу висоти над рівнем моря, де буде встановлений пристрій, це актуально для датчиків BMP180 та BME280, для корекції показників тиску. Приклади вводу команди: "altitude 42", "altitude-56", "altitude=83". Де "altitude" команда, а числа роз'єднані символами пробіл, тире і дорівнює - висота в метрах над рівнем моря де встановлено пристрій. Цю висоту над рівнем моря можна взнати, наприклад по гугломапам.
maxvoltage - (за замовчуванням 3.3 вольта) команда вводу максимальної напруги яку вимірюємо на "дільнику напруги" A0.
Оновлення по WEB OTA
Оновлення прошивки зручно робити за технологією WEB OTA. Пристрій, який вже працює в електричній схемі, не потрібно демонтувати, розбирати і знову підключати до ПК, щоб залити нову прошивку. Достатньо зайти за адресою: http://host.local/update , де host це унікальне ім'я пристрою, яке ви надали пристрою в початкових налаштуваннях. Майте на увазі, що домен local підтримують не всі роутери, тому, скоріш за все потрібно набрати в браузері http://device_ip/update , де device_ip - це ip вашого пристрою в вашій локальній мережі. Взнати його можна, як засобами вашого роутера, так і засобами якогось програмного IP сканера, або ж додавши до свого проекту віджет terminal який має бути на віртуальній шпильці V41, та ввести команду "ip". В вікні терміналу надрукується поточний IP вашого пристрою.
Коли завантажиться сторінка оновлення прошивки, оберіть через файловий діалог файл прошивки, та натисніть кнопку "update". Через декілька секунд прошивка оновиться і пристрій перезавантажиться. Пристрій буде "пам'ятати" ваш SSID, PASS, AUTH, та ім'я пристрою і в повторному налаштуванні немає потреби. Пристрій після оновлення і перезавантаження під'єднається до мережі, з'єднається з Blynk сервером і почне працювати.
Віртуальні шпильки
Сенсор DS18B20
Температура DS18B20_0 V0 - працює
Температура DS18B20_1 V1 - працює
Температура DS18B20_2 V2 - працює
Температура DS18B20_3 V3 - працює
Температура DS18B20_4 V4 - працює
Сенсор DHT22
Температура DHT22 V5 - працює
Вологість DHT22 V6 - працює
Сенсор TSL2561
Люкси TSL2561 V7 - працює
Сенсор BMP180
Температура BMP180 V8 - працює
Тиск BMP180 V9 - працює
Висота над рівнем моря BMP180 V10 - працює
Сенсор BME280
Температура BME280 V11 - працює
Вологість BME280 V12 - працює
Тиск BME280 V13 - працює
Висота над рівнем моря BME280 V14 - працює
Сенсор HDC1080
Температура HDC1080 V16 - працює
Вологість HDC1080 V17 - працює
Рівень WiFi сигналу у відсотках
Рівень WiFi сигналу у відсотках V80 - працює (при відсутності WiFi сигналу показує > 200%)
Рівень напруги на A0
Рівень напруги або значення ADC на A0 V81 - працює
Реле
Кнопка на V20 (керує основним реле, що на платі GPIO12) - працює
Кнопка на V21 (керує додатковим реле 1 що на платі Expander I/O 4x4) - працює
Кнопка на V22 (керує додатковим реле 2 що на платі Expander I/O 4x4) - працює
Кнопка на V23 (керує додатковим реле 3 що на платі Expander I/O 4x4) - працює
Кнопка на V24 (керує додатковим реле 4 що на платі Expander I/O 4x4) - працює
Кнопка на V25 - зарезервовано, в розробці
Кнопка на V26 - зарезервовано, в розробці
Кнопка на V27 - зарезервовано, в розробці
Кнопка на V28 - зарезервовано, в розробці
Кнопка на V29 - зарезервовано, в розробці
Дисплей
Кнопка на V30 - Вмикає і вимикає дисплей SSD1306
Рівень води
Кнопка на V31 (Widget Button) - Ініціює встановлення потрібного рівня води
Тижневі планувальники встановлення рівня води на V62, V63 (Widget Time Input)
Сегментний перемикач встановлення потрібного рівня води наV32 (Widget Segmented Switch)
Індикатор рівня води на V15 (Widget Level H)
Плата розширювача на PCA9685
zeRGBa або Slider V100 - V115 - встановлення рівня на каналах PWM 0-15
Кнопка на V33 - вмикає або вимикає RGB стрічку
Два тижневі планувальники на V64 і V65
Віджети
LED V19 - стан охоронного сенсору. 0 - вимкнуте (в режимі охорони), 255 - увімкнуто (охорону порушено), стан PIR датчику. 0 - вимкнуте, 1 - увімкнуто (в режимі PIR)
TERMINAL V41 - різноманітна інформація та введення команд (корисна річ)
TIME_INPUT_0 V50 - планувальник реле на GPIO12
TIME_INPUT_1 V51 - планувальник реле на GPIO12
TIME_INPUT_2 V52 - планувальник реле на GPIO12
TIME_INPUT_3 V53 - планувальник реле на GPIO12
TIME_INPUT_4 V54 - планувальник реле на GPIO12
TIME_INPUT_5 V55 - планувальник реле на GPIO12
TIME_INPUT_6 V56 - планувальник реле на GPIO12
TIME_INPUT_7 V57 - планувальник увімкнення і вимкнення дисплею SSD1306
TIME_INPUT_8 V58 - планувальник для реле 1 що на платі Expander I/O 4x4
TIME_INPUT_9 V59 - планувальник для реле 2 що на платі Expander I/O 4x4
TIME_INPUT_10 V60 - планувальник для реле 3 що на платі Expander I/O 4x4
TIME_INPUT_11 V61 - планувальник для реле 4 що на платі Expander I/O 4x4
TIME_INPUT_12 V62 - планувальник для встановлення рівня води на платі "Water Level"
TIME_INPUT_13 V63 - планувальник для встановлення рівня води на платі "Water Level"
TIME_INPUT_14 V64 - планувальник для увімкнення/вимкнення LED стрічок
TIME_INPUT_15 V65 - планувальник для увімкнення/вимкнення LED стрічок
TABLE V66 - налаштування пристрою
GPS_TRIGGER_ENTER V70 - не працює. В розробці.
GPS_TRIGGER_EXIT V71 - не працює. В розробці.
WebHook
Дані з датчиків можна відправляти не тільки на сервер Blynk, а й на інші служби, наприклад, такі як: ThingSpeak, Народний Моніторинг, тощо.
WHOOK_HDC1080 V74 - дані з сенсору HDC1080: температура і вологість
WHOOK_DHT V75 - дані з сенсору DHT22: температура і вологість.
WHOOK_BMP180 V76 - дані з сенсору BMP180: температура і тиск.
WHOOK_BME280 V77 - дані з сенсору BME280: температура, вологість, тиск
WHOOK_TSL2561 V78 - дані з сенсору TSL2561: рівень освітлення
WHOOK_DS18B20 V79 - дані з сенсорів DS18B20: температура
Плата Expander I/O 4x4 для Sonoff Basic (TH) та інших пристроїв на базі ESP8266 з прошивкою MyHomeIoT 1.1.1 і вище
Схема, малюнки плат, gerber файли, опис за ланкою: Expander I/O 4x4
Реле прив'язані до таких шпильок: V21, V22, V23, V24
Та кожне реле має по одному планувальнику на таких шпильках: V58, V59, V60, V61
Плата в зборі
Приклад інтерфейсу для плати розширення
Плата Water Level
Схема пристрою "Рівень води" та демо-код за цією ланкою - Water Level
Кнопка встановлення рівня води прив'язана до - V31 (Widget Button OFF - 0, ON - 1, SWITCH)
Два планувальника встановлення рівня води на - V62, V63 (Widget Time Input: ALLOW START/STOP INPUT - NO)
Індикатор рівня води - V15 (Widget Level H 0 - 255, READING RATE - 1-5sec)
Сегментний перемикач встановлення потрібного рівня води - V32 (Widget Segmented Switch - 5 sectors: Empty, 1/4, 1/2, 3/4, Full)
Прототип плати "Рівень води"
Приклад інтерфейсу для "Рівня води"
Схема розширювача PWM PCA9685 (16ch 12bit)
Типова схема підключення PCA9685
Встановлення рівня на каналах PWM 0-15 прив'язані до таких шпильок: V100 - V115
Увімкнути/вимкнути світлодіодні стрічки, кнопка на V33
Два планувальника для кнопки на V33 прив'язані до таких шпильок: V64, V65
Адреса на шині I2C: 0x50
Схема для саморобок на ESP8266 сумісний з Sonoff Basic(TH)
Схема для саморобок на ESP8266 та NodeMCU
Клацайте на світлину щоб збільшити. Де HLK-PM1 це такий ізольований від мережі 220V малогабарітний, малопотужний блок живлення. Потрібен 220V to 5V. U1 - стабілізатор напруги на 3.3V AMS1117.
Схема для саморобок на ESP8266 для підключення світлодіодної стрічки на 12В з регулюванням яскравості
Схема для саморобок на ESP8266 для роботи з світлодіодною стрічкою
Клацайте на світлину щоб збільшити. Де U1 - стабілізатор напруги на 3.3V AMS1117. Транзистор Q1 будь який MOSFET n-channel з напругою на повне відкриття VGS(th) не більше 3V. Наприклад AO3400. Купити пачками можна тут.