HYT humidity & temp sensor polling / showing received data at TFT with capacitive touchscreen

Dependencies:   FT800_2 HYT mbed

HYT humidity & temperature sensor: polling and showing data at TFT via graphical controller FT800/FT801.

Hardware

For documentation on the FT800 library, please refer to the library pages.

Connection

MCU-board to TFT-module

MCU-board is connected to TFT-module via Break Out Board. You need 6 signals to connect: SCK, MOSI and MISO are connected to a SPI channel, SS is the chip select signal, PD work as powerdown and INT for interrupts from TFT to MCU.

/media/uploads/Ksenia/4_-22-.jpg

You have to connect VDD to BLVDD at Break Out Board if you use the board:

/media/uploads/Ksenia/4_-5-.jpg

MCU-board to HYT sensor

MCU-board is connected to sensor via I2C. Remember to use pull-up resisrors there:

/media/uploads/Ksenia/freshpaint-20-2016.09.16-10.37.03.png

Подробнее в статьях Как перестать бояться и полюбить mbed [Часть 1 - 5] на https://habrahabr.ru/users/uuuulala/topics/

Committer:
Ksenia
Date:
Fri Oct 07 11:08:19 2016 +0000
Revision:
0:5d3131d1b142
Initial commit;

Who changed what in which revision?

UserRevisionLine numberNew contents of line
Ksenia 0:5d3131d1b142 1 #include "display.h"
Ksenia 0:5d3131d1b142 2
Ksenia 0:5d3131d1b142 3 /* For drawing current values */
Ksenia 0:5d3131d1b142 4
Ksenia 0:5d3131d1b142 5 /**************************************************************************************************************************
Ksenia 0:5d3131d1b142 6 ************************** Draw horisontal grid for current temperature (-50 .. +125) *************************************
Ksenia 0:5d3131d1b142 7 **************************************************************************************************************************/
Ksenia 0:5d3131d1b142 8 void Display::HorisontalGrid_Current_Temperature()
Ksenia 0:5d3131d1b142 9 {
Ksenia 0:5d3131d1b142 10 (*_TFT).DL(COLOR_RGB(20, 20, 20));
Ksenia 0:5d3131d1b142 11 char gridNumb = 125 + 50;
Ksenia 0:5d3131d1b142 12 for (int i = 70 * 16; i <= 225 * 16; i += 352) {
Ksenia 0:5d3131d1b142 13 (*_TFT).DL(BEGIN(LINES));
Ksenia 0:5d3131d1b142 14 (*_TFT).DL(LINE_WIDTH(8));
Ksenia 0:5d3131d1b142 15 (*_TFT).DL(VERTEX2F(15 * 16, i));
Ksenia 0:5d3131d1b142 16 (*_TFT).DL(VERTEX2F(423 * 16, i));
Ksenia 0:5d3131d1b142 17 if (gridNumb >= 50) {
Ksenia 0:5d3131d1b142 18 (*_TFT).Number(435, i/16 - 9, 26, 0, gridNumb - 50);
Ksenia 0:5d3131d1b142 19 } else if (gridNumb == 25) {
Ksenia 0:5d3131d1b142 20 (*_TFT).Text(435, i/16 - 9, 26, 0, "-25");
Ksenia 0:5d3131d1b142 21 } else if (gridNumb == 0) {
Ksenia 0:5d3131d1b142 22 (*_TFT).Text(435, i/16 - 9, 26, 0, "-50");
Ksenia 0:5d3131d1b142 23 }
Ksenia 0:5d3131d1b142 24 gridNumb = gridNumb - 25;
Ksenia 0:5d3131d1b142 25 }
Ksenia 0:5d3131d1b142 26 }
Ksenia 0:5d3131d1b142 27
Ksenia 0:5d3131d1b142 28 /**************************************************************************************************************************
Ksenia 0:5d3131d1b142 29 ************************** Draw horisontal grid for current humidity (0 .. 100) *******************************************
Ksenia 0:5d3131d1b142 30 **************************************************************************************************************************/
Ksenia 0:5d3131d1b142 31 void Display::HorisontalGrid_Current_Humidity()
Ksenia 0:5d3131d1b142 32 {
Ksenia 0:5d3131d1b142 33 (*_TFT).DL(COLOR_RGB(20, 20, 20));
Ksenia 0:5d3131d1b142 34 char gridNumb = 100;
Ksenia 0:5d3131d1b142 35 for (int i = 70 * 16; i <= 220 * 16; i += 600) {
Ksenia 0:5d3131d1b142 36 (*_TFT).DL(BEGIN(LINES));
Ksenia 0:5d3131d1b142 37 (*_TFT).DL(LINE_WIDTH(8));
Ksenia 0:5d3131d1b142 38 (*_TFT).DL(VERTEX2F(15 * 16, i));
Ksenia 0:5d3131d1b142 39 (*_TFT).DL(VERTEX2F(423 * 16, i));
Ksenia 0:5d3131d1b142 40 (*_TFT).Number(435, i/16 - 9, 26, 0, gridNumb);
Ksenia 0:5d3131d1b142 41 gridNumb = gridNumb - 25;
Ksenia 0:5d3131d1b142 42 }
Ksenia 0:5d3131d1b142 43 }
Ksenia 0:5d3131d1b142 44
Ksenia 0:5d3131d1b142 45
Ksenia 0:5d3131d1b142 46
Ksenia 0:5d3131d1b142 47 /* For drawing statistics values */
Ksenia 0:5d3131d1b142 48
Ksenia 0:5d3131d1b142 49 /**************************************************************************************************************************
Ksenia 0:5d3131d1b142 50 ************************** Draw horisontal grid for temperature (-50 .. +125) *********************************************
Ksenia 0:5d3131d1b142 51 **************************************************************************************************************************/
Ksenia 0:5d3131d1b142 52 void Display::HorisontalGrid_Statistics_Temperature()
Ksenia 0:5d3131d1b142 53 {
Ksenia 0:5d3131d1b142 54 (*_TFT).DL(COLOR_RGB(80, 80, 80));
Ksenia 0:5d3131d1b142 55 char gridNumb = 125 + 50;
Ksenia 0:5d3131d1b142 56 for (int i = 100 * 16; i <= 200 * 16; i += 228) {
Ksenia 0:5d3131d1b142 57 (*_TFT).DL(BEGIN(LINES));
Ksenia 0:5d3131d1b142 58 (*_TFT).DL(LINE_WIDTH(8));
Ksenia 0:5d3131d1b142 59 if (gridNumb == 0 + 50) {
Ksenia 0:5d3131d1b142 60 (*_TFT).DL(LINE_WIDTH(12));
Ksenia 0:5d3131d1b142 61 }
Ksenia 0:5d3131d1b142 62 (*_TFT).DL(VERTEX2F(25 * 16, i));
Ksenia 0:5d3131d1b142 63 (*_TFT).DL(VERTEX2F(438 * 16, i));
Ksenia 0:5d3131d1b142 64 if (gridNumb >= 50) {
Ksenia 0:5d3131d1b142 65 (*_TFT).Number(445, i/16 - 9, 26, 0, gridNumb - 50);
Ksenia 0:5d3131d1b142 66 } else if (gridNumb == 25) {
Ksenia 0:5d3131d1b142 67 (*_TFT).Text(445, i/16 - 9, 26, 0, "-25");
Ksenia 0:5d3131d1b142 68 } else if (gridNumb == 0) {
Ksenia 0:5d3131d1b142 69 (*_TFT).Text(445, i/16 - 9, 26, 0, "-50");
Ksenia 0:5d3131d1b142 70 }
Ksenia 0:5d3131d1b142 71 gridNumb = gridNumb - 25;
Ksenia 0:5d3131d1b142 72 }
Ksenia 0:5d3131d1b142 73 }
Ksenia 0:5d3131d1b142 74
Ksenia 0:5d3131d1b142 75 /**************************************************************************************************************************
Ksenia 0:5d3131d1b142 76 ************************** Draw horisontal grid for humidity (0 .. 100) ***************************************************
Ksenia 0:5d3131d1b142 77 **************************************************************************************************************************/
Ksenia 0:5d3131d1b142 78 void Display::HorisontalGrid_Statistics_Humidity()
Ksenia 0:5d3131d1b142 79 {
Ksenia 0:5d3131d1b142 80 (*_TFT).DL(COLOR_RGB(80, 80, 80));
Ksenia 0:5d3131d1b142 81 char gridNumb = 100;
Ksenia 0:5d3131d1b142 82 for (int i = 100 * 16; i <= 200 * 16; i += (25*16)) {
Ksenia 0:5d3131d1b142 83 (*_TFT).DL(BEGIN(LINES));
Ksenia 0:5d3131d1b142 84 (*_TFT).DL(LINE_WIDTH(8));
Ksenia 0:5d3131d1b142 85 (*_TFT).DL(VERTEX2F(25 * 16, i));
Ksenia 0:5d3131d1b142 86 (*_TFT).DL(VERTEX2F(438 * 16, i));
Ksenia 0:5d3131d1b142 87 (*_TFT).Number(445, i/16 - 9, 26, 0, gridNumb);
Ksenia 0:5d3131d1b142 88 gridNumb = gridNumb - 25;
Ksenia 0:5d3131d1b142 89 }
Ksenia 0:5d3131d1b142 90 }
Ksenia 0:5d3131d1b142 91
Ksenia 0:5d3131d1b142 92 /**************************************************************************************************************************
Ksenia 0:5d3131d1b142 93 ************************** Draw vertical grid for 24-hour interval ******************************************&*************
Ksenia 0:5d3131d1b142 94 **************************************************************************************************************************/
Ksenia 0:5d3131d1b142 95 void Display::VerticalGrid24hrs(uint64_t gridSecondsOffset)
Ksenia 0:5d3131d1b142 96 {
Ksenia 0:5d3131d1b142 97 uint64_t gridSeconds = gridSecondsOffset;
Ksenia 0:5d3131d1b142 98 for (int i = 25 * 16; i <= 433 * 16; i += 17 * 16) {
Ksenia 0:5d3131d1b142 99 (*_TFT).DL(COLOR_RGB(80, 80, 80));
Ksenia 0:5d3131d1b142 100 (*_TFT).DL(BEGIN(LINES));
Ksenia 0:5d3131d1b142 101 (*_TFT).DL(LINE_WIDTH(8));
Ksenia 0:5d3131d1b142 102 (*_TFT).DL(VERTEX2F(i, 100 * 16));
Ksenia 0:5d3131d1b142 103 (*_TFT).DL(VERTEX2F(i, 200 * 16));
Ksenia 0:5d3131d1b142 104 CreateStringTime(gridTimeStr, gridSeconds);
Ksenia 0:5d3131d1b142 105 if ((i - 25 * 16) % (3 * 17 * 16) == 0) {
Ksenia 0:5d3131d1b142 106 (*_TFT).Text(i/16 - 20, 210, 20, 0, gridTimeStr);
Ksenia 0:5d3131d1b142 107 (*_TFT).DL(COLOR_RGB(20, 20, 20));
Ksenia 0:5d3131d1b142 108 (*_TFT).DL(BEGIN(LINES));
Ksenia 0:5d3131d1b142 109 (*_TFT).DL(VERTEX2F(i, 100 * 16));
Ksenia 0:5d3131d1b142 110 (*_TFT).DL(VERTEX2F(i, 205 * 16));
Ksenia 0:5d3131d1b142 111 }
Ksenia 0:5d3131d1b142 112 gridSeconds = gridSeconds + 3600;
Ksenia 0:5d3131d1b142 113 }
Ksenia 0:5d3131d1b142 114 }
Ksenia 0:5d3131d1b142 115
Ksenia 0:5d3131d1b142 116 /**************************************************************************************************************************
Ksenia 0:5d3131d1b142 117 ************************** Draw vertical grid for three-hour interval *****************************************************
Ksenia 0:5d3131d1b142 118 **************************************************************************************************************************/
Ksenia 0:5d3131d1b142 119 void Display::VerticalGrid3hrs(uint64_t gridSecondsOffset)
Ksenia 0:5d3131d1b142 120 {
Ksenia 0:5d3131d1b142 121 (*_TFT).DL(COLOR_RGB(0, 0, 0));
Ksenia 0:5d3131d1b142 122 uint64_t gridSeconds = 300 * timePoint3hrs + gridSecondsOffset;
Ksenia 0:5d3131d1b142 123 for (int i = 25 * 16; i <= 433 * 16; i += 34 * 16) {
Ksenia 0:5d3131d1b142 124 (*_TFT).DL(BEGIN(LINES));
Ksenia 0:5d3131d1b142 125 (*_TFT).DL(LINE_WIDTH(8));
Ksenia 0:5d3131d1b142 126 (*_TFT).DL(VERTEX2F(i, 100 * 16));
Ksenia 0:5d3131d1b142 127 (*_TFT).DL(VERTEX2F(i, 200 * 16));
Ksenia 0:5d3131d1b142 128 CreateStringTime(gridTimeStr, gridSeconds);
Ksenia 0:5d3131d1b142 129 if ((i - 25*16) % (2 * 34 * 16) == 0) {
Ksenia 0:5d3131d1b142 130 (*_TFT).DL(COLOR_RGB(80, 80, 80));
Ksenia 0:5d3131d1b142 131 (*_TFT).Text(i/16 - 20, 210, 20, 0, gridTimeStr);
Ksenia 0:5d3131d1b142 132 (*_TFT).DL(COLOR_RGB(0, 0, 0));
Ksenia 0:5d3131d1b142 133 (*_TFT).DL(BEGIN(LINES));
Ksenia 0:5d3131d1b142 134 (*_TFT).DL(VERTEX2F(i, 100 * 16));
Ksenia 0:5d3131d1b142 135 (*_TFT).DL(VERTEX2F(i, 205 * 16));
Ksenia 0:5d3131d1b142 136 }
Ksenia 0:5d3131d1b142 137 gridSeconds = gridSeconds + 900;
Ksenia 0:5d3131d1b142 138 }
Ksenia 0:5d3131d1b142 139 }
Ksenia 0:5d3131d1b142 140
Ksenia 0:5d3131d1b142 141 /**************************************************************************************************************************
Ksenia 0:5d3131d1b142 142 ************************** Draw vertical grid for 30-minutes interval *****************************************************
Ksenia 0:5d3131d1b142 143 **************************************************************************************************************************/
Ksenia 0:5d3131d1b142 144 void Display::VerticalGrid30min(uint64_t gridSecondsOffset)
Ksenia 0:5d3131d1b142 145 {
Ksenia 0:5d3131d1b142 146 (*_TFT).DL(COLOR_RGB(0, 0, 0));
Ksenia 0:5d3131d1b142 147 uint64_t gridSeconds = 300 * (timePoint3hrs + timePoint30min) + gridSecondsOffset;
Ksenia 0:5d3131d1b142 148 for (int i = 25 * 16; i <= 433 * 16; i += 68 * 16) {
Ksenia 0:5d3131d1b142 149 (*_TFT).DL(BEGIN(LINES));
Ksenia 0:5d3131d1b142 150 (*_TFT).DL(LINE_WIDTH(8));
Ksenia 0:5d3131d1b142 151 (*_TFT).DL(VERTEX2F(i, 100 * 16));
Ksenia 0:5d3131d1b142 152 (*_TFT).DL(VERTEX2F(i, 205 * 16));
Ksenia 0:5d3131d1b142 153 CreateStringTime(gridTimeStr, gridSeconds);
Ksenia 0:5d3131d1b142 154 (*_TFT).DL(COLOR_RGB(80, 80, 80));
Ksenia 0:5d3131d1b142 155 (*_TFT).Text(i/16 - 20, 210, 20, 0, gridTimeStr);
Ksenia 0:5d3131d1b142 156 (*_TFT).DL(COLOR_RGB(0, 0, 0));
Ksenia 0:5d3131d1b142 157 gridSeconds = gridSeconds + 300;
Ksenia 0:5d3131d1b142 158 }
Ksenia 0:5d3131d1b142 159 }