
Какие задачи решает радио выключатель:
- В комнате с готовым ремонтом переместили мебель, шкафом закрыли выключатель
- На этапе ремонта не продумали удобный выключатель около кровати
- В доме из бруса не эстетично тянуть наружную проводку, требуются радио выключатели, но с конкретным дизайном
- Интеграция с существующей системой автоматизации
На данный момент существуют Z-Wave выключатели на батарейках, например Z-Wave.Me Wall Controller, но эти выключатели идут с определенным дизайном клавиш. Если вы хотите использовать выключатели Legrand, Gira и др., то тут на помощь приходит Z-Wave плата Z-Uno.
Я покажу как из обычно выключателя Gira сделать радио выключатель на батарейках, который можно установить в любое удобное место. Видео работы выключателя в конце статьи.
Я использую механизм выключателя Gira для жалюзи с 4 кнопками и фиксацией в середине. Дизайн клавиш и рамки выбрал из серии System 55 только потому, что в линейке Z-Wave выключателей на батарейках есть рамки в таком же дизайне.

Добавление новых функций к Z-Uno происходит постоянно, и в последнем релизе был добавлен KeyScanner, который позволяет обрабатывать нажатия от 112 кнопок одновременно, я ограничусь считыванием 4 кнопок от выключателя.
В приведенном ниже скетче Z-Uno в спящем режиме ожидает нажатия одной из кнопок, после нажатия Z-Uno просыпается и отправляет радио команду, после чего сразу же засыпает, чтобы не расходовать заряд батареи.

Скетч 4-кнопочный радио выключатель на базе Z-Uno
// KeyPad 1x4 #include <ZMEKeypad.h> // Count of rows #define ROWS 1 // Count of columns #define COLS 4 // Set rows pins BYTE rowPins[1] = {17}; // Set columns pins BYTE columnPins[4] = {9, 10, 11, 12}; // Create object KeyPad ZMEKeypad kpd = ZMEKeypad(columnPins, COLS, rowPins, ROWS); #define CONTROL_GROUP1 1 // number of Association Group #define CONTROL_GROUP2 2 // number of Association Group #define SWITCH_ON 0xff #define SWITCH_OFF 0 // Start holding flags for 4 buttons byte button_0_start_holding = TRUE; byte button_1_start_holding = TRUE; byte button_2_start_holding = TRUE; byte button_3_start_holding = TRUE; ZUNO_SETUP_ASSOCIATIONS(ZUNO_ASSOCIATION_GROUP_SET_VALUE_AND_DIM, ZUNO_ASSOCIATION_GROUP_SET_VALUE_AND_DIM); // Send Turn On/Off and Dim commands to associated devices ZUNO_SETUP_SLEEPING_MODE(ZUNO_SLEEPING_MODE_SLEEPING); // SLEEPING MODE void setup() { zunoSetupKeyScannerWU(4); // turn INT1 wakeup into Key Scanner mode with two columns: pins 9 and 10 // can also be called in any other place before zunoSendDeviceToSleep() kpd.begin(); kpd.setHoldTime(50); // 100 ms for detect hold button, 10 = 100 ms kpd.setDebounceTime(2); // 20 ms debounce, 2 = 20 ms } void loop() { byte actions[4]; // Array that return all actions from keypad (hold, release, press, double press, etc.) byte go_to_sleep = FALSE; // go to sleep after button released; // Default value for buttons - inactive, then read real states byte button_0_active = FALSE; byte button_1_active = FALSE; byte button_2_active = FALSE; byte button_3_active = FALSE; byte num_touched_keys = kpd.scanKeys(actions); if (num_touched_keys) { bool hold = KEYPAD_IS_HOLDING(actions[0]); switch (KEYPAD_KEYINDEX(actions[0])) { case 0: // Button Left Down button_0_active = TRUE; if (hold && button_0_start_holding) { // If button 0 start holding button_0_start_holding = FALSE; zunoSendToGroupDimmingCommand(CONTROL_GROUP1, TRUE, TRUE); // start dimming down (group, direction, start_stop) } if (!hold) { // If button 0 not holding go_to_sleep = TRUE; zunoSendToGroupSetValueCommand(CONTROL_GROUP1, SWITCH_OFF); } break; case 1: // Button Left Up button_1_active = TRUE; if (hold && button_1_start_holding) { // If button 1 start holding button_1_start_holding = FALSE; zunoSendToGroupDimmingCommand(CONTROL_GROUP1, FALSE, TRUE); // start dimming up (group, direction, start_stop) } if (!hold) { // If button 1 not holding go_to_sleep = TRUE; zunoSendToGroupSetValueCommand(CONTROL_GROUP1, SWITCH_ON); } break; case 2: // Button Right Down button_2_active = TRUE; if (hold && button_2_start_holding) { // If button 2 start holding button_2_start_holding = FALSE; zunoSendToGroupDimmingCommand(CONTROL_GROUP2, TRUE, TRUE); // start dimming down (group, direction, start_stop) } if (!hold) { // If button 2 not holding go_to_sleep = TRUE; zunoSendToGroupSetValueCommand(CONTROL_GROUP2, SWITCH_OFF); } break; case 3: // Button Right Up button_3_active = TRUE; if (hold && button_3_start_holding) { // If button 3 start holding button_3_start_holding = FALSE; zunoSendToGroupDimmingCommand(CONTROL_GROUP2, FALSE, TRUE); // start dimming down (group, direction, start_stop) } if (!hold) { // If button 3 not holding go_to_sleep = TRUE; zunoSendToGroupSetValueCommand(CONTROL_GROUP2, SWITCH_ON); } break; } } if(!button_0_start_holding && !button_0_active) { // If button 0 release holding button_0_start_holding = TRUE; zunoSendToGroupDimmingCommand(CONTROL_GROUP1, TRUE, FALSE); // stop dimming down (group, direction, start_stop) } if(!button_1_start_holding && !button_1_active) { // If button 1 release holding button_1_start_holding = TRUE; zunoSendToGroupDimmingCommand(CONTROL_GROUP1, FALSE, FALSE); // stop dimming up (group, direction, start_stop) } if(!button_2_start_holding && !button_2_active) { // If button 2 release holding button_2_start_holding = TRUE; zunoSendToGroupDimmingCommand(CONTROL_GROUP2, TRUE, FALSE); // stop dimming down (group, direction, start_stop) } if(!button_3_start_holding && !button_3_active) { // If button 3 release holding button_3_start_holding = TRUE; zunoSendToGroupDimmingCommand(CONTROL_GROUP2, FALSE, FALSE); // stop dimming up (group, direction, start_stop) } // if all buttons released if (kpd.isIdled()) { go_to_sleep = TRUE; } if (go_to_sleep) { zunoSendDeviceToSleep(); } } // Для правильной работы этого скетча на версии Z-Uno 2.0.6 требуется в файле /Volumes/Files/user/Library/Arduino15/packages/Z-Uno/hardware/zw8051/2.0.6/libraries/ZMEKeypad/ZMEKeypad.h добавить "BYTE isIdled(){return mon_keys == 0;};" после строки 55
На каждую из 4 кнопок с помощью ассоциаций настраивается получатель радио команды, это может быть реле, диммер, RGBW лента, LED лампа или другое исполнительное устройство. В скетче я создаю 2 группы ассоциаций для управления 2-мя устройствами, верхние кнопки отправляют команды включения, нижние кнопки отправляют команды выключения.

К пинам Z-Uno 1,2,3,4 подключаем механизм выключателя GIRA. В комплекте с Z-Uno идет штекер, его я припаял к батарейному отсеку 1/2 AA и подключил в разъем для аккумулятора. Батарейка 1/2AA (ER14250) компактная емкая 3.6 В, но можно использовать и 2 батарейки AA, они тоже отлично влезают в подрозетник.
В Z-Uno работают 2 DC-DC преобразователя, при работе от батарейки они не требуются, поэтому их можно исключить из схемы питания, отпаяв перемычку R12. При этом энергопотребление Z-Uno в спящем режиме снижается в 143 раза, с 1 мА до 7мкА.
Подрозетники рекомендую 60 мм глубиной, с ними удобнее работать, в 40 мм подрозетник затолкать Z-Uno с батарейкой, проводами и самим выключателем сложно, но можно!


2 правые кнопки управляют розеткой, отправляют команды ВКЛ и ВЫКЛ на розетка Z-Wave.Me.
2 левые кнопки управляют диммером, при коротком нажатии отправляются команды ВКЛ и ВЫКЛ, при долгом удержании ВВЕРХ или ВНИЗ отправляются команды диммирования на диммер Z-Wave.Me.
Как видите батареечное устройство считывающее состояние кнопок с помощью Z-Uno делается очень просто, и таким способ можно к Z-Uno подключить целую клавиатуру, где каждая кнопка будет выполнять полезную функцию вашего умного дома.
Видео работы батареечного выключателя на базе Z-Uno. Управление диммером и реле.
