Метеостанция DIY с дисплеем Nextion и Arduino: 11 шагов
Метеостанция DIY с дисплеем Nextion и Arduino: 11 шагов
Anonim
Image
Image
Что тебе понадобится
Что тебе понадобится

В этом руководстве мы будем использовать дисплей Nextion, модуль времени rtc1307, Arduino UNO и Visuino для отображения текущего времени, температуры и влажности.

Посмотрите демонстрационное видео.

Шаг 1. Что вам понадобится

Что тебе понадобится
Что тебе понадобится
Что тебе понадобится
Что тебе понадобится
  • Arduino uno (или nano, мега-любой может использоваться)
  • Nextion lcd 2.8 дюймов nx3224t028_011 (любой другой nextion lcd также подойдет)
  • I2C RTC DS1307 24C32 Модуль часов реального времени для Arduino
  • Провода перемычки
  • Макетная плата
  • Программа Visuino: Скачать Visuino
  • Программа Nextion Editor: Скачать здесь

Шаг 2: Разработка интерфейса в редакторе Nextion

Разработка интерфейса в редакторе Nextion
Разработка интерфейса в редакторе Nextion
Разработка интерфейса в редакторе Nextion
Разработка интерфейса в редакторе Nextion
Разработка интерфейса в редакторе Nextion
Разработка интерфейса в редакторе Nextion

Сначала убедитесь, что SD-карта отформатирована в FAT32 (используйте какое-нибудь программное обеспечение, например, форматировщик карт).

  • Запустите программу Nextion Editor, нажмите «Создать» и сохраните свой проект во что-то вроде «Погода».
  • Затем появится диалоговое окно «Настройки», выберите тип дисплея, который у вас есть.
  • Будет создан чистый белый лист.
  • Из Панели инструментов слева перетащите 3-кратное изображение.
  • В левом нижнем углу выберите вкладку «Изображение», нажмите кнопку «+» и загрузите изображения. Вы можете загрузить из Интернета несколько красивых иконок для времени, температуры и влажности (например, на веб-сайте Iconarchive).
  • Выберите каждый элемент изображения и в правом нижнем углу окна «Атрибут» дважды щелкните поле «pic» и выберите изображение, сделайте это для каждого элемента изображения (3x).

В меню выберите «Инструменты> Генератор шрифтов».

  • Создайте шрифт, который будет использоваться для отображения времени, температуры и влажности, и задайте имя, например MyFont1.
  • Нажмите «Создать шрифт» и сохраните его где-нибудь, когда спросят «Добавить сгенерированный шрифт?» нажмите Да.
  • Закройте диалоговое окно, и сгенерированный шрифт появится в нижней части слева на вкладке «Шрифты» с идентификатором 0.
  • Из панели инструментов слева перетащите 3 раза «текст», поместите его туда, где будут отображаться данные.
  • Для каждого текстового элемента, установленного в правом нижнем окне «Атрибуты», шрифт равен 0 <ID шрифта, который вы сгенерировали ранее, вы можете использовать несколько шрифтов и установить идентификатор для каждого текстового элемента.
  • Вы можете установить текстовое значение по умолчанию в поле «txt», например «Время», «C», «%».
  • Вы можете установить цвет, щелкнув поле «pco». Обратите внимание, что каждый текстовый элемент имеет определенное имя объекта, например «t0» и т. Д., Это позже будет использоваться в Visuino.
  • Вы можете найти каждое имя объекта в окне "Атрибуты"> имя объекта.

Когда вы разместили и разместили все элементы:

  • нажмите кнопку "Скомпилировать"
  • нажмите на меню «Файл»> «Открыть папку сборки», найдите файл в нашем случае «Weather.tft» и скопируйте его на SD-карту.

Шаг 3: Схема

Схема
Схема
  • Подключите вывод Arduino [5 В] к положительному выводу макетной платы [красный]
  • Подключите вывод Arduino [GND] к отрицательному выводу макетной платы [синий]
  • Подключите контакт датчика DHT11 [-] к контакту Arduino [GND].
  • Подключите контакт датчика DHT11 [-] к положительному контакту макетной платы [красный]
  • Подключите сигнальный контакт датчика DHT11 [S] к цифровому контакту Arduino [7].
  • Подключите вывод модуля Time DS1307 [Vcc] к положительному выводу макетной платы [красный]
  • Подключите вывод модуля Time DS1307 [GND] к отрицательному выводу макетной платы [синий]
  • Подключите вывод модуля Time DS1307 [SDA] к выводу Arduino [SDA].
  • Подключите вывод модуля Time DS1307 [SCL] к выводу Arduino [SCL].
  • Подключите контакт дисплея Nextion [VCC] к положительному контакту макетной платы [красный]
  • Подключите контакт дисплея Nextion [GND] к отрицательному контакту макетной платы [синий]
  • Подключите вывод Nextion Display [RX] к выводу Arduino [TX]
  • Подключите вывод Nextion Display [TX] к выводу Arduino [RX].

Шаг 4. Запустите Visuino и выберите тип платы Arduino UNO

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

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

Имейте в виду, что в Arduino IDE 1.6.6 есть несколько критических ошибок. Убедитесь, что вы установили 1.6.7 или выше, иначе это руководство не будет работать! Если вы еще не сделали, следуйте инструкциям в этом Руководстве, чтобы настроить Arduino IDE для программирования Arduino UNO! Также необходимо установить Visuino: https://www.visuino.eu. Запустите Visuino, как показано на первом рисунке. Нажмите кнопку «Инструменты» на компоненте Arduino (рисунок 1) в Visuino. Когда появится диалоговое окно, выберите «Arduino UNO», как показано на рисунке 2.

Шаг 5: Добавьте компоненты в Visuino

В Visuino Добавить компоненты
В Visuino Добавить компоненты
В Visuino Добавить компоненты
В Visuino Добавить компоненты
В Visuino Добавить компоненты
В Visuino Добавить компоненты
  1. Добавить компонент "Старт"
  2. Добавить компонент "Часы реального времени (RTC) DS 1307"
  3. Добавить компонент "Генератор часов"
  4. Добавить компонент "Влажность и термометр DHT11"
  5. Добавьте 2x компонента "Аналог к тексту"
  6. Добавить компонент "Декодировать (разделить) дату и время"
  7. Добавить компонент "Nextion Display"

Шаг 6: Компоненты набора Visuino

Компоненты набора Visuino
Компоненты набора Visuino
Компоненты набора Visuino
Компоненты набора Visuino
Компоненты набора Visuino
Компоненты набора Visuino

Дважды щелкните компонент «RealTimeClock1», откроется окно элементов и:

  • Перетащите «Установить день» и в окне свойств установите «Значение» на текущую дату.
  • Перетащите «Установить год» и в окне свойств установите «Значение» на текущий год.
  • Перетащите «Установить месяц» и в окне свойств установите «Значение» на текущий месяц.
  • Перетащите «Установить час» и в окне свойств установите «Значение» на текущий час.
  • Перетащите «Установить минуту» и в окне свойств установите «Значение» на текущие минуты.

Выберите компонент «FormattedText1» и в окне свойств установите для «текст» значение:% 0:% 1:% 2

Дважды щелкните компонент «FormattedText1», откроется окно элементов и:

Перетащите 3 раза «Текстовый элемент» влево.

Дважды щелкните компонент «DisplayNextion1», откроется окно элементов и:

Перетащите 3x элемента «Текст» влево и для каждого набора элементов:

  • для первого элемента назовите его: Время
  • для второго элемента назовите его: Температура
  • для третьего элемента назовите его: Влажность
  • Для каждого элемента установлен «Индекс страницы»: 0
  • для первого набора элементов "Имя элемента": t0 (это имя, которое отображается в редакторе Nextion над каждым элементом, в моем случае это t0)
  • для второго элемента установите "Имя элемента": t1 (это имя, которое отображается в редакторе Nextion над каждым элементом, в моем случае это t1)
  • для второго элемента установите «Имя элемента»: t2 (это имя, которое отображается в редакторе Nextion над каждым элементом, в моем случае это t2)

Шаг 7. В компонентах Visuino Connect

В компонентах Visuino Connect
В компонентах Visuino Connect
  • Подключите вывод «Start1» «Out» к «RealTimeClock1»> «Set Day1», вывод «Clock»
  • Подключите вывод «Start1» «Out» к «RealTimeClock1»> «Set Hour1», вывод «Clock»
  • Подключите вывод «Start1» «Out» к «RealTimeClock1»> «Установить год1», вывод «Clock»
  • Подключите вывод «Start1» «Out» к «RealTimeClock1»> «Установить месяц1», вывод «Clock»
  • Подключите вывод «Start1» «Out» к «RealTimeClock1»> «Set Minute1», вывод «Clock»
  • Подключите вывод компонента «RealTimeClock1» [Out] к выводу «DecodeDateTime1» [In]
  • Подключите вывод компонента «RealTimeClock1» [Control] к выводу I2C платы Arduino [In]
  • Подключите вывод компонента «ClockGenerator1» [Out] к выводу компонента «HumidityThermometer1» [Clock]
  • Подключите компонент «DecodeDateTime1» к контакту [Hour] с контактом «FormattedText1»> «Textelement1» [In]
  • Подключите компонент «DecodeDateTime1» к контакту [Hour] с контактом «FormattedText1»> «Textelement2» [In]
  • Подключите компонент «DecodeDateTime1» к контакту [Hour] с контактом «FormattedText1»> «Textelement3» [In]
  • Подключите компонентный контакт «HumidityThermometer1» [Температура] к компонентному контакту «AnalogToText1» [In]
  • Подключите вывод компонента «HumidityThermometer1» [Humidity] к компонентному выводу «AnalogToText2» [In]
  • Подключите вывод компонента «HumidityThermometer1» [Sensor] к цифровому выводу [7] платы Arduino.
  • Подключите вывод компонента «FormattedText1» [Out] к выводу компонента «DisplayNextion1». Время [In]
  • Подключите вывод компонента «AnalogToText1» [Out] к выводу компонента «DisplayNextion1». Температура [In]
  • Подключите вывод компонента «AnalogToText2» [Out] к выводу компонента «DisplayNextion1». Влажность [In]

Подключите вывод DisplayNextion1 [Out] к выводу Serial [0] платы Arduino [In]

Шаг 8: скопируйте файл Nextion на SD-карту

Убедитесь, что у вас есть файл Nextion на SD-карте

  • Выключите дисплей Nextion
  • Вставьте SD-карту в Nextion Display
  • Включите Nextion Display, и вы должны увидеть прогресс обновления дисплея Nextion.
  • Выключите дисплей Nextion
  • Извлеките SD-карту из дисплея Nextion

Теперь дисплей Nextion готов.

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

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

В Visuino нажмите F9 или нажмите кнопку, показанную на рисунке 1, чтобы сгенерировать код Arduino, и откройте IDE Arduino. В среде Arduino IDE нажмите кнопку «Загрузить», чтобы скомпилировать и загрузить код (рисунок 2). Примечание.

Убедитесь, что при загрузке кода в Arduino отключите вывод Arduino [RX] и вывод Arduino [TX]. После завершения загрузки снова подключите вывод Arduino [RX] и вывод Arduino [TX]

Шаг 10: Играйте

Если вы включите модуль Arduino UNO, дисплей начнет показывать текущую температуру и уровень влажности + время, которое вы установили в Visuino. Поздравляю! Вы завершили свой проект метеостанции с Visuino.

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

а также

Файл Nextion для редактора Nextion (Weather. HMI) и скомпилированный файл Nextion (Weather.tft), которые вы можете скопировать прямо на свой дисплей Nextion.

Шаг 11: Ресурсы

Вы также можете проверить это замечательное руководство, чтобы узнать, как работать с дисплеями Nextion.