Показаны различия между двумя версиями страницы.
Предыдущая версия справа и слеваПредыдущая версияСледующая версия | Предыдущая версия | ||
products:laboratory_iot:exp70 [2020/06/15 17:00] – [Эксперимент 70. Графический интерфейс метеостанции] labuser29 | products:laboratory_iot:exp70 [2024/12/17 18:15] (текущий) – [Программный код эксперимента] labuser30 | ||
---|---|---|---|
Строка 17: | Строка 17: | ||
{{ : | {{ : | ||
- | // | + | // |
+ | {{ : | ||
+ | // | ||
==== Программный код эксперимента ==== | ==== Программный код эксперимента ==== | ||
Строка 40: | Строка 42: | ||
spi = SPI(1, baudrate=40000000, | spi = SPI(1, baudrate=40000000, | ||
tft = TFT_GREEN(128, | tft = TFT_GREEN(128, | ||
- | tft.initr() | + | tft.initr(tft.BGR) # tft.initr(tft.RGB) #Если вместо синего цвета отображается красный, |
Строка 88: | Строка 90: | ||
tft.text(1, | tft.text(1, | ||
- | tft.draw_bmp(34, | + | tft.draw_bmp(34, |
- | tft.draw_bmp(5, | + | tft.draw_bmp(5, |
tft.text(30, | tft.text(30, | ||
Строка 98: | Строка 100: | ||
</ | </ | ||
+ | В этой программе мы сосредоточились на создании GUI — графического интерфейса пользователя, | ||
+ | |||
+ | Первым делом извлекаем из структуры нужные нам данные. А именно: | ||
+ | |||
+ | Название города записываем в переменную wCity | ||
+ | <code python[enable_line_numbers=" | ||
+ | wCity = data[' | ||
+ | </ | ||
+ | |||
+ | Текущую температуру записываем в переменную wTemp | ||
+ | <code python[enable_line_numbers=" | ||
+ | wTemp = round(data[' | ||
+ | </ | ||
+ | |||
+ | Ощущение температуры записываем в переменную wTempFeels. (например из-за ветра или влажности температура может ощущаться человеком как более низкая, | ||
+ | <code python[enable_line_numbers=" | ||
+ | wTempFeels = data[' | ||
+ | </ | ||
+ | |||
+ | Влажность в % записываем в переменную wHumidity | ||
+ | <code python[enable_line_numbers=" | ||
+ | wHumidity = data[' | ||
+ | </ | ||
+ | |||
+ | Скорость ветра в метрах в секунду записываем в переменную wWind | ||
+ | <code python[enable_line_numbers=" | ||
+ | wWind = data[' | ||
+ | </ | ||
+ | |||
+ | Текущее время суток записываем в переменную pod. Если сейчас день, то в ней будет значение d, а если ночь — n. Эти данные нам понадобятся для выбора правильной иконки погоды. Например, | ||
+ | <code python[enable_line_numbers=" | ||
+ | pod = data[' | ||
+ | </ | ||
+ | |||
+ | Сервис weatherbit.io среди прочих данных о погоде сообщает код текущей погоды. Это коды, которые используются именно этим сервисом. По ним можно понять какую иконку погоды нужно отобразить. [[https:// | ||
+ | <code python[enable_line_numbers=" | ||
+ | wCode = int(data[' | ||
+ | </ | ||
+ | |||
+ | Сервис поддерживает очень большое количество иконок у нас столько нет. У нас всего 18 погодных иконок — 9 дневных и 9 ночных. Поэтому нам нужно настроить соответствие кодов из сервиса нашим иконкам. Например несколько видов дождя, которые обозначаются разными кодами, | ||
+ | <code python[enable_line_numbers=" | ||
+ | if wCode <= 233: | ||
+ | wPic = ' | ||
+ | elif (wCode >= 300 and wCode <= 520) or wCode == 522: | ||
+ | wPic = ' | ||
+ | elif wCode in (521, 600): | ||
+ | wPic = ' | ||
+ | elif wCode >= 601 and wCode <= 622: | ||
+ | wPic = ' | ||
+ | elif wCode >= 623 and wCode <= 751: | ||
+ | wPic = ' | ||
+ | elif wCode == 800: | ||
+ | wPic = ' | ||
+ | elif wCode in (801, 802): | ||
+ | wPic = ' | ||
+ | elif wCode == 803: | ||
+ | wPic = ' | ||
+ | elif wCode == 804: | ||
+ | wPic = ' | ||
+ | </ | ||
+ | |||
+ | Для отображения иконки термометра на дисплее нужно определить положительная сейчас температура или отрицательная. Если температура ниже нуля, то будем отображать " | ||
+ | |||
+ | <code python[enable_line_numbers=" | ||
+ | if (wTemp > 0): | ||
+ | wTempPic = ' | ||
+ | else: | ||
+ | wTempPic = ' | ||
+ | </ | ||
+ | |||
+ | Определяем цвета для шрифтов. Один из них будет использоваться для отображения названия города и температуры, | ||
+ | <code python[enable_line_numbers=" | ||
+ | FontColor = tft.rgbcolor(33, | ||
+ | FontColor2 = tft.rgbcolor(8, | ||
+ | </ | ||
+ | |||
+ | Закрашиваем весь дисплей белым | ||
+ | <code python[enable_line_numbers=" | ||
+ | tft.clear(tft.rgbcolor(255, | ||
+ | </ | ||
+ | |||
+ | |||
+ | Выводим на дисплей название города | ||
+ | <code python[enable_line_numbers=" | ||
+ | tft.text(1, | ||
+ | </ | ||
+ | |||
+ | Рисуем иконки: | ||
+ | <code python[enable_line_numbers=" | ||
+ | tft.draw_bmp(34, | ||
+ | tft.draw_bmp(5, | ||
+ | </ | ||
+ | |||
+ | Выводим текущую температуру | ||
+ | <code python[enable_line_numbers=" | ||
+ | tft.text(30, | ||
+ | </ | ||
+ | |||
+ | Выводим дополнительные данные: | ||
+ | <code python[enable_line_numbers=" | ||
+ | tft.text(5, | ||
+ | tft.text(5, | ||
+ | tft.text(5, | ||
+ | </ |