Freeman Oldman / Mbed 2 deprecated PSTFT_DC_Power_Supply

Dependencies:   mbed TFT_fonts SPI_TFT_ILI9341 beep _24LCXXX

Committer:
sinrab
Date:
Thu Jun 06 10:22:13 2019 +0000
Revision:
10:60fa02641552
Parent:
0:ed1ba99f7b14
v1.0.1

Who changed what in which revision?

UserRevisionLine numberNew contents of line
sinrab 0:ed1ba99f7b14 1 #include "mbed.h"
sinrab 0:ed1ba99f7b14 2 #include "SPI_TFT_ILI9341.h"
sinrab 0:ed1ba99f7b14 3 #include "Consolas26x49.h"
sinrab 0:ed1ba99f7b14 4 #include "digi36x44.h"
sinrab 0:ed1ba99f7b14 5 #include "Courier8x13.h"
sinrab 0:ed1ba99f7b14 6 #include "Consolas19x35.h"
sinrab 0:ed1ba99f7b14 7 #include "CourierNew13x23.h"
sinrab 0:ed1ba99f7b14 8 SPI_TFT_ILI9341 TFT(D11, D12, D13, D8, D9, D10,"TFT"); // mosi, miso, sclk, cs, reset, dc
sinrab 0:ed1ba99f7b14 9 void grid(void);
sinrab 0:ed1ba99f7b14 10 Timer t;// FPS
sinrab 0:ed1ba99f7b14 11 //Ticker valueUI;
sinrab 0:ed1ba99f7b14 12 InterruptIn button(USER_BUTTON); // кнопка питания вкл\выкл
sinrab 0:ed1ba99f7b14 13 //-----------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 14 //----------- my functions ---------//
sinrab 0:ed1ba99f7b14 15 void drawScreen1(void); // экран 1
sinrab 0:ed1ba99f7b14 16 void drawScreen2(void); // экран 2
sinrab 0:ed1ba99f7b14 17 void drawScreen3(void); // экран 3
sinrab 0:ed1ba99f7b14 18 void drawScreen4(void); // экран 4
sinrab 0:ed1ba99f7b14 19 void bootCold(void); // холодный старт
sinrab 0:ed1ba99f7b14 20 void map(void); // масштабирование
sinrab 0:ed1ba99f7b14 21 //---------------------------
sinrab 0:ed1ba99f7b14 22 float avgAin0(); // среднее значение с входа A0
sinrab 0:ed1ba99f7b14 23 float avgAin1(); // среднее значение с входа A1
sinrab 0:ed1ba99f7b14 24 float avgAin2(); // среднее значение с входа A2
sinrab 0:ed1ba99f7b14 25 float avgAin3(); // среднее значение с входа A3
sinrab 0:ed1ba99f7b14 26 float avgAin4(); // среднее значение с входа A4
sinrab 0:ed1ba99f7b14 27 float avgAin5(); // среднее значение с входа A5
sinrab 0:ed1ba99f7b14 28 //----
sinrab 0:ed1ba99f7b14 29 float in0 = 0;
sinrab 0:ed1ba99f7b14 30 float in1 = 0;
sinrab 0:ed1ba99f7b14 31 float in2 = 0;
sinrab 0:ed1ba99f7b14 32 float in3 = 0;
sinrab 0:ed1ba99f7b14 33 float in4 = 0;
sinrab 0:ed1ba99f7b14 34 float in5 = 0;
sinrab 0:ed1ba99f7b14 35 //----
sinrab 0:ed1ba99f7b14 36 float Ureal = 0;
sinrab 0:ed1ba99f7b14 37 float Ireal = 0;
sinrab 0:ed1ba99f7b14 38 float Uset = 0;
sinrab 0:ed1ba99f7b14 39 float Iset = 0;
sinrab 0:ed1ba99f7b14 40 float Uusb = 0;
sinrab 0:ed1ba99f7b14 41 float Iusb = 0;
sinrab 0:ed1ba99f7b14 42 //---------------------------
sinrab 0:ed1ba99f7b14 43 void dataProcessing(void); // обработка и подготовка данных с аналоговых входов
sinrab 0:ed1ba99f7b14 44 void powerButton(void); // при нажатии кнопки питания
sinrab 0:ed1ba99f7b14 45 void buttonUse(void); // обработка нажатий кнопок
sinrab 0:ed1ba99f7b14 46 //-----------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 47 float a0a = 0.000677; // A0 - U бп - avg при 0 - нижняя точка
sinrab 0:ed1ba99f7b14 48 float a0k = 33.61; // A0 - U бп - коэффициент - верхняя точка
sinrab 0:ed1ba99f7b14 49 //---------------------------------------------------------------
sinrab 0:ed1ba99f7b14 50 float a1a = 0.0024; // A1 - I бп - avg при 0 - нижняя точка a1a = avgAin1() - 0.00004
sinrab 0:ed1ba99f7b14 51 int a1k = 3144; // A1 - I бп - коэффициент - верхняя точка a1k = 2000/(avgAin1() - a1a) при 2амперах
sinrab 0:ed1ba99f7b14 52 //---------------------------------------------------------------
sinrab 0:ed1ba99f7b14 53 float a2a = 0.0024; // A2 - U уст - avg при 0 - нижняя точка
sinrab 0:ed1ba99f7b14 54 float a2k = 4; // A2 - U уст - коэффициент - верхняя точка
sinrab 0:ed1ba99f7b14 55 //---------------------------------------------------------------
sinrab 0:ed1ba99f7b14 56 float a3a = 0.0024; // A3 - I уст - avg при 0 - нижняя точка
sinrab 0:ed1ba99f7b14 57 float a3k = 4; // A3 - I уст - коэффициент - верхняя точка
sinrab 0:ed1ba99f7b14 58 //---------------------------------------------------------------
sinrab 0:ed1ba99f7b14 59 float a4a = 0.0024; // A4 - U usb - avg при 0 - нижняя точка
sinrab 0:ed1ba99f7b14 60 float a4k = 2.0; // A4 - U usb - коэффициент - верхняя точка
sinrab 0:ed1ba99f7b14 61 //---------------------------------------------------------------
sinrab 0:ed1ba99f7b14 62 float a5a = 0.0024; // A5 - I usb - avg при 0 - нижняя точка
sinrab 0:ed1ba99f7b14 63 int a5k = 3144; // A5 - I usb - коэффициент - верхняя точка
sinrab 0:ed1ba99f7b14 64 //---------------------------------------------------------------
sinrab 0:ed1ba99f7b14 65 float noisea0; //типа уровень шума (разница между минимум и максимум за 100 измерений) для А0
sinrab 0:ed1ba99f7b14 66 float noisea1; // - - для A1
sinrab 0:ed1ba99f7b14 67 float noisea2; // - - для A2
sinrab 0:ed1ba99f7b14 68 float noisea3; // - - для A3
sinrab 0:ed1ba99f7b14 69 float noisea4; // - - для A4
sinrab 0:ed1ba99f7b14 70 float noisea5; // - - для A5
sinrab 0:ed1ba99f7b14 71 //-----------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 72 DigitalIn buttonUp(D3); // Up
sinrab 0:ed1ba99f7b14 73 DigitalIn buttonDown(D4); // Down
sinrab 0:ed1ba99f7b14 74 DigitalIn buttonEnter(D5); // Enter
sinrab 0:ed1ba99f7b14 75 int Screen=1; // по умолчанию грузим первое меню
sinrab 0:ed1ba99f7b14 76 int complit=0; // в начале меню не прорисовано
sinrab 0:ed1ba99f7b14 77 int pb=0; // для прорисовки кнопки
sinrab 0:ed1ba99f7b14 78 int kline=15; // номер начальной строки в меню калибровки экран 4
sinrab 0:ed1ba99f7b14 79 //-----------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 80 DigitalOut powerMosfet(D2); // выход управления нагрузкой
sinrab 0:ed1ba99f7b14 81 AnalogIn ainA0(A0);
sinrab 0:ed1ba99f7b14 82 AnalogIn ainA1(A1);
sinrab 0:ed1ba99f7b14 83 AnalogIn ainA2(A2);
sinrab 0:ed1ba99f7b14 84 AnalogIn ainA3(A3);
sinrab 0:ed1ba99f7b14 85 AnalogIn ainA4(A4);
sinrab 0:ed1ba99f7b14 86 AnalogIn ainA5(A5);
sinrab 0:ed1ba99f7b14 87 //BusOut unused(A5,A2,A3,A4);
sinrab 0:ed1ba99f7b14 88 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 89 //--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 90 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 91 int main() //--------- Главная функция ---------//
sinrab 0:ed1ba99f7b14 92 {
sinrab 0:ed1ba99f7b14 93 powerMosfet = 0; // при включении выход выключен
sinrab 0:ed1ba99f7b14 94 bootCold(); // холодный старт
sinrab 0:ed1ba99f7b14 95 button.fall(&powerButton);
sinrab 0:ed1ba99f7b14 96
sinrab 0:ed1ba99f7b14 97 while(1) {
sinrab 0:ed1ba99f7b14 98 dataProcessing(); // обработка и подготовка данных с аналоговых входов
sinrab 0:ed1ba99f7b14 99 buttonUse(); // обработка нажатий кнопок
sinrab 0:ed1ba99f7b14 100 if (Screen == 1) drawScreen1();
sinrab 0:ed1ba99f7b14 101 if (Screen == 2) drawScreen2();
sinrab 0:ed1ba99f7b14 102 if (Screen == 3) drawScreen3();
sinrab 0:ed1ba99f7b14 103 if (Screen == 4) drawScreen4();
sinrab 0:ed1ba99f7b14 104 }
sinrab 0:ed1ba99f7b14 105 } //--------- Главная функция ---------//
sinrab 0:ed1ba99f7b14 106 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 107 //--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 108 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 109 void drawScreen1(void) // экран 1
sinrab 0:ed1ba99f7b14 110 {
sinrab 0:ed1ba99f7b14 111 if (complit==0) {
sinrab 0:ed1ba99f7b14 112 pb=0;
sinrab 0:ed1ba99f7b14 113 TFT.set_orientation(3);
sinrab 0:ed1ba99f7b14 114 TFT.background(Black);
sinrab 0:ed1ba99f7b14 115 TFT.cls();
sinrab 0:ed1ba99f7b14 116 TFT.rect(0,0,319,239,0xECA7); //рамка
sinrab 0:ed1ba99f7b14 117 TFT.rect(10,62,309,76,0x9000); //аналоговая 1
sinrab 0:ed1ba99f7b14 118 TFT.rect(10,137,309,151,0x9000); //авалоговая 2
sinrab 0:ed1ba99f7b14 119 //grid();
sinrab 0:ed1ba99f7b14 120 //int y = 51;
sinrab 0:ed1ba99f7b14 121 //TFT.line(5,y,310,y, White);
sinrab 0:ed1ba99f7b14 122 TFT.background(Black);
sinrab 0:ed1ba99f7b14 123 TFT.foreground(0xECA7); // цвет слов
sinrab 0:ed1ba99f7b14 124 TFT.set_font((unsigned char*) Consolas26x49);
sinrab 0:ed1ba99f7b14 125 TFT.locate(185, 13);
sinrab 0:ed1ba99f7b14 126 TFT.printf("V"); // U=
sinrab 0:ed1ba99f7b14 127 TFT.locate(165, 88);
sinrab 0:ed1ba99f7b14 128 TFT.printf("mA"); // I=
sinrab 0:ed1ba99f7b14 129 complit = 1; // прорисовали!
sinrab 0:ed1ba99f7b14 130
sinrab 0:ed1ba99f7b14 131 TFT.fillrect(230,10,304,53,Green); // c.v c.c
sinrab 0:ed1ba99f7b14 132 TFT.fillrect(230,85,304,128,Green);
sinrab 0:ed1ba99f7b14 133 TFT.background(Green);
sinrab 0:ed1ba99f7b14 134 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 135 TFT.set_font((unsigned char*) Consolas19x35);
sinrab 0:ed1ba99f7b14 136 TFT.locate(241, 14);
sinrab 0:ed1ba99f7b14 137 TFT.printf("C.V");
sinrab 0:ed1ba99f7b14 138 TFT.locate(241, 89);
sinrab 0:ed1ba99f7b14 139 TFT.printf("C.C");
sinrab 0:ed1ba99f7b14 140
sinrab 0:ed1ba99f7b14 141
sinrab 0:ed1ba99f7b14 142 TFT.rect(10,160,105,232,0xECA7);
sinrab 0:ed1ba99f7b14 143 TFT.fillrect(11,161,104,231,0x09E1);
sinrab 0:ed1ba99f7b14 144 TFT.rect(112,160,207,232,0xECA7);
sinrab 0:ed1ba99f7b14 145 TFT.rect(214,160,309,232,0xECA7);
sinrab 0:ed1ba99f7b14 146 TFT.background(0x09E1);
sinrab 0:ed1ba99f7b14 147 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 148 TFT.set_font((unsigned char*) CourierNew13x23);
sinrab 0:ed1ba99f7b14 149 TFT.locate(11, 161);
sinrab 0:ed1ba99f7b14 150 TFT.printf("10.4 W");
sinrab 0:ed1ba99f7b14 151 TFT.locate(11, 185);
sinrab 0:ed1ba99f7b14 152 TFT.printf("00.42.58");
sinrab 0:ed1ba99f7b14 153 TFT.locate(11, 209);
sinrab 0:ed1ba99f7b14 154 TFT.printf("42 'C");
sinrab 0:ed1ba99f7b14 155
sinrab 0:ed1ba99f7b14 156
sinrab 0:ed1ba99f7b14 157 }
sinrab 0:ed1ba99f7b14 158
sinrab 0:ed1ba99f7b14 159 TFT.background(Black);
sinrab 0:ed1ba99f7b14 160 TFT.foreground(Green);
sinrab 0:ed1ba99f7b14 161 TFT.set_font((unsigned char*) digi36x44);
sinrab 0:ed1ba99f7b14 162 TFT.locate(10, 10);
sinrab 0:ed1ba99f7b14 163 TFT.printf("%05.2f", Ureal); // выводим значение с A0 (напряжение)
sinrab 0:ed1ba99f7b14 164 TFT.locate(10, 85);
sinrab 0:ed1ba99f7b14 165 TFT.printf("%04.0f", Ireal); // выводим значение с A1 (ток)
sinrab 0:ed1ba99f7b14 166
sinrab 0:ed1ba99f7b14 167 if (powerMosfet==0 & pb==0) { // выводим OFF
sinrab 0:ed1ba99f7b14 168 TFT.background(0x09E1);
sinrab 0:ed1ba99f7b14 169 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 170 TFT.fillrect(215,161,308,231,0x09E1);
sinrab 0:ed1ba99f7b14 171 TFT.set_font((unsigned char*) Consolas26x49);
sinrab 0:ed1ba99f7b14 172 TFT.locate(226, 174);
sinrab 0:ed1ba99f7b14 173 TFT.printf("OFF");
sinrab 0:ed1ba99f7b14 174 pb=1;
sinrab 0:ed1ba99f7b14 175 }
sinrab 0:ed1ba99f7b14 176 if (powerMosfet==1 & pb==0) { // выводим ON
sinrab 0:ed1ba99f7b14 177 TFT.background(Green);
sinrab 0:ed1ba99f7b14 178 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 179 TFT.fillrect(215,161,308,231,Green);
sinrab 0:ed1ba99f7b14 180 TFT.set_font((unsigned char*) Consolas26x49);
sinrab 0:ed1ba99f7b14 181 TFT.locate(237, 174);
sinrab 0:ed1ba99f7b14 182 TFT.printf("ON");
sinrab 0:ed1ba99f7b14 183 pb=1;
sinrab 0:ed1ba99f7b14 184 }
sinrab 0:ed1ba99f7b14 185
sinrab 0:ed1ba99f7b14 186
sinrab 0:ed1ba99f7b14 187
sinrab 0:ed1ba99f7b14 188 }
sinrab 0:ed1ba99f7b14 189 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 190 void drawScreen2(void) // экран 2
sinrab 0:ed1ba99f7b14 191 {
sinrab 0:ed1ba99f7b14 192 if (complit==0) {
sinrab 0:ed1ba99f7b14 193 TFT.background(Blue);
sinrab 0:ed1ba99f7b14 194 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 195 TFT.cls();
sinrab 0:ed1ba99f7b14 196 complit = 1; // прорисовали!
sinrab 0:ed1ba99f7b14 197 }
sinrab 0:ed1ba99f7b14 198
sinrab 0:ed1ba99f7b14 199 TFT.background(Blue);
sinrab 0:ed1ba99f7b14 200 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 201 TFT.set_font((unsigned char*) Courier8x13);
sinrab 0:ed1ba99f7b14 202 TFT.locate(0, 0);
sinrab 0:ed1ba99f7b14 203 printf("--------- Data Analog In --------- \n");
sinrab 0:ed1ba99f7b14 204 printf("U.real A0 noise= %0.2f, avg= %0.5f \n", noisea0, in0);
sinrab 0:ed1ba99f7b14 205 printf("U= %06.4f coeff. k=%0.4f, a=%0.6f \n", Ureal, a0k, a0a); // A0 U real
sinrab 0:ed1ba99f7b14 206 printf("---------------------------------- \n");
sinrab 0:ed1ba99f7b14 207 printf("I.real A1 noise= %0.2f, avg= %0.5f \n", noisea1, in1);
sinrab 0:ed1ba99f7b14 208 printf("I= %06.2f coeff. k=%0.0d, a=%0.4f \n", Ireal, a1k, a1a); // A1 I real
sinrab 0:ed1ba99f7b14 209 printf("---------------------------------- \n");
sinrab 0:ed1ba99f7b14 210 printf("U.set A2 noise= %0.2f, avg= %0.5f \n", noisea2, in2);
sinrab 0:ed1ba99f7b14 211 printf("U= %06.3f coeff. k=%0.0f, a=%0.4f \n", Uset, a2k, a2a); // A2 U set
sinrab 0:ed1ba99f7b14 212 printf("---------------------------------- \n");
sinrab 0:ed1ba99f7b14 213 printf("I.set A3 noise= %0.2f, avg= %0.5f \n", noisea3, in3);
sinrab 0:ed1ba99f7b14 214 printf("I= %06.1f coeff. k=%0.0f, a=%0.4f \n", Iset, a3k, a3a); // A3 I set
sinrab 0:ed1ba99f7b14 215 printf("---------------------------------- \n");
sinrab 0:ed1ba99f7b14 216 printf("U.usb A4 noise= %0.2f, avg= %0.5f \n", noisea4, in4);
sinrab 0:ed1ba99f7b14 217 printf("U= %06.3f coeff. k=%0.0f, a=%0.4f \n", Uusb, a4k, a4a); // A4 U usb
sinrab 0:ed1ba99f7b14 218 printf("---------------------------------- \n");
sinrab 0:ed1ba99f7b14 219 printf("I.usb A5 noise= %0.2f, avg= %0.5f \n", noisea5, in5);
sinrab 0:ed1ba99f7b14 220 printf("I= %06.1f coeff. k=%0.0d, a=%0.4f \n", Iusb, a5k, a5a); // A5 I usb
sinrab 0:ed1ba99f7b14 221 }
sinrab 0:ed1ba99f7b14 222 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 223 void drawScreen3(void) // экран 3
sinrab 0:ed1ba99f7b14 224 {
sinrab 0:ed1ba99f7b14 225 TFT.background(Blue);
sinrab 0:ed1ba99f7b14 226 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 227 TFT.cls();
sinrab 0:ed1ba99f7b14 228 TFT.locate(0, 0);
sinrab 0:ed1ba99f7b14 229 }
sinrab 0:ed1ba99f7b14 230 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 231 void drawScreen4(void) // экран 4 калибровка
sinrab 0:ed1ba99f7b14 232 {
sinrab 0:ed1ba99f7b14 233 if (complit==0) {
sinrab 0:ed1ba99f7b14 234 TFT.background(Black);
sinrab 0:ed1ba99f7b14 235 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 236 TFT.cls();
sinrab 0:ed1ba99f7b14 237 complit = 1; // прорисовали!
sinrab 0:ed1ba99f7b14 238 }
sinrab 0:ed1ba99f7b14 239 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 240 TFT.background(Black);
sinrab 0:ed1ba99f7b14 241 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 242 TFT.locate(0, 0);
sinrab 0:ed1ba99f7b14 243 TFT.set_font((unsigned char*) Courier8x13);
sinrab 0:ed1ba99f7b14 244 printf(" Calibration. Enter - set. \n");
sinrab 0:ed1ba99f7b14 245 printf("--------------------------- \n");
sinrab 0:ed1ba99f7b14 246 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 247 if (kline==1) {
sinrab 0:ed1ba99f7b14 248 TFT.background(Green);
sinrab 0:ed1ba99f7b14 249 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 250 } else {
sinrab 0:ed1ba99f7b14 251 TFT.background(Black);
sinrab 0:ed1ba99f7b14 252 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 253 }
sinrab 0:ed1ba99f7b14 254 printf(" U real = %06.3f set zero \n", Ureal); // U real A0 zero
sinrab 0:ed1ba99f7b14 255 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 256 if (kline==2) {
sinrab 0:ed1ba99f7b14 257 TFT.background(Green);
sinrab 0:ed1ba99f7b14 258 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 259 } else {
sinrab 0:ed1ba99f7b14 260 TFT.background(Black);
sinrab 0:ed1ba99f7b14 261 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 262 }
sinrab 0:ed1ba99f7b14 263 printf(" U real = %06.3f set up dot \n", Ureal); // U real A0 hi
sinrab 0:ed1ba99f7b14 264 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 265 if (kline==3) {
sinrab 0:ed1ba99f7b14 266 TFT.background(Green);
sinrab 0:ed1ba99f7b14 267 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 268 } else {
sinrab 0:ed1ba99f7b14 269 TFT.background(Black);
sinrab 0:ed1ba99f7b14 270 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 271 }
sinrab 0:ed1ba99f7b14 272 printf(" I real = %06.1f set zero \n", Ireal); // I real A1 zero
sinrab 0:ed1ba99f7b14 273 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 274 if (kline==4) {
sinrab 0:ed1ba99f7b14 275 TFT.background(Green);
sinrab 0:ed1ba99f7b14 276 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 277 } else {
sinrab 0:ed1ba99f7b14 278 TFT.background(Black);
sinrab 0:ed1ba99f7b14 279 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 280 }
sinrab 0:ed1ba99f7b14 281 printf(" I real = %06.1f set up dot \n", Ireal); // I real A1 hi
sinrab 0:ed1ba99f7b14 282 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 283 if (kline==5) {
sinrab 0:ed1ba99f7b14 284 TFT.background(Green);
sinrab 0:ed1ba99f7b14 285 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 286 } else {
sinrab 0:ed1ba99f7b14 287 TFT.background(Black);
sinrab 0:ed1ba99f7b14 288 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 289 }
sinrab 0:ed1ba99f7b14 290 printf(" U set = %06.3f set zero \n", Uset); // U set A2 zero
sinrab 0:ed1ba99f7b14 291 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 292 if (kline==6) {
sinrab 0:ed1ba99f7b14 293 TFT.background(Green);
sinrab 0:ed1ba99f7b14 294 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 295 } else {
sinrab 0:ed1ba99f7b14 296 TFT.background(Black);
sinrab 0:ed1ba99f7b14 297 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 298 }
sinrab 0:ed1ba99f7b14 299 printf(" U set = %06.3f set up dot \n", Uset); // U set A2 hi
sinrab 0:ed1ba99f7b14 300 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 301 if (kline==7) {
sinrab 0:ed1ba99f7b14 302 TFT.background(Green);
sinrab 0:ed1ba99f7b14 303 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 304 } else {
sinrab 0:ed1ba99f7b14 305 TFT.background(Black);
sinrab 0:ed1ba99f7b14 306 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 307 }
sinrab 0:ed1ba99f7b14 308 printf(" I set = %06.1f set zero \n", Iset); // I set A3 zero
sinrab 0:ed1ba99f7b14 309 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 310 if (kline==8) {
sinrab 0:ed1ba99f7b14 311 TFT.background(Green);
sinrab 0:ed1ba99f7b14 312 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 313 } else {
sinrab 0:ed1ba99f7b14 314 TFT.background(Black);
sinrab 0:ed1ba99f7b14 315 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 316 }
sinrab 0:ed1ba99f7b14 317 printf(" I set = %06.1f set up dot \n",Iset); // I set A3 hi
sinrab 0:ed1ba99f7b14 318 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 319 if (kline==9) {
sinrab 0:ed1ba99f7b14 320 TFT.background(Green);
sinrab 0:ed1ba99f7b14 321 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 322 } else {
sinrab 0:ed1ba99f7b14 323 TFT.background(Black);
sinrab 0:ed1ba99f7b14 324 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 325 }
sinrab 0:ed1ba99f7b14 326 printf(" U usb = %06.3f set up dot \n", Uusb); // U usb A4 zero
sinrab 0:ed1ba99f7b14 327 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 328 if (kline==10) {
sinrab 0:ed1ba99f7b14 329 TFT.background(Green);
sinrab 0:ed1ba99f7b14 330 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 331 } else {
sinrab 0:ed1ba99f7b14 332 TFT.background(Black);
sinrab 0:ed1ba99f7b14 333 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 334 }
sinrab 0:ed1ba99f7b14 335 printf(" U usb = %06.3f set zero \n", Uusb); // U usb A4 hi
sinrab 0:ed1ba99f7b14 336 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 337 if (kline==11) {
sinrab 0:ed1ba99f7b14 338 TFT.background(Green);
sinrab 0:ed1ba99f7b14 339 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 340 } else {
sinrab 0:ed1ba99f7b14 341 TFT.background(Black);
sinrab 0:ed1ba99f7b14 342 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 343 }
sinrab 0:ed1ba99f7b14 344 printf(" I usb = %06.1f set up dot \n", Iusb); // I usb A5 zero
sinrab 0:ed1ba99f7b14 345 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 346 if (kline==12) {
sinrab 0:ed1ba99f7b14 347 TFT.background(Green);
sinrab 0:ed1ba99f7b14 348 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 349 } else {
sinrab 0:ed1ba99f7b14 350 TFT.background(Black);
sinrab 0:ed1ba99f7b14 351 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 352 }
sinrab 0:ed1ba99f7b14 353 printf(" I usb = %06.1f set up dot \n", Iusb); // I usb A5 hi
sinrab 0:ed1ba99f7b14 354 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 355 if (kline==13) {
sinrab 0:ed1ba99f7b14 356 TFT.background(Green);
sinrab 0:ed1ba99f7b14 357 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 358 } else {
sinrab 0:ed1ba99f7b14 359 TFT.background(Black);
sinrab 0:ed1ba99f7b14 360 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 361 }
sinrab 0:ed1ba99f7b14 362 printf(" Load Default \n");
sinrab 0:ed1ba99f7b14 363 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 364 if (kline==14) {
sinrab 0:ed1ba99f7b14 365 TFT.background(Green);
sinrab 0:ed1ba99f7b14 366 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 367 } else {
sinrab 0:ed1ba99f7b14 368 TFT.background(Black);
sinrab 0:ed1ba99f7b14 369 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 370 }
sinrab 0:ed1ba99f7b14 371 printf(" Save all to flash memory \n");
sinrab 0:ed1ba99f7b14 372 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 373 if (kline==15) {
sinrab 0:ed1ba99f7b14 374 TFT.background(Green);
sinrab 0:ed1ba99f7b14 375 TFT.foreground(Black);
sinrab 0:ed1ba99f7b14 376 } else {
sinrab 0:ed1ba99f7b14 377 TFT.background(Black);
sinrab 0:ed1ba99f7b14 378 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 379 }
sinrab 0:ed1ba99f7b14 380 printf(" Exit \n");
sinrab 0:ed1ba99f7b14 381 //----------------------------------------------------------------
sinrab 0:ed1ba99f7b14 382 TFT.background(Black);
sinrab 0:ed1ba99f7b14 383 TFT.foreground(White);
sinrab 0:ed1ba99f7b14 384 printf("--------------------------- \n");
sinrab 0:ed1ba99f7b14 385
sinrab 0:ed1ba99f7b14 386
sinrab 0:ed1ba99f7b14 387 }
sinrab 0:ed1ba99f7b14 388 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 389 void bootCold(void)
sinrab 0:ed1ba99f7b14 390 {
sinrab 0:ed1ba99f7b14 391 TFT.claim(stdout); // send stdout to the TFT display
sinrab 0:ed1ba99f7b14 392
sinrab 0:ed1ba99f7b14 393 }
sinrab 0:ed1ba99f7b14 394 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 395 long map(long x, long in_min, long in_max, long out_min, long out_max) // функция масштабирования
sinrab 0:ed1ba99f7b14 396 {
sinrab 0:ed1ba99f7b14 397 return (x - in_min) * (out_max - out_min) / (in_max - in_min) + out_min;
sinrab 0:ed1ba99f7b14 398 }
sinrab 0:ed1ba99f7b14 399 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 400 float avgAin0() // функция среднего значения с входа A0
sinrab 0:ed1ba99f7b14 401 {
sinrab 0:ed1ba99f7b14 402 int m = 100;
sinrab 0:ed1ba99f7b14 403 float value[m];
sinrab 0:ed1ba99f7b14 404 float max;
sinrab 0:ed1ba99f7b14 405 float min;
sinrab 0:ed1ba99f7b14 406 double itg;
sinrab 0:ed1ba99f7b14 407 max = itg = 0.0;
sinrab 0:ed1ba99f7b14 408 min = 3.3;
sinrab 0:ed1ba99f7b14 409 for (int i=0; i<m; i++) {
sinrab 0:ed1ba99f7b14 410 value[i] = ainA0;
sinrab 0:ed1ba99f7b14 411 if (value[i] > max) max = value[i];
sinrab 0:ed1ba99f7b14 412 if (value[i] < min) min = value[i];
sinrab 0:ed1ba99f7b14 413 itg += value[i];
sinrab 0:ed1ba99f7b14 414 }
sinrab 0:ed1ba99f7b14 415 noisea0 = (max - min)*1000;
sinrab 0:ed1ba99f7b14 416 return itg/m;
sinrab 0:ed1ba99f7b14 417 }
sinrab 0:ed1ba99f7b14 418 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 419 float avgAin1() // функция среднего значения с входа A1
sinrab 0:ed1ba99f7b14 420 {
sinrab 0:ed1ba99f7b14 421 float value[100];
sinrab 0:ed1ba99f7b14 422 float max;
sinrab 0:ed1ba99f7b14 423 float min;
sinrab 0:ed1ba99f7b14 424 double itg;
sinrab 0:ed1ba99f7b14 425 max = itg = 0.0;
sinrab 0:ed1ba99f7b14 426 min = 3.3;
sinrab 0:ed1ba99f7b14 427 for (int i=0; i<100; i++) {
sinrab 0:ed1ba99f7b14 428 value[i] = ainA1;
sinrab 0:ed1ba99f7b14 429 if (value[i] > max) max = value[i];
sinrab 0:ed1ba99f7b14 430 if (value[i] < min) min = value[i];
sinrab 0:ed1ba99f7b14 431 itg += value[i];
sinrab 0:ed1ba99f7b14 432 }
sinrab 0:ed1ba99f7b14 433 noisea1 = (max - min)*1000;
sinrab 0:ed1ba99f7b14 434 return itg/100;
sinrab 0:ed1ba99f7b14 435 }
sinrab 0:ed1ba99f7b14 436 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 437 float avgAin2() // функция среднего значения с входа A2
sinrab 0:ed1ba99f7b14 438 {
sinrab 0:ed1ba99f7b14 439 float value[100];
sinrab 0:ed1ba99f7b14 440 float max;
sinrab 0:ed1ba99f7b14 441 float min;
sinrab 0:ed1ba99f7b14 442 double itg;
sinrab 0:ed1ba99f7b14 443 max = itg = 0.0;
sinrab 0:ed1ba99f7b14 444 min = 3.3;
sinrab 0:ed1ba99f7b14 445 for (int i=0; i<100; i++) {
sinrab 0:ed1ba99f7b14 446 value[i] = ainA2;
sinrab 0:ed1ba99f7b14 447 if (value[i] > max) max = value[i];
sinrab 0:ed1ba99f7b14 448 if (value[i] < min) min = value[i];
sinrab 0:ed1ba99f7b14 449 itg += value[i];
sinrab 0:ed1ba99f7b14 450 }
sinrab 0:ed1ba99f7b14 451 noisea2 = (max - min)*1000;
sinrab 0:ed1ba99f7b14 452 return itg/100;
sinrab 0:ed1ba99f7b14 453 }
sinrab 0:ed1ba99f7b14 454 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 455 float avgAin3() // функция среднего значения с входа A3
sinrab 0:ed1ba99f7b14 456 {
sinrab 0:ed1ba99f7b14 457 float value[100];
sinrab 0:ed1ba99f7b14 458 float max;
sinrab 0:ed1ba99f7b14 459 float min;
sinrab 0:ed1ba99f7b14 460 double itg;
sinrab 0:ed1ba99f7b14 461 max = itg = 0.0;
sinrab 0:ed1ba99f7b14 462 min = 3.3;
sinrab 0:ed1ba99f7b14 463 for (int i=0; i<100; i++) {
sinrab 0:ed1ba99f7b14 464 value[i] = ainA3;
sinrab 0:ed1ba99f7b14 465 if (value[i] > max) max = value[i];
sinrab 0:ed1ba99f7b14 466 if (value[i] < min) min = value[i];
sinrab 0:ed1ba99f7b14 467 itg += value[i];
sinrab 0:ed1ba99f7b14 468 }
sinrab 0:ed1ba99f7b14 469 noisea3 = (max - min)*1000;
sinrab 0:ed1ba99f7b14 470 return itg/100;
sinrab 0:ed1ba99f7b14 471 }
sinrab 0:ed1ba99f7b14 472 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 473 float avgAin4() // функция среднего значения с входа A4
sinrab 0:ed1ba99f7b14 474 {
sinrab 0:ed1ba99f7b14 475 float value[100];
sinrab 0:ed1ba99f7b14 476 float max;
sinrab 0:ed1ba99f7b14 477 float min;
sinrab 0:ed1ba99f7b14 478 double itg;
sinrab 0:ed1ba99f7b14 479 max = itg = 0.0;
sinrab 0:ed1ba99f7b14 480 min = 3.3;
sinrab 0:ed1ba99f7b14 481 for (int i=0; i<100; i++) {
sinrab 0:ed1ba99f7b14 482 value[i] = ainA4;
sinrab 0:ed1ba99f7b14 483 if (value[i] > max) max = value[i];
sinrab 0:ed1ba99f7b14 484 if (value[i] < min) min = value[i];
sinrab 0:ed1ba99f7b14 485 itg += value[i];
sinrab 0:ed1ba99f7b14 486 }
sinrab 0:ed1ba99f7b14 487 noisea4 = (max - min)*1000;
sinrab 0:ed1ba99f7b14 488 return itg/100;
sinrab 0:ed1ba99f7b14 489 }
sinrab 0:ed1ba99f7b14 490 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 491 float avgAin5() // функция среднего значения с входа A5
sinrab 0:ed1ba99f7b14 492 {
sinrab 0:ed1ba99f7b14 493 float value[100];
sinrab 0:ed1ba99f7b14 494 float max;
sinrab 0:ed1ba99f7b14 495 float min;
sinrab 0:ed1ba99f7b14 496 double itg;
sinrab 0:ed1ba99f7b14 497 max = itg = 0.0;
sinrab 0:ed1ba99f7b14 498 min = 3.3;
sinrab 0:ed1ba99f7b14 499 for (int i=0; i<100; i++) {
sinrab 0:ed1ba99f7b14 500 value[i] = ainA5;
sinrab 0:ed1ba99f7b14 501 if (value[i] > max) max = value[i];
sinrab 0:ed1ba99f7b14 502 if (value[i] < min) min = value[i];
sinrab 0:ed1ba99f7b14 503 itg += value[i];
sinrab 0:ed1ba99f7b14 504 }
sinrab 0:ed1ba99f7b14 505 noisea5 = (max - min)*1000;
sinrab 0:ed1ba99f7b14 506 return itg/100;
sinrab 0:ed1ba99f7b14 507 }
sinrab 0:ed1ba99f7b14 508 /*/------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 509 void drawMainScale(void) {
sinrab 0:ed1ba99f7b14 510 a
sinrab 0:ed1ba99f7b14 511 int a = avg*1000;
sinrab 0:ed1ba99f7b14 512 b = mapIOIO(c, 0, 100, 0, 220);
sinrab 0:ed1ba99f7b14 513
sinrab 0:ed1ba99f7b14 514 TFT.fillrect(10, 10, (b+10), 20, Red); // аналоговая шкала 1
sinrab 0:ed1ba99f7b14 515 TFT.fillrect((b+10), 10, 230, 20, Black);
sinrab 0:ed1ba99f7b14 516 }
sinrab 0:ed1ba99f7b14 517 //------------------------------------------------------------------------------------------------------------*/
sinrab 0:ed1ba99f7b14 518 void powerButton(void) // при нажатии кнопки питания
sinrab 0:ed1ba99f7b14 519 {
sinrab 0:ed1ba99f7b14 520 powerMosfet=!powerMosfet;
sinrab 0:ed1ba99f7b14 521 pb=0;
sinrab 0:ed1ba99f7b14 522 }
sinrab 0:ed1ba99f7b14 523 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 524 void dataProcessing(void) // обработка и подготовка данных с аналоговых входов
sinrab 0:ed1ba99f7b14 525 {
sinrab 0:ed1ba99f7b14 526 /*t.reset();// FPS
sinrab 0:ed1ba99f7b14 527 t.start();// FPS*/
sinrab 0:ed1ba99f7b14 528
sinrab 0:ed1ba99f7b14 529 in0 = avgAin0();
sinrab 0:ed1ba99f7b14 530 in1 = avgAin1();
sinrab 0:ed1ba99f7b14 531 in2 = avgAin2();
sinrab 0:ed1ba99f7b14 532 in3 = avgAin3();
sinrab 0:ed1ba99f7b14 533 in4 = avgAin4();
sinrab 0:ed1ba99f7b14 534 in5 = avgAin5();
sinrab 0:ed1ba99f7b14 535
sinrab 0:ed1ba99f7b14 536 // A0 U real U = (avgAin0() - a0a) * a0k
sinrab 0:ed1ba99f7b14 537 // A1 I real I = (avgAin1() - a1a) * a1k
sinrab 0:ed1ba99f7b14 538 // A2 U set U = (avgAin2() - a2a) * a2k
sinrab 0:ed1ba99f7b14 539 // A3 I set I = (avgAin3() - a3a) * a3k
sinrab 0:ed1ba99f7b14 540 // A4 U usb U = (avgAin4() - a4a) * a4k
sinrab 0:ed1ba99f7b14 541 // A5 I usb I = (avgAin5() - a5a) * a5k
sinrab 0:ed1ba99f7b14 542
sinrab 0:ed1ba99f7b14 543 Ureal = a0k*(in0-a0a);
sinrab 0:ed1ba99f7b14 544 Ireal = a1k*(in1-a1a);
sinrab 0:ed1ba99f7b14 545 Uset = a2k*(in2-a2a);
sinrab 0:ed1ba99f7b14 546 Iset = a3k*(in3-a3a);
sinrab 0:ed1ba99f7b14 547 Uusb = a4k*(in4-a4a);
sinrab 0:ed1ba99f7b14 548 Iusb = a5k*(in5-a5a);
sinrab 0:ed1ba99f7b14 549
sinrab 0:ed1ba99f7b14 550 /*t.stop();// FPS
sinrab 0:ed1ba99f7b14 551 TFT.background(Black);// FPS
sinrab 0:ed1ba99f7b14 552 TFT.foreground(Green);// FPS
sinrab 0:ed1ba99f7b14 553 TFT.set_font((unsigned char*) Courier8x13);// FPS
sinrab 0:ed1ba99f7b14 554 TFT.locate(260,225);// FPS
sinrab 0:ed1ba99f7b14 555 TFT.printf("%0.2f", (1/t.read()));// FPS*/
sinrab 0:ed1ba99f7b14 556 }
sinrab 0:ed1ba99f7b14 557 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 558 void buttonUse(void) // обработка нажатий кнопок
sinrab 0:ed1ba99f7b14 559 {
sinrab 0:ed1ba99f7b14 560 int one=0; // для обработки одной кнопки за раз
sinrab 0:ed1ba99f7b14 561 //------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 562 if (Screen==1 & one==0) { //главный экран
sinrab 0:ed1ba99f7b14 563 if (buttonEnter==0) { // Enter
sinrab 0:ed1ba99f7b14 564 //wait(1);
sinrab 0:ed1ba99f7b14 565 Screen=2;
sinrab 0:ed1ba99f7b14 566 complit=0;
sinrab 0:ed1ba99f7b14 567 }
sinrab 0:ed1ba99f7b14 568 if (buttonDown==0) { // Down
sinrab 0:ed1ba99f7b14 569 Screen=4;
sinrab 0:ed1ba99f7b14 570 complit=0;
sinrab 0:ed1ba99f7b14 571 }
sinrab 0:ed1ba99f7b14 572 if (buttonUp==0) { // Up
sinrab 0:ed1ba99f7b14 573 Screen=3;
sinrab 0:ed1ba99f7b14 574 complit=0;
sinrab 0:ed1ba99f7b14 575 }
sinrab 0:ed1ba99f7b14 576 one=1;
sinrab 0:ed1ba99f7b14 577 }
sinrab 0:ed1ba99f7b14 578 //------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 579 if (Screen==2 & one==0) {
sinrab 0:ed1ba99f7b14 580 if (buttonEnter==0) { // Enter
sinrab 0:ed1ba99f7b14 581 //wait(1);
sinrab 0:ed1ba99f7b14 582 Screen=1;
sinrab 0:ed1ba99f7b14 583 complit=0;
sinrab 0:ed1ba99f7b14 584 }
sinrab 0:ed1ba99f7b14 585 one=1;
sinrab 0:ed1ba99f7b14 586 }
sinrab 0:ed1ba99f7b14 587 //------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 588 if (Screen==3 & one==0) { //экран меню общие настройки
sinrab 0:ed1ba99f7b14 589 if (buttonEnter==0) { // Enter
sinrab 0:ed1ba99f7b14 590 //wait(1);
sinrab 0:ed1ba99f7b14 591 Screen=1;
sinrab 0:ed1ba99f7b14 592 complit=0;
sinrab 0:ed1ba99f7b14 593 }
sinrab 0:ed1ba99f7b14 594 one=1;
sinrab 0:ed1ba99f7b14 595 }
sinrab 0:ed1ba99f7b14 596 //------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 597 if (Screen==4 & one==0) { //экран меню Калибровка
sinrab 0:ed1ba99f7b14 598 if (buttonEnter==0) { // Enter
sinrab 0:ed1ba99f7b14 599 if (kline==1) a0a = in0 - 0.0001;
sinrab 0:ed1ba99f7b14 600 if (kline==2) a0k = 20/(in0-a0a);
sinrab 0:ed1ba99f7b14 601 if (kline==3) Screen=1;
sinrab 0:ed1ba99f7b14 602 if (kline==4) Screen=1;
sinrab 0:ed1ba99f7b14 603 if (kline==5) Screen=1;
sinrab 0:ed1ba99f7b14 604 if (kline==6) Screen=1;
sinrab 0:ed1ba99f7b14 605 if (kline==7) Screen=1;
sinrab 0:ed1ba99f7b14 606 if (kline==8) Screen=1;
sinrab 0:ed1ba99f7b14 607 if (kline==9) Screen=1;
sinrab 0:ed1ba99f7b14 608 if (kline==10) Screen=1;
sinrab 0:ed1ba99f7b14 609 if (kline==11) Screen=1;
sinrab 0:ed1ba99f7b14 610 if (kline==12) Screen=1;
sinrab 0:ed1ba99f7b14 611 if (kline==13) Screen=1;
sinrab 0:ed1ba99f7b14 612 if (kline==14) Screen=1;
sinrab 0:ed1ba99f7b14 613 if (kline==15) Screen=1;
sinrab 0:ed1ba99f7b14 614 complit=0;
sinrab 0:ed1ba99f7b14 615 }
sinrab 0:ed1ba99f7b14 616
sinrab 0:ed1ba99f7b14 617 if (buttonUp==0) { // Up
sinrab 0:ed1ba99f7b14 618 kline--;
sinrab 0:ed1ba99f7b14 619 if (kline==0) kline=15;
sinrab 0:ed1ba99f7b14 620
sinrab 0:ed1ba99f7b14 621 }
sinrab 0:ed1ba99f7b14 622
sinrab 0:ed1ba99f7b14 623 if (buttonDown==0) { // Down
sinrab 0:ed1ba99f7b14 624 kline++;
sinrab 0:ed1ba99f7b14 625 if (kline==16) kline=1;
sinrab 0:ed1ba99f7b14 626
sinrab 0:ed1ba99f7b14 627 }
sinrab 0:ed1ba99f7b14 628 one=1;
sinrab 0:ed1ba99f7b14 629 }
sinrab 0:ed1ba99f7b14 630 //------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 631 }
sinrab 0:ed1ba99f7b14 632 //------------------------------------------------------------------------------------------------------------
sinrab 0:ed1ba99f7b14 633 void grid(void)
sinrab 0:ed1ba99f7b14 634 {
sinrab 0:ed1ba99f7b14 635 TFT.cls();
sinrab 0:ed1ba99f7b14 636 for (int i=0; i<240; i=i+5) {
sinrab 0:ed1ba99f7b14 637 TFT.line(0,i,320,i, White);
sinrab 0:ed1ba99f7b14 638 }
sinrab 0:ed1ba99f7b14 639 for (int i=2; i<240; i=i+5) {
sinrab 0:ed1ba99f7b14 640 TFT.line(4,i,320,i, White);
sinrab 0:ed1ba99f7b14 641 }
sinrab 0:ed1ba99f7b14 642 for (int i=3; i<240; i=i+5) {
sinrab 0:ed1ba99f7b14 643 TFT.line(4,i,320,i, White);
sinrab 0:ed1ba99f7b14 644 }
sinrab 0:ed1ba99f7b14 645
sinrab 0:ed1ba99f7b14 646 }