Русифицированная версия программы для измерения температуры и отн. влажности и вывода информации на сенсорный TFT
Dependencies: FT800_2 HYT mbed
Компоненты
- Датчик температуры и относительной влажности HYT-271 / HYT-221 / HYT-939 от компании IST-AG
- TFT-модуль серии uxTouch от компании Riverdi
- Плата-переходник Break Out Board 20 от компании Riverdi
- Любая отладочная плата с поддержкой mbed, интерфейсами I2C и SPI interface двумя свободными линиями для сигналов PD и INT
Подключение
Отладочная плата к TFT-модулю
Отладочная плата подключается к модулю через переходник Break Out Board 20. На плате-переходнике используется 6 сигналов: SCK, MOSI, MISO, SS (интерфейс SPI), PD (powerdown) и INT (interrupt).
Питание должно быть подано не только на VDD, но и на BLVDD - подсветку экрана. Соответствующие выводы можно просто соединить между собой:
Отладочная плата к датчику серии HYT
К датчику отладочная плата подключается по I2C. Не забываем про подтяжку к питанию:

Демонстрация работы
Процесс создания приложения подробно описан тут: https://habrahabr.ru/users/uuuulala/topics/
TFT/display.Draw_3hrsStatistics.cpp
- Committer:
- Ksenia
- Date:
- 2016-10-12
- Revision:
- 1:8ca8a4ecbe6b
- Parent:
- 0:9db07391e780
File content as of revision 1:8ca8a4ecbe6b:
#include "display.h"
/**************************************************************************************************************************
************************** Display data about humidity in the three-hour interval *****************************************
**************************************************************************************************************************/
void Display::StatHumidity_3hrs(volatile uint64_t seconds, short int statistics24hrs[3][288], uint64_t gridSecondsOffset)
{
// start FT800 display list
StartDL();
// mark 6 areas for touch input (for zoom in),
// make each every second zone gray, make the active zone green
char ZonesCnt = 0;
for (int i = 25; i < 433; i += 68) {
(*_TFT).DL(COLOR_RGB(255, 255, 255));
if (ZonesCnt % 2 == 0) {
(*_TFT).DL(COLOR_RGB(233, 233, 233));
}
if (pressedButton - ZONE_1_PRESS == ZonesCnt) {
(*_TFT).DL(COLOR_RGB(200, 255, 200));
timePoint30min = 6 * ZonesCnt;
}
(*_TFT).DL(TAG_MASK(1));
(*_TFT).DL(TAG(ZONE_1_PRESS + ZonesCnt));
(*_TFT).DL(BEGIN(RECTS));
(*_TFT).DL(VERTEX2II(i, 100, 0, 0));
(*_TFT).DL(VERTEX2II(i + 68, 200, 0, 0));
(*_TFT).DL(TAG_MASK(0));
ZonesCnt++;
}
// create time string, GridLines, link to main menu
TimeSinceTurnOn(seconds);
VerticalGrid3hrs(gridSecondsOffset);
HorisontalGrid_Statistics_Humidity();
MainMenuReference();
// draw graph line
for (int i = 0; i < 36; i++) {
char currentValue = statistics24hrs[0][i + timePoint3hrs];
char currentMinValue = statistics24hrs[1][i + timePoint3hrs];
char currentMaxValue = statistics24hrs[2][i + timePoint3hrs];
if (currentValue != INIT_STATISTICS_NUMBER) {
(*_TFT).DL(COLOR_RGB(9, 0, 63));
if (currentMaxValue - currentMinValue >= DELTA_HUMIDITY) {
(*_TFT).DL(COLOR_RGB(207, 45, 13));
(*_TFT).DL(BEGIN(LINES));
(*_TFT).DL(LINE_WIDTH(16));
(*_TFT).DL(VERTEX2F(i * 181 + 25 * 16, (200 - currentValue) * 16));
(*_TFT).DL(VERTEX2F(i * 181 + 25 * 16, (200 - currentMaxValue) * 16));
(*_TFT).DL(VERTEX2F(i * 181 + 22 * 16, (200 - currentMaxValue) * 16));
(*_TFT).DL(VERTEX2F(i * 181 + 28 * 16, (200 - currentMaxValue) * 16));
(*_TFT).DL(END());
(*_TFT).DL(BEGIN(LINES));
(*_TFT).DL(LINE_WIDTH(16));
(*_TFT).DL(VERTEX2F(i * 181 + 25 * 16, (200 - currentValue) * 16));
(*_TFT).DL(VERTEX2F(i * 181 + 25 * 16, (200 - currentMinValue) * 16));
(*_TFT).DL(VERTEX2F(i * 181 + 22 * 16, (200 - currentMinValue) * 16));
(*_TFT).DL(VERTEX2F(i * 181 + 28 * 16, (200 - currentMinValue) * 16));
(*_TFT).DL(END());
}
(*_TFT).DL(BEGIN(POINTS));
(*_TFT).DL(POINT_SIZE(45));
(*_TFT).DL(VERTEX2F(i * 181 + 25 * 16, (200 - currentValue) * 16));
}
}
// write main title
(*_TFT).DL(COLOR_RGB(0, 0, 0));
CreateStringRussian("Отн. влажность за 3 часа");
(*_TFT).Text(15, 15, 3, 0, russianStr);
// finish FT800 display list
FinishDL();
}
/**************************************************************************************************************************
************************** Display data about temeprature in the three-hour interval **************************************
**************************************************************************************************************************/
void Display::StatTemperature_3hrs(volatile uint64_t seconds, short int statistics24hrs[3][288], uint64_t gridSecondsOffset)
{
// start FT800 display list
StartDL();
// mark 6 areas for touch input (for zoom in),
// make each every second zone gray, make the active zone green
char ZonesCnt = 0;
for (int i = 25; i < 433; i += 68) {
(*_TFT).DL(COLOR_RGB(255, 255, 255));
if (ZonesCnt % 2 == 0) {
(*_TFT).DL(COLOR_RGB(233, 233, 233));
}
if (pressedButton - ZONE_1_PRESS == ZonesCnt) {
(*_TFT).DL(COLOR_RGB(200, 255, 200));
timePoint30min = 6 * ZonesCnt;
}
(*_TFT).DL(TAG_MASK(1));
(*_TFT).DL(TAG(ZONE_1_PRESS + ZonesCnt));
(*_TFT).DL(BEGIN(RECTS));
(*_TFT).DL(VERTEX2II(i, 100, 0, 0));
(*_TFT).DL(VERTEX2II(i + 68, 200, 0, 0));
(*_TFT).DL(TAG_MASK(0));
ZonesCnt++;
}
// create time string, GridLines, link to main menu
TimeSinceTurnOn(seconds);
VerticalGrid3hrs(gridSecondsOffset);
HorisontalGrid_Statistics_Temperature();
MainMenuReference();
// draw graph line
for (int i = 0; i < 36; i++) {
char currentValue = (statistics24hrs[0][i + timePoint3hrs] / TEMPERATURE_MULTIPLIER + 50) * 0.57;
char currentMinValue = (statistics24hrs[1][i + timePoint3hrs] / TEMPERATURE_MULTIPLIER + 50) * 0.57;
char currentMaxValue = (statistics24hrs[2][i + timePoint3hrs] / TEMPERATURE_MULTIPLIER + 50) * 0.57;
char delta = statistics24hrs[2][i + timePoint3hrs] - statistics24hrs[1][i + timePoint3hrs];
if (statistics24hrs[0][i + timePoint3hrs] != INIT_STATISTICS_NUMBER) {
(*_TFT).DL(COLOR_RGB(9, 0, 63));
if (delta >= DELTA_TEMPERATURE + TEMPERATURE_MULTIPLIER) {
(*_TFT).DL(COLOR_RGB(207, 45, 13));
(*_TFT).DL(BEGIN(LINES));
(*_TFT).DL(LINE_WIDTH(16));
(*_TFT).DL(VERTEX2F(i * 181 + 25 * 16, (200 - currentValue) * 16));
(*_TFT).DL(VERTEX2F(i * 181 + 25 * 16, (200 - currentMaxValue) * 16));
(*_TFT).DL(VERTEX2F(i * 181 + 22 * 16, (200 - currentMaxValue) * 16));
(*_TFT).DL(VERTEX2F(i * 181 + 28 * 16, (200 - currentMaxValue) * 16));
(*_TFT).DL(END());
(*_TFT).DL(BEGIN(LINES));
(*_TFT).DL(LINE_WIDTH(16));
(*_TFT).DL(VERTEX2F(i * 181 + 25 * 16, (200 - currentValue) * 16));
(*_TFT).DL(VERTEX2F(i * 181 + 25 * 16, (200 - currentMinValue) * 16));
(*_TFT).DL(VERTEX2F(i * 181 + 22 * 16, (200 - currentMinValue) * 16));
(*_TFT).DL(VERTEX2F(i * 181 + 28 * 16, (200 - currentMinValue) * 16));
(*_TFT).DL(END());
}
(*_TFT).DL(BEGIN(POINTS));
(*_TFT).DL(POINT_SIZE(45));
(*_TFT).DL(VERTEX2F(i * 181 + 25 * 16, (200 - currentValue) * 16));
}
}
// write main title
(*_TFT).DL(COLOR_RGB(0, 0, 0));
CreateStringRussian("Температура за 3 часа");
(*_TFT).Text(15, 15, 3, 0, russianStr);
// finish FT800 display list
FinishDL();
}