image


Предисловие


Умная розетка на Arduino, что может быть проще. Основной целью данного проекта было разработать розетки с беспроводным управлением, а также «автоматизировать» вход в Windows. Мотивирующая составляющая – разобраться, что такое RFID–метки и как с ними работать. В итоге было разработано два устройства – деблокиратор, который считывает карточки и собственно умная розетка, которая принимает сигнал «включиться» от деблокиратора. Если я Вас заинтересовал прошу к прочтению.


К слову, деблокиратор в данном проекте умеет как читать RFID-метки, так и писать на них. Область применения умной розетки достаточно большая. С их помощью можно удаленно включать и отключать электрические устройства. Так же данный проект может быть использован как пример для создания более сложных устройств управления электрическими устройствами (об этом в заключении). Сначала, думаю, стоит показать проект в работе, а потом рассказать как все работает.



Из чего это сделано


Умная розетка


Вид изнутри:


image


Схема подключения:


image


Использованные компоненты:


  • Arduino Leonardo
  • АС-DС миниатюрный блок питания на 12В
  • Bluetooth-модуль
  • Обычная розетка на 220В, 2 штуки
  • Вилка 220В с проводом
  • Контактная площадка
  • Двухцветный светодиод для индикации работы
  • Площадка из ДСП для размещения компонентов

Подробнее о компонентах. Все комплектующие я разместил на площадке из ДСП размером 15 на 15 сантиметров.


image


Крепление всех комплектующих к площадке выполнено при помощи шурупов и предварительно просверленных в площадке отверстий. В качестве микроконтроллера я использовал именно Arduino Leonardo, так как эта плата в отличие от Uno, например, может выступать в роли USB-HID устройства. На фото Uno, но это фото, сделанное до появления идеи разблокировать Windows с помощью розетки. Leonardo нам нужен, чтобы сымитировать ввод пароля. Вместо Leonardo для этих целей можно было взять Arduino Due, Micro, Zero или Esplora.


Модуль реле


Что касаемо модуля реле, то он на два канала:


image


Коммутируемые токи до 10А при AC250V или DC30V. Имеется два управляющих пина на каждое реле и пины питания и земли. Важно отметить, что пины в данном модуле инверсные, то есть делая так:


digitalWrite(relay_pin, HIGH);

Вы размыкаете реле. Чтобы ток пошел, нужно подать на пин логический ноль.


О проводке. Для низковольтной части схемы я использовал обычные коннекторы из шлейфа DuPont. Для высоковольтной части я взял алюминиевые провода сечением 2 мм. Будьте очень осторожны и внимательны при монтаже высоковольтных проводов!


О блоке питания. Я использовал блок питания для светодиодных лент, выходные параметры которого 12В, 0,4 А — достаточно и не много для Arduino. Зачем он нужен? Нужен для того, чтобы низковольтная часть схемы использовало то же напряжение, которое идет на наши розетки. Плюс от блока питания подается на Vin вход Arduino, минус — на Gnd. На заметку: вполне безопасно подключать USB-кабель одновременно с подключенным блоком питания на Vin.


Bluetooth-модуль


Теперь самое интересное — Bluetooth-модуль. В данном проекте я использовал модуль HC-05, так как он может выступать как в роле мастера, так и в роли слейва.


image


Слейвом у меня является модуль, установленный в умную розетку, мастером — модуль в деблокираторе. Таким образом, деблокиратор всегда является инициатором подключения. Данные модули можно сконфигурировать так, чтобы при включении они соединялись автоматически. Так я и сделал. Конфигурирование данного bluetooth-модуля выполняется путем отправки ему AT-команд. Для того, чтобы модуль мог принимать AT-команды его нужно перевести в AT-режим. Модуль, который попался мне (FC-114) имеет на борту кнопку (см. фото). Если ее зажать при включении модуль войдет в AT-режим. Согласитесь, неудобно. При таком подходе я не смогу динамически подключиться к какому-либо неизвестному до этого модулю. Было бы хорошо, чтобы можно было подать на какой-либо пин модуля логическую единицу и таким образом войти в AT-режим. Так и сделано во многих модулях, но не в FC-114. Такой пин имеет номер 34 в моем модуле и для того, чтобы в будущем, если понадобится подключаться к bluetooth-модулям динамически, я припаял к пину 34 модуля провод, который можно подключить к пину Arduino.


image


Теперь о командах для соединения двух bluettoth-модулей HC-05. В режиме слейв каждый модуль HC-05 работает "из коробки". Нужно лишь узнать его MAC-адрес, который мы будем использовать при конфигурировании мастера. Делать это будем при помощи AT-команд, о которых я упоминал выше. Для начала необходимо подключить пин RX bluetooth-модуля к пину 0 Arduino (тоже RX), пин TX соответственно к пину 1 Arduino. Обратите внимание, что здесь соединение не кроссовер, потому что мы используем UART Arduino. Далее необходимо залить на Arduino пустой скетч, так как опять таки мы используем UART Arduino.


void setup()
{
}
void loop()
{
}

Далее, перед включением питания, как я упоминал выше, необходимо зажать маленькую кнопку на bluetooth-модуле, чтобы войти в AT-режим. После этого, используя стандартную IDE (Tools -> Serial Monitor). Также, открыв Serial Monitor, необходимо установить скорость передачи данных (baud rate) равную 38400 и установить подстановку символов \r\n после каждой команды (Both NL & CR). Проверить, что все подключено верно и работает, можно путем ввода "AT". В ответ мы должны получить "OK". Далее можно написать команду "AT+NAME?". В ответ мы должны получить название bluetooth-модуля. На данный момент мы работает со слейв-устройством, поэтому все, что нам нужно, это узнать его MAC-адрес и убедиться, что оно работает в режиме "Slave", а не "Master". Для этого вводим две команды:


AT+ROLE?

Если мы получили 0 — значит, что устройство работает в режиме "Slave", 1 — "Master". Чтобы изменить это значение, команда отправляется таким образом:


AT+ROLE=0 - изменить режим работы на "Slave":

Теперь узнаем MAC-адрес Slave'а, чтобы Master знал, к кому ему нужно подключаться. Вводим команду:


AT+ADDR?

Например, ответ был такой: "ADDR:20:2:110001". Это означает, что MAC-адрес нашего Slave'а 20:2:110001.


image


На этом работа со Slave'ом закончена. Переходим к конфигурированию Master'а. Таким же образом подключаем его к Arduino и заливаем пустой скетч, открываем Serial Monitor, ставим скорость передачи 38400, и подстановку /r/n. Далее вводим команды по порядку.


AT+ORGL
AT+RMAAD
AT+ROLE=1
AT+CMODE=1
AT+INIT
AT+INQ
AT+LINK=MAC-адрес (пример: 20,2,110001)

Итак, подробнее о каждой команде. Команда ORGL полностью сбрасывает устройство, а команда RMAAD удаляет все предыдущие "пары" с другими Slave-устройствами. Команда ROLE, как говорилось выше, имея аргумент 1 означает, что мы хотим, чтобы устройство работало в режиме Master. Команда CMODE с аргументом 1 (по умолчанию равен 0) означает, что наше Master-устройство может подключаться к Slave-устройству с любым адресом (можно задать определенный). Команда INIT запускает библиотеку SPP (Serial Port Profile), нужную для передачи/получения информации. Емкое высказывание зачем она нужна: "В то время как спецификация Bluetooth описывает как работает эта технология, профили определяет то, как с этой технологией работать". Вы можете получить ошибку 17 на данном шаге. Это означает, что библиотека уже запущена, просто продолжайте. Команда INQ означает, что наше Master-устройство начинает поиск Slave-устройств. Вывод данной команды — это список MAC-адресов найденных устройств. Например:


+INQ:address,type,signal   20:2:110001,0,7FFF

Сигнал и тип можно проигнорировать. Находим MAC-адрес нашего Slave'а и следующей командой LINK соединяем Master-устройство со Slave'ом. Обратите внимание, что здесь двоеточия в MAC-адресе заменяются на запятые. После этого Ваши bluetooth-устройства должны начать моргать два раза в ~2 секунды. Это означает, что они соединены. До этого они моргали достаточно часто (два раза в секунду) — это значит, что они в поиске "пары".


Полный список AT-команд:


image


Деблокиратор


Вид изнутри:


image


Схема подключения:


image


Использованные компоненты:


  • Arduino Uno
  • Bluetooth-модуль
  • RFID — сенсор
  • LCD — модуль
  • Тумблер для переключения режима
  • Пьезоэлемент

Подробнее о компонентах.


LCD — модуль


В рамках данного проекта был использован LCD-модуль 1620. Данный дисплей способен отобразить 2 строки по 16 символов каждая. Модуль подключается к микроконтроллеру Arduino через интерфейс I2C. I2C – последовательная шина данных для связи интегральных схем, использующая две двунаправленные линии связи (SDA и SCL). Данные передаются по двум проводам — проводу данных и проводу тактов. Есть ведущий (master) и ведомый (slave), такты генерирует master, ведомый лишь принимает байты. Всего на одной двухпроводной шине может быть до 127 устройств. I2C использует две двунаправленные линии, подтянутые к напряжению питания и управляемые через открытый коллектор или открытый сток – последовательная линия данных (SDA, англ. Serial Dаta) и последовательная линия тактирования (SCL, англ. Serial Clock). В скетче для работы с данным модулем используется библиотека LiquidCrystal_I2С. С ее помощью выводить данные на дисплей предельно просто. Данный пример кода выводит две символьные строки на две строки дисплея.


void lcd_display_two_lines(const char* first_line, const char* second_line)
{
  g_lcd.clear();
  g_lcd.setCursor(0, 0); // Установить курсор в начало первой строки
  g_lcd.print(first_line);
  g_lcd.setCursor(0, 1); // Установить курсор в начало второй строки
  g_lcd.print(second_line);
}

RFID — модуль


image


С этим модулем и с технологией RFID в целом было особенно интересно разобраться. В рамках данного проекта был использован RFID-модуль RC-522, который работает с картами стандарта HF, в частности MIFARE с частотой 13,56 МГц. Данный модуль подключается к микроконтроллеру Arduino через интерфейс SPI. SPI – последовательный синхронный стандарт передачи данных в режиме полного дуплекса, предназначенный для обеспечения простого и недорогого высокоскоростного сопряжения микроконтроллеров и периферии. В SPI используются четыре цифровых сигнала:


  • MOSI – Служит для передачи данных от ведущего устройства ведомому;
  • MISO – Служит для передачи данных от ведомого устройства ведущему;
  • SCK – Служит для передачи тактового сигнала для ведомых устройств;
  • NSS – выбор микросхемы, выбор ведомого

RFID-модуль выступает в качестве ведомого, а микроконтроллер – в качестве ведущего.


Структура памяти RFID-карт MIFARE Classic


Память чипов MIFARE Classic имеет четкую структуру (в отличие от MIFARE DESFIre, имеющего более сложную, файловую организацию памяти). Память MIFARE 1K и MIFARE 4K разделена на сектора, 16 секторов у MIFARE 1K и 40 секторов у MIfare 4K. Каждый сектор MIFARE 1K и первые 32 сектора MIFARE 4K состоят из трех блоков данных и одного блока для хранения ключей (Sector Trailer). Последние 8 секторов MIFARE 4K состоят из 15 блоков данных и одного (16-го) блока хранения ключей. Блоки данных доступны для чтения/записи при условии успешной авторизации по ключу.


О "служебном" блоке. Блок Sector Trailer хранит секретные значения ключей (А и В) для доступа к соответствующему сектору, а также условие доступа (определяемое значением битов доступа). Блок Sector Trailer всегда последний (четвертый) блок в секторе. Каждый сектор MIFARE Classic может иметь свои собственные ключи доступа и условия записи/чтения данных.


О блоках данных. Каждый блок данных состоит из 16 байт, доступных для записи/чтения (кроме блока 0 сектора 0, где хранится не стираемая информация завода-изготовителя). Запись/чтение данных производится по ключу и битам доступа. Блоки данных могут быть сконфигурированы как блоки для обычной записи/чтения, или как блоки хранения условных единиц (функция электронного кошелька). В обычные блоки данных можно записывать любую информацию (цифры, символы и т.п.). Если блок данных сконфигурирован как блок для хранения условных единиц, то работа с таким блоком происходит по командам increment/decrement. То есть числовое значение, хранящееся в таком блоке, можно только увеличивать и уменьшать.


О правилах доступа. Ко всем секторам карты MIFARE Classic доступ осуществляется по единым правилам. Доступ к тому или иному сектору производится с помощью ключей (Ключ А и Ключ В). С помощью Access Condition (условие доступа в Sector Trailer) задаются условия записи и чтения данных из каждого сектора с использованием одного ключа (А или В) или обоих ключей А и В одновременно. Например, при пользовании клиентами карт MIFARE можно реализовать чтение (только чтение) данных из блока по ключу А, в то время как системный администратор может читать и писать данные к память MIFARE, используя ключ В. В четвертом блоке каждого сектора (Sector Trailer) для обеспечения такого разграничения доступа используются три бита (access bits) C1, C2 и С3. С помощью этих битов можно задать восемь различных режимов доступа к сектору MIFARE. Бит C1 считается младшим значащим битом (LSB).


О том, как я использовал память RFID-меток. В рамках проекта используется два режима: основной – чтение RFID – карты и включение розетки, дополнительный – программирование RFID – карты. Для авторизации RFID – карты деблокиратором на нее записывается секретный ключ длиной в 128 байт. 128 байт = 8 блоков по 16 байт. 3 блока пишутся в сектор 1, 3 блока в сектор 2 и, наконец, 2 оставшихся блока в сектор 3. Для чтения необходима аутентификация по ключу А, для записи – по ключу B, которых находятся в trailer блоке. Длина ключа в 128 байт была выбрана без каких-либо принципов, можно было использоваться хоть всю память карты. Ключ — случайный набор символов, который находится в коде прошивки и деблокиратора, и умной розетки. Такое решение сверх-безопасностью явно не обладает, но в рамках проекта задачи обеспечить защищенную систему не стояло. Об этом также в заключении.


Подключение тумблера


image


Как мне кажется, имеет смысл также отметить подключение тумблера к Arduino. Тумблер в деблокираторе используется для переключения режима работы. В первом режиме устройство считывает RFID-карты и если в нужных блоках памяти карты записан секретный ключ, о котором говорилось выше, посылает по bluetooth сигнал "Включить розетки и разблокировать Windows" на умную розетку. Во втором режиме, деблокиратор записывает на RFID-карту секретный ключ. Перед записью он карту считывает: если на ней уже записан правильный секретный ключ, он очищает нужные блоки памяти путем записи нулей. Согласитесь, странно снабжать деблокиратор и функцией чтения, и функцией записи RFID-карт. О том почему так — в заключении.


При подключении тумблеров, кнопок, переключателей имеет место "дребезг контактов" — явление, при котором вместо четкого и стабильного переключения мы получаем случайные многократные неконтролируемые замыкания и размыкания контактов. Другими словами, контакты при соприкосновении начинают колебаться (т.е. «дребезжать»), порождая множество срабатываний вместо одного. Соответственно, микроконтроллер «поймает» все эти нажатия, потому что дребезг не отличим от настоящего нажатия на кнопку.


image


Для подавления "дребезга" я использовал подтягивающий резистор емкостью 20 кОм, встроенный в Arduino. Он осуществляет подтягивание к логической единице. Так как у тумблера оба положения — ON, подтягивание к логической единице — то, что нужно. Используется он таким образом:


pinMode(pin_number, INPUT); // Подключаем пин на вход
pinMode(pin_number, INPUT_PULLUP); // Подтягивание входа к питанию

Заключение


Итак, у меня получилось два устройства, одно из них принимает сигналы по bluetooth и активирует розетки, а также разблокирует Windows на присоединенном компьютере, а другое — эти сигналы отправляет после успешной валидации по RFID-метке. Однако, как я уже говорил, было странным делать и запись, и чтение в одном устройстве, без какой-либо защиты. Я сделал так лишь потому, что хотел пойти дальше считывания ID RFID-карты и сравнения его с захардкоженым значением, а попробовать поработать с ее памятью, для чего она собственно предназначена. Таким образом, теперь я знаю как записать любую информацию на RFID-карту, как ее считать, как сделать карту Read Only и т.п. Получилась система для домашнего использования. Так и получается, я использую свой девайс дома, умная розетка подключена к компьютеру, в нее подсоединены колонки и зарядное для телефона. Деблокиратор стоит на входе комнаты. Не скажу, что это девайс, без которого я не могу жить, но идеи реального практического применения у него есть. Одна из них вполне осуществима и будет реализована.


Планируется сделать систему контроля доступа к рабочему месту студента в аудитории с компьютерами. Забегая вперед, скажу, что в качестве студенческого билета в нашем университете используется RFID-карта MIFARE 1K. Предположим, что у нас есть небольшая аудитория на 6 компьютеров, другими словами на 6 рабочих мест.


Сперва мы "клонируем" умную розетку — делаем еще 5 таких устройств, чтобы помимо использования компьютера, студент мог подключить свой ноутбук/паяльник/телефон к розетке. Тут нам и пригодится динамическое соединение Master-устройства bluetooth со Slave-устройством, о котором я говорил, рассказывая про bluetooth-модуль. Больше каким-либо образом модифицировать умную розетку не придется. Единственное, придется поискать решение, чтобы нельзя было перепрограммировать микроконтроллер Arduino, присоединенный к компьютеру через USB-кабель.


Теперь стоит сказать об изменениях в деблокираторе. Его мы лишаем функции записи, оставляя возможность только считывать RFID-карты. Если бы мы использовали самодельные RFID-карты, то понадобилось еще сделать устройство для записи RFID-карт. Так как планируется использовать уже готовые студенческие билеты с готовой записанной информацией, данное устройство в рамках будущего проекта не требуется, но в случае использования своих, "кастомных" карт его создание было бы очень простым с учетом проделанной работы над этим проектом. Также, деблокиратор необходимо будет оснастить Ethernet- или WiFi-модулем, для возможности осуществлять запросы на management-сервер. Какой и зачем, спросите вы? Чтобы сделать систему более гибкой и удобной, перед тем как придти поработать в аудиторию, студенту необходимо "забронировать" себе место с помощью данного веб-сайта. Деблокиратор при проверке RFID-карты студента будет обращаться на данный сервер для проверки бронирования (и еще чего-нибудь, если хочется). Остается подумать, как реализовать перепроверку присутствия студента (ушел и не приложил карту) и удобный способ информирования об окончании "рабочего" времени.


Код прошивки


https://bitbucket.org/sashadereh/arduino-smart-socket/src

Поделиться с друзьями
-->

Комментарии (51)


  1. GennPen
    27.06.2016 13:38
    -1

    Для подавления дребезга контактов кнопки лучше подключать через RC цепочку.


    1. vasimv
      27.06.2016 14:30
      +3

      Программно дребезг легко фильтруется, смысла нет ставить конденсатор.


  1. Imbecile
    27.06.2016 14:57

    Насколько я знаю, digitalWrite(relay_pin, HIGH) так работает везде.
    И да, мне кажется хорошей практикой запитывать реле отдельно, а не подавать питание с Ардуинки. Оттуда только сигнал на коммутацию.


    1. kanakhin
      27.06.2016 17:54

      И да, мне кажется хорошей практикой запитывать реле отдельно, а не подавать питание с Ардуинки. Оттуда только сигнал на коммутацию.

      тогда реле не будет срабатывать. земля реле и ардуины должна быть общей.


      1. tw1911
        27.06.2016 23:42
        +1

        Земля да, а вот VCC лучше брать напрямую с БП, потому что релюшки кушают довольно большой ток, у меня от 2 реле проседало напряжение на USB 2.0. Там есть отдельные входы IN и отдельные VCC.


      1. Imbecile
        27.06.2016 23:48

        Нет, не должна. Убираете пин с реле и запитываете полностью отдельно. Вот картинка: http://howtomechatronics.com/wp-content/uploads/2015/09/Arduino-Relay-Module-Circuit-Diagram.png отсюда: http://howtomechatronics.com/tutorials/arduino/control-high-voltage-devices-arduino-relay-tutorial/ По ссылке подробно расписаны варианты. Собственно, я своей малинкой именно в таком виде управляю релешками.


  1. NickUkolov
    27.06.2016 15:10

    На схема подключения синий провод 220V от вилки не дошел до реле? (Или я как то не так читаю схему)


    1. sashadereh
      27.06.2016 15:11

      Все верно, Вы правы. Видимо, в первоначальном варианте провод куда-то убежал :) Обновил схему в статье и в репозитории. Спасибо.


  1. alexpp
    27.06.2016 15:41

    Не боитесь, что рано или поздно использованное реле залипнет? На ГТ неоднократно уже писали, что данный модуль мягко говоря ненадежен и лучше использовать твердотельные реле.


  1. Winnie_The_Pooh
    27.06.2016 16:00

    Почему Вы решили использовать алюминиевые провода для высоковольтной части?


    1. serafims
      27.06.2016 17:55

      думаю, выбиралось из того, что было — реле все равно сдохнет раньше, чем пойдут проблемы из-за алюминиевого провода…


      1. Winnie_The_Pooh
        28.06.2016 08:45
        +1

        «Нет ничего более постоянного, чем временное!» (С)


    1. sashadereh
      27.06.2016 19:00

      Никаких причин для выбора именно алюминиевых проводов не было. Купил то, что было и подходило по силе тока. Сделал так, чтобы алюминиевые и медные провода друг друга не касались.


      1. Winnie_The_Pooh
        28.06.2016 08:49

        Понятно. Поясню свое удивление — в электронике и силовой электронике принято избегать алюминия, только медь. Поэтому было интересно выяснить — были ли какие-то причины использовать нестандартный материал проводов.


  1. vconst
    27.06.2016 16:17

    Сорри, что не совсем по теме
    Подскажите, где почитать о том, как сделать на Ардуино управление светодиодными лентами через энкодер с высокочастотным ШИМ? Гугль много что выдает, но без опыта не отделить зерна от плевел… А покупать тупо диммер с пультом – совсем не по гиковски. Понимаю, что задача простейшая, но не хочется учиться на своих обшибках


    1. IronHead
      27.06.2016 16:30
      +1

      1) Гуглим по фразе «ШИМ на Ардуино» — вникаем в написание прошивки с ШИМ
      2) Гуглим по фразе «Светодиодная лента и ардуино» — вникаем в схемотехнику силовой части
      3) Гуглим по фразе «Энкодер к ардуино» — вникаем как обрабатывать поворот энкодера
      4) Напрягаем мозг и собираем все это в кучу
      5) PROFIT!


      1. vconst
        27.06.2016 16:32

        Естественно я все это гуглил, как уже сказал, но опять же – не хочется учиться на своих ошибках. Может для высокочастотного ШИМ лучше купить отдельный ШИМ-модуль для управления двигателями и светодиодами, может получится обойтись программными методами


        1. aleyer
          27.06.2016 23:43
          +1

          Буквально недавно делал управление двумя лентами с одной ардуины. Чтобы получить ШИМ с частотой около 31кГц на пинах 9 и 10 всего-то надо в setup() добавить
          TCCR1B = (TCCR1B & 0b11111000) | 0x01;
          После этого использовать обычный analogWrite().
          Далее, через резисторы в 100 Ом я эти пины подключил к плате, которую сделал для управления двумя каналами. Плата — драйвер IR4427S, два транзистора + обвязка.
          Схема вот:

          Выглядит так:

          Питается ардуина и плата от 12В, которые нужны светодиодной ленте. Драйвер нужен, чтобы транзисторы адекватно работали на такой частоте. Сами платы не буду выкладывать, т.к. они специфичного форм-фактора (стыкуются с другой однослойной платой), при этом я перепутал верх и низ, и стыкуется она вверх ногами. На функционал не влияет, просто некрасиво. Транзисторы вот пришлось загибать.


          1. vconst
            27.06.2016 23:45

            Схемы пропали, дайте просто ссылки на изображения в виде текста без тегов


            1. aleyer
              27.06.2016 23:50
              +1

              Таки да. Хотя в превью все было на месте.
              https://habrastorage.org/files/722/8ab/724/7228ab7249e84d96a3ef1cde4b188fea.jpg
              https://habrastorage.org/files/1d8/495/af2/1d8495af213546a5b0c53d6b8e28f754.jpg


              1. vconst
                27.06.2016 23:52

                Спасибо, очень интересно!


                1. tw1911
                  29.06.2016 21:48

                  Вы знаете, чем писать то что Вам надо на Arduino, сделайте лучше на Attiny. Понимание процесса у Вас будет в 100 раз лучше, объем кода в 10 раз меньше, цена устройства так же упадет. Я вот по этим статьям учился, ну и даташит конечно. На много интереснее Arduino, полный контроль, настоящий geekway.


                  1. vconst
                    29.06.2016 21:53

                    Я умею водить машину, но категорически не хочу уметь ее чинить. Я умею паять, немного программирую, но не хочу заниматься этим на уровне отдельных битов. Как то так…


    1. Kitaer
      28.06.2016 14:31
      +1

      Про основы управления светодиодом/светодиодной лентой можно узнать здесь. Там рассказано про схему мигающего светодиода, но на ее основе можно подключить и светодиодную ленту.


      1. vconst
        28.06.2016 14:41

        Кармы у вас не хватало для оформления ссылок, повторите ее плиз


        1. Kitaer
          28.06.2016 15:23

          http://ledjournal.info/shemy/migayushhij-svetodiod-arduino.html

          но это основа-основ)


        1. Kitaer
          28.06.2016 15:30

          вот, криво ссылку кинул…


          1. vconst
            28.06.2016 15:33

            Ну да, самые азы :) Спасибо, буду гуглить дальше


  1. dueler
    27.06.2016 16:48

    Вы же можете переснять видео снова и заменить, верно?


  1. Hellsy22
    27.06.2016 19:30
    +1

    А почему Ардуино, а не ESP? И если уж Ардуино, то почему Leonardo, а не Mini Pro?


    1. sashadereh
      27.06.2016 23:47

      Mini pro вроде как не умеет работать в виде USB HID устройства. А вообще, взл Leonardo, потому что только она была в наличии при покупке (ну и Uno).


      1. osmanpasha
        28.06.2016 11:18

        Кстати, на Uno (ATMega328) и даже на ATTiny можно поставить софтверный USB (http://www.obdev.at/products/vusb/index.html). Если иметь желание и свободное время, конечно)


        1. holomen
          30.06.2016 00:56

          Можно. Но не нужно.


  1. k0ldbl00d
    27.06.2016 21:37

    А еще можно было бы снабдить датчиками тока, например на эффекте Холла. Получилось бы куда интереснее.


  1. Iona
    27.06.2016 22:54

    То, что реле у вас по умочанию замкнуто, потенциально опасно. В случае пропадания напряжения в сети, даже довольно кратковременного, реле замкнётся, и в розетках будет напряжение, пока ардуина не загрузится.


    1. aleyer
      28.06.2016 01:20

      На самом деле нет. Чуть выше выкладывали ссылку на статью, где есть схема платы с реле. http://howtomechatronics.com/wp-content/uploads/2015/09/Relay-Module-Circuit-Schematics02.png
      Тут видно, что реле включается, когда начинает течь ток через светодиод оптопары. Для этого на управляющей ноге ардуины должен быть 0 уровень. По умолчанию же контакты реле разомкнуты — и когда отключена ардуина, и когда отсутствует питание платы реле, и когда ардуина перезагружается (по умолчанию пины настроены как вход без подтяжки).


      1. Imbecile
        28.06.2016 09:33
        +1

        И опять не совсем верно. Если вы обратите внимание на фото, у каждого реле на плате (К1 и К2) по три винта контактов высокого напряжения. Почему именно три? Потому что реле позволяет смонтировать как нормально-замкнутую схему, так и нормально-разомкнутую схему. В первом случае нормально состяние цепи — замкнутое, а подаче сигнала с Ардуинки будет её размыкать. Во втором случае, цепь по умолчанию разомкнута, а подача сигнала будет её замыкать.


  1. andrewsh
    28.06.2016 11:13
    +1

    Я просто оставлю это здесь: https://www.itead.cc/sonoff-wifi-wireless-switch.html


  1. st1373
    28.06.2016 11:18

    «а также разблокирует Windows на присоединенном компьютере» — на схеме отсутствует присоединенный компьютер. Тупо пихать пароль в неизвестно куда :) оно ведь и в редакторе текстовом может выплыть неожиданно.


    1. sashadereh
      28.06.2016 11:20

      Ну, вообще мне лично не нравится то, как я это сделал. Это лишь первый пробный вариант. Я подумаю над тем, как выпилить пароль из исходников и сделать разблокирование более-менее секьюрным :)


  1. osmanpasha
    28.06.2016 11:30

    А можете пояснить, как INPUT_PULLUP спасает от дребезга контактов выключателя? Кажется, что подтягивающий резистор должен спасать от того, что контакт выключателя, не замкнутый на центральную землю, будет свободно болтаться и при чтении может выдать какое угодно значение.


    1. Winnie_The_Pooh
      28.06.2016 11:39

      INPUT_PULLUP от дребезга контактов конечно не спасает. Но включение подтягивающего резистора позволяет иметь на высокоомном (весьма!) входе четко дифференцированный по уровню сигнал — или 0 или +5в (VCC точнее). А это позволяет схеме антидребезга правильно работать. Без подтягивающего резистора сигнал на входе будет медленно (единицы секунд) нарастать и не факт, что к VCC. Равновесный потенциал будет зависеть от соотношения утечек.


      1. osmanpasha
        28.06.2016 13:35

        Схема антибребезга — это RC-цепь? А то сабж, кажется, такой схемы не имеет)


        1. Winnie_The_Pooh
          28.06.2016 13:59

          Дребезг можно давить как на аппаратном уровне (RC цепь или RS триггер), так и программном. Делая что-то на достаточно мощном процессоре (достаточно — применимо к обсуждаемым задачам конечно) разумно использовать готовую и отлаженную подпрограмму подавления дребезга контактов. Их есть в инете :) Я код автора не смотрел, но полагаю он что-то такое и использовал.


          1. Winnie_The_Pooh
            28.06.2016 14:24

            посмотрел код автора.

            он вовсе не давит дребезг :))))))

            У него программа выполняется либо по одной ветке, либо по другой, определяется это оператором if, который смотрит на сигнал с ноги с подключенным тумблером.

            Видимо основное тело программы выполняется дольше дребезга контактов и поэтому его программа нечувствительна к дребезгу контактов. На первый взгляд время выполнения основного цикла программы составляет от 300 до 600 мС, что заведомо больше времени дребезга.

            Автор путает два понятия: дребезг контактов и неопределенный потенциал на висящем в воздухе высокоомном входе.


  1. Winnie_The_Pooh
    28.06.2016 14:16
    +2

    кстати автору — достаточно одного оператора в коде pinmode (pinnum, INPUT_PULLUP) — он включит ножку в режим входа и включит подтягивающий резистор. Предыдущий оператор не нужен.


    1. sashadereh
      28.06.2016 14:25

      Точно, спасибо!


      1. Winnie_The_Pooh
        28.06.2016 14:29

        На здоровье!

        Обратите также внимание на мой комментарий на пару записей выше касательно дребезга. Я там обратил внимание, что в вашей программе нет подавления дребезга.


        1. sashadereh
          28.06.2016 14:50

          Да, уже посмотрел, спасибо. «Покурю» эту тему детальнее, когда будет время.


    1. ssneg
      28.06.2016 22:29

      Это появилось начиная с какой-то там версии, но устаревший код переползает из туториала в туториал…


  1. Delics
    28.06.2016 22:48

    > pinMode(pin_number, INPUT); // Подключаем пин на вход
    > pinMode(pin_number, INPUT_PULLUP); // Подтягивание входа к питанию

    Есть мнение, что достаточно написать только последнюю команду.

    И от дребезга это не спасет. Лучше всё-таки через конденсатор.