CH340 NodeMcu V3 Lua WI-FI ESP8266 подключить и настроить

1 сообщение / 0 новое
CH340 NodeMcu V3 Lua WI-FI ESP8266 подключить и настроить

Купить NodeMcu v3

Основные характеристики NodeMcu v3 (ESP-12E)

  • поддержка WiFi протоколов 802.11 b/g/n
  • Wi-Fi Direct (P2P), soft-AP
  • встроенный стек TCP/IP
  • встроенный TR переключатель, balun, LNA, усилитель мощности и соответствие сети
  • встроенный PLL, регуляторы, и система управления питанием
  • выходная мощность +20.5 дБм в режиме 802.11b
  • поддержка диверсити антенн
  • SDIO 2.0, SPI, UART
  • STBC, 1×1 MIMO, 2×1 MIMO
  • A-MPDU & A-MSDU aggregation & 0.4μs guard interval
  • пробуждение и отправка пакетов за время до 22 мс
  • Номинальное напряжение: 3,3 В
  • Входное напряжение: 3,7–20 В
  • Максимальный потребляемый ток: 220 мА

 

Контакты Wi-Fi модуля NodeMcu v3

NodeMcu v3

Модуль имеет 11 портов ввода-вывода общего назначения.

  • Некоторые из портов имеют дополнительные функции:
  • D9, D10 — UART
  • D1, D2 — I²C/TWI
  • D5–D8 — SPI
  • D1–D10 — выходы с ШИМ (PWM)
  • A0 — аналоговый вход с АЦП

Подключение модуля NodeMcu v3 к ПК и настройка Arduino IDE для работы с модулем

Для начала откроем среду программирования Arduino IDE и перейдем в настройки

NodeMcu v3

Потом в появившемся окне в строке Additional Boards Manager URLs (отмечено красным) вставим ссылку  http://arduino.esp8266.com/stable/package_esp8266com_index.json для установки в Arduino IDE дополнительных скриптов, что бы работать с модулями ESP8266, и жмем ОК

NodeMcu v3

Потом переходим в Tools > Board > Boards Manager

NodeMcu v3

В появившемся окне прокручиваем список вниз к скриптам esp8266 by ESP8266 Community и кликаем.

NodeMcu v3

В правом нижнем углу появится возможность выбора версии ПО, выбираем версию 2.1.0 (самая новая) и жмем кнопку Install

NodeMcuv3

После установки закрываем окно и переходим Tools > Board и видим список доступных для программирования устройств на чипе ESP8266

NodeMcu v3

Выбираем NodeMCU 1.0 (ESP-12E Module), теперь подключаем наше устройство к ПК, устанавливаем для него драйвера Драйвер CH340G и в настройках Arduino IDE выбираем правильный COM порт, остальные настройки оставляем по-умолчанию

NodeMcu v3

void setup() {
  pinMode(13, OUTPUT);
}
void loop() {
  digitalWrite(13, HIGH);
  delay(1000);
  digitalWrite(13, LOW);
  delay(1000);
}

После заливки скетча, снова смотрим распиновку NodeMcu v3 и определяем что нужный выход GPIO13 , это нога D7

NodeMcu v3

Теперь подключаем светодиод к нашей NodeMcu по схеме

NodeMcu v3

NodeMcuv3

Я специально не устанавливал Резистор, но для ограничения тока рекомендовано использовать на 82 Ом, если все правильно сделано, наш светодиод будет мигать с интервалом в 1 сек.

Для расчета светодиодов рекомендую пользоватся онлайн-калькулятором по ссылке

Ну а теперь сами подключите светодиод к D5 пину на NodeMcu, исправьте и перезалейте скетч… Это подключение нам понадобится для создания простого web сервера.

WebServer на NodeMcu

Для удаленного управления нагрузками по Wi-Fi , нам потребуется скетч из примеров WiFi WebServer

NodeMcuv3 WiFi WebServer

Открываем наш скетч

/*
 *  This sketch demonstrates how to set up a simple HTTP-like server.
 *  The server will set a GPIO pin depending on the request
 *    http://server_ip/gpio/0 will set the GPIO2 low,
 *    http://server_ip/gpio/1 will set the GPIO2 high
 *  server_ip is the IP address of the ESP8266 module, will be 
 *  printed to Serial when the module is connected.
 */
 
#include <ESP8266WiFi.h>
 
const char* ssid = "your-ssid";
const char* password = "your-password";
 
// Create an instance of the server
// specify the port to listen on as an argument
WiFiServer server(80);
 
void setup() {
  Serial.begin(115200);
  delay(10);
 
  // prepare GPIO2
  pinMode(2, OUTPUT);
  digitalWrite(2, 0);
  
  // Connect to WiFi network
  Serial.println();
  Serial.println();
  Serial.print("Connecting to ");
  Serial.println(ssid);
  
  WiFi.begin(ssid, password);
  
  while (WiFi.status() != WL_CONNECTED) {
    delay(500);
    Serial.print(".");
  }
  Serial.println("");
  Serial.println("WiFi connected");
  
  // Start the server
  server.begin();
  Serial.println("Server started");
 
  // Print the IP address
  Serial.println(WiFi.localIP());
}
 
void loop() {
  // Check if a client has connected
  WiFiClient client = server.available();
  if (!client) {
    return;
  }
  
  // Wait until the client sends some data
  Serial.println("new client");
  while(!client.available()){
    delay(1);
  }
  
  // Read the first line of the request
  String req = client.readStringUntil('\r');
  Serial.println(req);
  client.flush();
  
  // Match the request
  int val;
  if (req.indexOf("/gpio/0") != -1)
    val = 0;
  else if (req.indexOf("/gpio/1") != -1)
    val = 1;
  else {
    Serial.println("invalid request");
    client.stop();
    return;
  }
 
  // Set GPIO2 according to the request
  digitalWrite(2, val);
  
  client.flush();
 
  // Prepare the response
  String s = "HTTP/1.1 200 OK\r\nContent-Type: text/html\r\n\r\n<!DOCTYPE HTML>\r\n<html>\r\nGPIO is now ";
  s += (val)?"high":"low";
  s += "</html>\n";
 
  // Send the response to the client
  client.print(s);
  delay(1);
  Serial.println("Client disonnected");
 
  // The client will actually be disconnected 
  // when the function returns and 'client' object is detroyed
}

И видим, что вверху закомментирована важная информация, а именно что нагрузка по умолчанию в скетче подключается к GPIO2

/*
* This sketch demonstrates how to set up a simple HTTP-like server.
* The server will set a GPIO pin depending on the request
* http://server_ip/gpio/0 will set the GPIO2 low,
* http://server_ip/gpio/1 will set the GPIO2 high
* server_ip is the IP address of the ESP8266 module, will be 
* printed to Serial when the module is connected.
*/

Но мы помним, что в NodeMcu, выход GPIO2 это нога D4 и при заливке стандартного скетча нам потребуется нагрузку повесить на D4 … Но в предыдущем скетче мы подключили нагрузку к ноге D5

Изменяем в скетче соответствующие строки

// prepare GPIO2
  pinMode(2, OUTPUT);
  digitalWrite(2, 0);

на строки 

// prepare GPIO14
  pinMode(14, OUTPUT);
  digitalWrite(14, 0);

и еще

// Set GPIO2 according to the request
  digitalWrite(2, val);

на строку

// Set GPIO14 according to the request
  digitalWrite(14, val);

а потом пропишем в строках имя нашей Wi-Fi сети ( your-ssid )  и пароль доступа к ней ( your-password ) в строках

const char* ssid = "your-ssid";
const char* password = "your-password";

и перезальем скетч в NodeMcu и после удачной загрузки откроем монитор порта в Arduino IDE

NodeMcuv3 WiFi WebServer настроить

Запустится установка соединения с нашей сетью Wi-Fi , а потом и сам сервер с отображением IP-адреса, на котором он работает…  Запомним IP-адрес и для включения светодиода сформируем строку http://server_ip/gpio/1 где server_ip — это Ваш IP-адрес из монитора порта. Для отключения светодиода формируем строку http://server_ip/gpio/0 , у меня получилось как на фото

NodeMcuv3 WiFi WebServer настройка

NodeMcuv3 WiFi WebServer настройка

Если все сделано правильно — отобразится надпись с состоянием диода на страничке с запросом и в мониторе порта

NodeMcuv3 WiFi WebServer настроить

Все заработало, но для удобства включения/отключения светодиода мы еще создадим приложение в MIT App Inventor 2 , для телефона на Android.

Создание приложения WebON в MIT App Inventor 2

Для начала перейдем по ссылке MIT App Inventor 2 и после регистрации создадим новый проект, в котором в панели Pallete слева нам понадобится два элемента Button и Web

NodeMcuv3 WiFi WebServer настроить

Выравниваем кнопку по центру и изменяем надпись на LED, потом переходим в режим программирования Blocks и составляем из блоков

NodeMcuv3 WiFi WebServer настроить

событие для нажатия при обычном нажатии, и событие при длительном нажатии на кнопку  — ну а если своими словами, то при обычном (кратковременном) нажатии на кнопку мы отправим запрос на наш сервер http://192.168.31.179/gpio/1 и включится светодиод, а при длительном нажатии на кнопку (нажать и удерживать) отправится второй запрос http://192.168.31.179/gpio/0 который отключит светодиод. С дизайном приложения я не заморачивался, главное что ясна суть создания и работы приложения.  Чуть ниже на видео, отображен весь процесс

 

Оставить комментарий

Plain text

  • HTML-теги не обрабатываются и показываются как обычный текст
  • Строки и параграфы переносятся автоматически.
9 + 1 =
Решите эту простую математическую задачу и введите результат. Например, для 1+3, введите 4.