ESP8266 и Visuino: веб-сервер температуры и влажности DHT11: 12 шагов
ESP8266 и Visuino: веб-сервер температуры и влажности DHT11: 12 шагов
Anonim
Image
Image

Модули ESP8266 - отличные недорогие автономные контроллеры со встроенным Wi-Fi, и я уже написал о них несколько инструкций.

DTH11 / DTH21 / DTH22 и AM2301 - очень популярные комбинированные датчики температуры и влажности Arduino, и я также сделал с ними ряд инструкций, в том числе дистанционный термометр и датчик влажности с двумя ESP8266, подключенными вместе в их собственной частной сети Wi-Fi.

В этом руководстве я покажу вам, как создать веб-сервер температуры и влажности с ESP8266 и DHT11 и подключиться к нему в существующей сети Wi-Fi с нескольких устройств с помощью веб-браузера.

Шаг 1: Компоненты

Подключите DHT11 к модулю NodeMCU ESP8266
Подключите DHT11 к модулю NodeMCU ESP8266
  1. Плата OneNodeMCU ESP8266 (я использовал версию NodeMCU 0.9, но подойдет любая другая или даже автономная ESP-12 или ESP-01)
  2. Один модуль датчика DHT11, который я получил из этого дешевого набора из 37 датчиков
  3. 3 перемычки мама-женщина

Шаг 2. Подключите DHT11 к модулю NodeMCU ESP8266

Подключите DHT11 к модулю NodeMCU ESP8266
Подключите DHT11 к модулю NodeMCU ESP8266
Подключите DHT11 к модулю NodeMCU ESP8266
Подключите DHT11 к модулю NodeMCU ESP8266
Подключите DHT11 к модулю NodeMCU ESP8266
Подключите DHT11 к модулю NodeMCU ESP8266
  1. Подключите питание (красный провод), заземление (черный провод) и данные (серый провод) к модулю DHT11 (на рисунке 1 показаны 2 различных типа сенсорных модулей DHT11. Как вы можете видеть, контакты могут отличаться, поэтому подключайтесь осторожно!)
  2. Подключите другой конец провода заземления (черный провод) к контакту заземления модуля ESP8266 (Рисунок 2).
  3. Подключите другой конец провода питания (красный провод) к контакту питания 3,3 В модуля ESP8266 (Рисунок 2).
  4. Подключите другой конец провода данных (серый провод) к цифровому контакту 2 модуля ESP8266 (Рисунок 3).
  5. На рисунке 4 показано, где находятся контакты заземления, питания 3,3 В и цифровых 2 узла NodeMCU 0.9.

Шаг 3. Запустите Visuino и выберите тип платы ESP8266

Запустите Visuino и выберите тип платы ESP8266
Запустите Visuino и выберите тип платы ESP8266
Запустите Visuino и выберите тип платы ESP8266
Запустите Visuino и выберите тип платы ESP8266

Чтобы начать программировать Arduino, вам потребуется установить Arduino IDE отсюда:

Имейте в виду, что в Arduino IDE 1.6.6 есть несколько критических ошибок

Убедитесь, что вы установили 1.6.7 или выше, иначе это руководство не будет работать!

Если вы еще не сделали этого, следуйте инструкциям в этом Руководстве, чтобы настроить IDE Arduino для программирования ESP 8266

Visuino: https://www.visuino.com также должен быть установлен.

  1. Запустите Visuino, как показано на первой картинке.
  2. Нажмите кнопку «Инструменты» на компоненте Arduino (рисунок 1) в Visuino.
  3. Когда появится диалоговое окно, выберите «NodeMCU ESP-12», как показано на рисунке 2.

Шаг 4. В Visuino: установите имя хоста и точку доступа

В Visuino: установите имя хоста и точку доступа
В Visuino: установите имя хоста и точку доступа
В Visuino: установите имя хоста и точку доступа
В Visuino: установите имя хоста и точку доступа
В Visuino: установите имя хоста и точку доступа
В Visuino: установите имя хоста и точку доступа
В Visuino: установите имя хоста и точку доступа
В Visuino: установите имя хоста и точку доступа

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

  1. В инспекторе объектов разверните свойство «Модули», затем вспомогательное свойство «WiFi».
  2. В Инспекторе объектов установите значение свойства HostName на «dht11server» (Рисунок 1).
  3. В Инспекторе объектов разверните подсвойство «AccessPoints» для «WiFi» и нажмите кнопку «…» рядом с его значением (рисунок 2).
  4. В редакторе «AccessPoins» выберите «WiFi Access Point» в правом окне, а затем нажмите кнопку «+» слева, чтобы добавить точку доступа (Рисунок 2).
  5. В Инспекторе объектов установите значение свойства «SSID» равным SSID вашей точки доступа Wi-Fi (точки доступа) (рисунок 4).
  6. Если для вашей точки доступа Wi-Fi (точки доступа) требуется пароль, в инспекторе объектов установите пароль в значении свойства «Пароль» (рисунок 4).
  7. Закройте диалоговое окно «AccessPoints».

Шаг 5: В Visuino: добавьте сокет сервера TCP / IP для связи

В Visuino: добавление сокета сервера TCP / IP для связи
В Visuino: добавление сокета сервера TCP / IP для связи
В Visuino: добавление сокета сервера TCP / IP для связи
В Visuino: добавление сокета сервера TCP / IP для связи
В Visuino: добавление сокета сервера TCP / IP для связи
В Visuino: добавление сокета сервера TCP / IP для связи

Затем нам нужно добавить сокет TCP / IP Server для связи.

  1. В инспекторе объектов нажмите кнопку «…» рядом со значением вложенного свойства «Сокеты» Wi-Fi (рисунок 1).
  2. В редакторе сокетов выберите «TCP / IP Server», а затем нажмите кнопку «+» (рисунок 2), чтобы добавить его (рисунок 3).
  3. Закройте диалоговое окно «Сокеты».

Шаг 6: В Visuino: добавьте DTH11 и компонент форматированного текста с 2 аналоговыми каналами

В Visuino: добавьте DTH11 и компонент форматированного текста с 2 аналоговыми каналами
В Visuino: добавьте DTH11 и компонент форматированного текста с 2 аналоговыми каналами
В Visuino: добавьте DTH11 и компонент форматированного текста с 2 аналоговыми каналами
В Visuino: добавьте DTH11 и компонент форматированного текста с 2 аналоговыми каналами
В Visuino: добавьте DTH11 и компонент форматированного текста с 2 аналоговыми каналами
В Visuino: добавьте DTH11 и компонент форматированного текста с 2 аналоговыми каналами

Чтобы контролировать и считывать температуру и влажность с DHT11, нам нужно добавить для него компонент в Visuino.

Нам также необходимо сгенерировать веб-страницу из данных. Страница представляет собой просто текстовый документ HTML, поэтому мы можем использовать компонент форматированного текста для его создания.

  1. Введите «dht» в поле «Фильтр» на панели инструментов компонентов, затем выберите компонент «Влажность и термометр DHT11 / 21/22 / AM2301» (рисунок 1) и поместите его в область дизайна.
  2. Введите «форма» в поле «Фильтр» на панели инструментов компонента, затем выберите компонент «Форматированный текст» (рисунок 2) и поместите его в область дизайна.
  3. Нажмите кнопку «Инструменты» компонента FormattedText1 (Рисунок 3).
  4. В редакторе элементов выберите Аналоговый элемент справа и нажмите 2 раза кнопку «+» слева (Рисунок 4), чтобы добавить 2 из них (Рисунок 5).
  5. Закройте редактор «Элементы».

Шаг 7. В Visuino: установите форматированный текст для ответа сервера

В Visuino: установите форматированный текст для ответа сервера
В Visuino: установите форматированный текст для ответа сервера
В Visuino: установите форматированный текст для ответа сервера
В Visuino: установите форматированный текст для ответа сервера

Нам нужно указать текст HTML, который будет сгенерирован при подключении веб-клиента к серверу.

Мы укажем соединение, которое нужно закрыть после отправки данных, а также проинструктируем браузер повторно подключиться (Обновить) через 5 секунд, добавив в документ «Обновить: 5». Таким образом, веб-страница будет обновляться каждые 5 секунд.

  1. В области дизайна выберите компонент FormattedText1 (рисунок 1).
  2. В инспекторе объектов выберите свойство «Текст» и нажмите кнопку «…» рядом с его значением (рисунок 1).
  3. В редакторе «Текст» введите: «HTTP / 1.1 200 OK» «Content-Type: text / html» «Соединение: закрыть» «Обновить: 5» «« »"""""" Температура:% 0 "" Влажность:% 1 "" "" "(Рисунок 2)% 0 будет заменен значением из AnalogElement1, а% 1 будет заменен значением из AnalogElement2
  4. Нажмите кнопку ОК, чтобы закрыть диалоговое окно.

Шаг 8: В Visuino: подключите компонент DHT11

В Visuino: подключите компонент DHT11
В Visuino: подключите компонент DHT11
В Visuino: подключите компонент DHT11
В Visuino: подключите компонент DHT11
В Visuino: подключите компонент DHT11
В Visuino: подключите компонент DHT11
  1. Подключите выходной контакт «Температура» компонента HumidityThermometer1 к контакту «In» AnalogElement1 компонента FormattedText1 (Рисунок 1).
  2. Подключите выходной контакт "Humidity" компонента HumidityThermometer1 к контакту "In" AnalogElement2 компонента FormattedText1 (Рисунок 2).
  3. Подключите контакт "Sensor" компонента HumidityThermometer1 к входному контакту "Digital" канала "Digital [2]" компонента Arduino (Рисунок 3).

Шаг 9. В Visuino: добавьте и подключите компонент Edge Detect

В Visuino: добавление и подключение компонента обнаружения границ
В Visuino: добавление и подключение компонента обнаружения границ
В Visuino: добавление и подключение компонента обнаружения границ
В Visuino: добавление и подключение компонента обнаружения границ
В Visuino: добавление и подключение компонента обнаружения границ
В Visuino: добавление и подключение компонента обнаружения границ
В Visuino: добавление и подключение компонента обнаружения границ
В Visuino: добавление и подключение компонента обнаружения границ

Нам нужно отправлять HTML-текст каждый раз, когда возникает новое соединение. Перед отправкой нам нужно немного подождать, поскольку веб-браузеры должны отправить запрос, прежде чем они ожидают увидеть результат. Для этого мы будем использовать компонент Delay, подключенный к контакту «Connected» разъема сервера TCP / IP.

  1. Введите «задержка» в поле «Фильтр» на панели инструментов компонентов, затем выберите компонент «Задержка» (рисунок 1) и перетащите его в область дизайна.
  2. В Свойствах установите значение свойства «Интервал (uS)» равным 200000 (Рисунок 2).
  3. Подключите контакт «Connected» модуля «Modules. WiFi. Sockets. TCPServer1» компонента «NodeMCU ESP-12» к контакту «In» компонента Delay1 (Рисунок 3).
  4. Подключите контакт "Out" компонента Delay1 к входному контакту "Clock" компонента FormattedText1 (рисунок 4).

Шаг 10: В Visuino: подключите компонент форматированного текста, а также добавьте и подключите компонент задержки

В Visuino: подключите компонент форматированного текста, а также добавьте и подключите компонент задержки
В Visuino: подключите компонент форматированного текста, а также добавьте и подключите компонент задержки
В Visuino: подключите компонент форматированного текста, а также добавьте и подключите компонент задержки
В Visuino: подключите компонент форматированного текста, а также добавьте и подключите компонент задержки
В Visuino: подключите компонент форматированного текста, а также добавьте и подключите компонент задержки
В Visuino: подключите компонент форматированного текста, а также добавьте и подключите компонент задержки
В Visuino: подключите компонент форматированного текста, а также добавьте и подключите компонент задержки
В Visuino: подключите компонент форматированного текста, а также добавьте и подключите компонент задержки
  1. Подключите вывод «Out» компонента FormattedText1 к контакту «In» «Modules. WiFi. Sockets. TCPServer1» компонента «NodeMCU ESP-12» (Рисунок 1).
  2. Введите «задержка» в поле «Фильтр» на панели инструментов компонентов, затем выберите компонент «Задержка» (рисунок 2) и поместите его в область дизайна.
  3. Подключите контакт «Out» компонента FormattedText1 к контакту «In» компонента Delay2 (рисунок 3).
  4. Подключите вывод «Out» компонента Delay2 к входному контакту «Disconnect» модуля «Modules. WiFi. Sockets. TCPServer1» компонента «NodeMCU ESP-12» (Рисунок 4).

Компонент Delay отключит сокет вскоре после отправки текста.

Шаг 11: сгенерируйте, скомпилируйте и загрузите код Arduino

Сгенерируйте, скомпилируйте и загрузите код Arduino
Сгенерируйте, скомпилируйте и загрузите код Arduino
Сгенерируйте, скомпилируйте и загрузите код Arduino
Сгенерируйте, скомпилируйте и загрузите код Arduino
  1. В Visuino нажмите F9 или нажмите кнопку, показанную на рисунке 1, чтобы сгенерировать код Arduino, и откройте IDE Arduino.
  2. Подключите модуль NodeMCU с помощью USB-кабеля к компьютеру.
  3. Выберите тип платы и последовательный порт, как я показал вам в этой инструкции.
  4. В среде Arduino IDE нажмите кнопку «Загрузить», чтобы скомпилировать и загрузить код (рисунок 2).

Шаг 12: И играем…

Image
Image
И играй…
И играй…

Поздравляю! Вы создали веб-сервер температуры и влажности Wi-Fi.

На рисунке 1 и в видео вы можете увидеть подключенный и включенный проект. Я использовал небольшой USB Power Bank для питания модуля.

Убедитесь, что в проекте на шаге 4 вы ввели правильный SSID и пароль для точки доступа Wi-Fi

Если вы откроете веб-браузер на своем компьютере или мобильном устройстве и наберете:

dht11server./

И нажмите Enter, вы увидите измеренные модулем температуру и влажность. Показания будут обновляться каждые 5 секунд, как указано в шаге 7.

Обязательно добавьте точку в конце имени, иначе Windows не сможет разрешить имя домена

На рисунке 2 вы можете увидеть полную схему Visuino.

Также прилагается проект Visuino, который я создал для этого руководства. Вы можете скачать и открыть его в Visuino: