Можно собрать шлюз с WIFI, запущенный на модуле ESP8266. Портировал код Yveaux и задокументировал здесь.
Самым простым вариантом, является использование NodeMcu Devkit v.10 (от NodeMcu). Схемы и разводку можно найти здесь. На этой плате установлен модуль ESP-12. Просто подключите радио, установите программное обеспечение для шлюза, и у вас всё готово.
Установка программного обеспечения
Стандартный эскиз шлюза ESP8266 можно использовать без изменений (кроме SSID и пароля).
Настройка
- Установите Arduino IDE 1.6.5+
- Загрузитк библиотеку ESP8266 в Arduino, см. Установка с помощью Boards Manager
- Установите последнюю библиотеку MySensors в Менеджере библиотек
- Установите драйверы CP2102 отсюда.
- Подключите NodeMCU плату.
Компиляция и загрузка скетча шлюза
- Откройте Wi-Fi-шлюз в IDE Arduino (Файл -> Примеры-> Библиотеки -> MySensors -> Esp8266Gateway
- Сохраните его, чтобы можно было редактировать
- Отредактируйте SSID и WiFi-пароль в переменные ‘ssid’ и ‘pass’
- Выберите плату ESP8266, в меню Инструменты -> Панель. Используйте модуль ESP12, который является «платой NodeMCU 1.0 (ESP 12E module)».
- Проверьте эскиз. Он должен компилироваться без ошибок.
- Теперь загрузите эскиз. Плата NodeMCU обычно прошивается автоматически и не требует нажатие на кнопку bootload/reset. Если вы видите ошибку, попробуйте изменить скорость передачи с 9600 до 57600. Ели и дальше проблемы? Удерживайте flash и нажмите «Сброс». После чего начните загрузку в среде IDE, удерживая нажатой кнопку Flash, до тех пор, пока не начнется загрузка.
- Откройте монитор порта и посмотрите, как плата подключается к вашей сети Wi-Fi.
- Обратите внимание на назначенный ему IP-адрес. При желании, включите статический ip на вашем DHCP-сервере, если вы предпочитаете иметь тот же IP при следующем запуске.
- Любое приложение, поддерживающее связь с обычным шлюзом MySensors Ethernet, должно связываться с шлюзом ESP
-
Наслаждайтесь!
Конфигурация
Дополнительные сведения о «кнопке включения» и светодиодах см. В дополнительных параметрах сборки.
Пример ESP8266Gateway
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 |
/* * The MySensors Arduino library handles the wireless radio link and protocol * between your home built sensors/actuators and HA controller of choice. * The sensors forms a self healing radio network with optional repeaters. Each * repeater and gateway builds a routing tables in EEPROM which keeps track of the * network topology allowing messages to be routed to nodes. * * Created by Henrik Ekblad <henrik.ekblad@mysensors.org> * Copyright (C) 2013-2019 Sensnology AB * Full contributor list: https://github.com/mysensors/MySensors/graphs/contributors * * Documentation: http://www.mysensors.org * Support Forum: http://forum.mysensors.org * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * version 2 as published by the Free Software Foundation. * ******************************* * * REVISION HISTORY * Version 1.0 - Henrik Ekblad * Contribution by a-lurker and Anticimex, * Contribution by Norbert Truchsess <norbert.truchsess@t-online.de> * Contribution by Ivo Pullens (ESP8266 support) * * DESCRIPTION * The EthernetGateway sends data received from sensors to the WiFi link. * The gateway also accepts input on ethernet interface, which is then sent out to the radio network. * * VERA CONFIGURATION: * Enter "ip-number:port" in the ip-field of the Arduino GW device. This will temporarily override any serial configuration for the Vera plugin. * E.g. If you want to use the default values in this sketch enter: 192.168.178.66:5003 * * LED purposes: * - To use the feature, uncomment any of the MY_DEFAULT_xx_LED_PINs in your sketch, only the LEDs that is defined is used. * - RX (green) - blink fast on radio message received. In inclusion mode will blink fast only on presentation received * - TX (yellow) - blink fast on radio message transmitted. In inclusion mode will blink slowly * - ERR (red) - fast blink on error during transmission error or receive crc error * * See https://www.mysensors.org/build/connect_radio for wiring instructions. * * If you are using a "barebone" ESP8266, see * https://www.mysensors.org/build/esp8266_gateway#wiring-for-barebone-esp8266 * * Inclusion mode button: * - Connect GPIO5 (=D1) via switch to GND ('inclusion switch') * * Hardware SHA204 signing is currently not supported! * * Make sure to fill in your ssid and WiFi password below for ssid & pass. */ // Enable debug prints to serial monitor #define MY_DEBUG // Use a bit lower baudrate for serial prints on ESP8266 than default in MyConfig.h #define MY_BAUD_RATE 9600 // Enables and select radio type (if attached) #define MY_RADIO_RF24 //#define MY_RADIO_RFM69 //#define MY_RADIO_RFM95 #define MY_GATEWAY_ESP8266 #define MY_WIFI_SSID "MySSID" #define MY_WIFI_PASSWORD "MyVerySecretPassword" // Enable UDP communication //#define MY_USE_UDP // If using UDP you need to set MY_CONTROLLER_IP_ADDRESS or MY_CONTROLLER_URL_ADDRESS below // Set the hostname for the WiFi Client. This is the hostname // it will pass to the DHCP server if not static. #define MY_HOSTNAME "ESP8266_GW" // Enable MY_IP_ADDRESS here if you want a static ip address (no DHCP) //#define MY_IP_ADDRESS 192,168,178,87 // If using static ip you can define Gateway and Subnet address as well //#define MY_IP_GATEWAY_ADDRESS 192,168,178,1 //#define MY_IP_SUBNET_ADDRESS 255,255,255,0 // The port to keep open on node server mode #define MY_PORT 5003 // How many clients should be able to connect to this gateway (default 1) #define MY_GATEWAY_MAX_CLIENTS 2 // Controller ip address. Enables client mode (default is "server" mode). // Also enable this if MY_USE_UDP is used and you want sensor data sent somewhere. //#define MY_CONTROLLER_IP_ADDRESS 192, 168, 178, 68 //#define MY_CONTROLLER_URL_ADDRESS "my.controller.org" // Enable inclusion mode //#define MY_INCLUSION_MODE_FEATURE // Enable Inclusion mode button on gateway //#define MY_INCLUSION_BUTTON_FEATURE // Set inclusion mode duration (in seconds) //#define MY_INCLUSION_MODE_DURATION 60 // Digital pin used for inclusion mode button //#define MY_INCLUSION_MODE_BUTTON_PIN D1 // Set blinking period //#define MY_DEFAULT_LED_BLINK_PERIOD 300 // Flash leds on rx/tx/err // Led pins used if blinking feature is enabled above //#define MY_DEFAULT_ERR_LED_PIN 16 // Error led pin //#define MY_DEFAULT_RX_LED_PIN 16 // Receive led pin //#define MY_DEFAULT_TX_LED_PIN 16 // the PCB, on board LED #include <MySensors.h> void setup() { // Setup locally attached sensors } void presentation() { // Present locally attached sensors here } void loop() { // Send locally attached sensors data here } |