Linear stabilizer voltage and current on lm358 and transictor. Digital control and indication on stm32f103rbt and tft01-22sp (ili9341). https://www.youtube.com/watch?v=DLC3KEtlr9I https://radiokot.ru/forum/viewtopic.php?f=11&t=112440
Dependencies: mbed TFT_fonts SPI_TFT_ILI9341 beep _24LCXXX
main.cpp
- Committer:
- sinrab
- Date:
- 2014-11-01
- Revision:
- 2:d20b1ef35d3f
- Parent:
- 1:7bc0f280c259
- Child:
- 3:791cf9a867d1
File content as of revision 2:d20b1ef35d3f:
#include "mbed.h" #include "SPI_TFT_ILI9341.h" #include "Consolas26x49.h" #include "digi36x44.h" #include "Courier8x13.h" #include "Consolas19x35.h" #include "CourierNew13x23.h" #include "Lucida13x21.h" //---------------------------------- #define text5 0xFFFF #define back5 0x018C #define text5_i 0x0000 #define back5_i 0x0660 #define back5_iset 0xF986 //---------------------------------- #define text4 0xFFFF #define back4 0x3320 #define text4_i 0x0000 #define back4_i 0xFCD9 //---------------------------------- #define text2 0x0000 #define back2 0x9E7F //---------------------------------- SPI_TFT_ILI9341 TFT(D11, D12, D13, D8, D9, D10,"TFT"); // mosi, miso, sclk, cs, reset, dc void grid(void); Timer fps;// FPS //Ticker valueUI; InterruptIn button(USER_BUTTON); // кнопка питания вкл\выкл //----------------------------------------------------------------------------------------------------------- Ввести в меню опцию коррекции падения напряжения на токоизмерительном шунте. int t; // секунд с момента включения int tstart; // при включении нагрузки равна реальному времени time_t treal; // секунды реального времени для таймера нагрузки int h=0; //вывод часов int m=0; // минут int s=0; // секунд void timeConvert(void); //----------- my functions ---------// void drawScreen1(void); // экран 1 Главный экран void drawScreen2(void); // экран 2 dats analog in and Noise void drawScreen3(void); // экран 3 void drawScreen4(void); // экран 4 Калибровка void drawScreen5(void); // экран 5 Настройки главный void drawScreen6(void); // экран 6 void drawScreen7(void); // экран 7 void drawScreen8(void); // экран 8 void bootCold(void); // холодный старт float map(float, float, float, float, float); // масштабирование void SetDateTime(void); // установка даты и времени int year=2014; int mon=11; int day=1; int hour=16; int min=42; int sec=0; time_t seconds; //для часов реального времени //--------------------------- float avgAin0(); // среднее значение с входа A0 float avgAin1(); // среднее значение с входа A1 float avgAin2(); // среднее значение с входа A2 float avgAin3(); // среднее значение с входа A3 float avgAin4(); // среднее значение с входа A4 float avgAin5(); // среднее значение с входа A5 //---- float in0 = 0; float in1 = 0; float in2 = 0; float in3 = 0; float in4 = 0; float in5 = 0; //---- float Ureal = 0; float Ireal = 0; float Uset = 0; float Iset = 0; float Uusb = 0; float Iusb = 0; //--------------------------- void dataProcessing(void); // обработка и подготовка данных с аналоговых входов void powerButton(void); // при нажатии кнопки питания void buttonUse(void); // обработка нажатий кнопок //----------------------------------------------------------------------------------------------------------- float a0a = 0.000677; // A0 - U бп - avg при 0 - нижняя точка float a0k = 33.61; // A0 - U бп - коэффициент - верхняя точка //--------------------------------------------------------------- float a1a = 0.0024; // A1 - I бп - avg при 0 - нижняя точка a1a = avgAin1() - 0.00004 int a1k = 3144; // A1 - I бп - коэффициент - верхняя точка a1k = 2000/(avgAin1() - a1a) при 2амперах //--------------------------------------------------------------- float a2a = 0.0024; // A2 - U уст - avg при 0 - нижняя точка float a2k = 4; // A2 - U уст - коэффициент - верхняя точка //--------------------------------------------------------------- float a3a = 0.0024; // A3 - I уст - avg при 0 - нижняя точка float a3k = 4; // A3 - I уст - коэффициент - верхняя точка //--------------------------------------------------------------- float a4a = 0.0024; // A4 - U usb - avg при 0 - нижняя точка float a4k = 2.0; // A4 - U usb - коэффициент - верхняя точка //--------------------------------------------------------------- float a5a = 0.0024; // A5 - I usb - avg при 0 - нижняя точка int a5k = 3144; // A5 - I usb - коэффициент - верхняя точка //--------------------------------------------------------------- float noisea0; //типа уровень шума (разница между минимум и максимум за 100 измерений) для А0 float noisea1; // - - для A1 float noisea2; // - - для A2 float noisea3; // - - для A3 float noisea4; // - - для A4 float noisea5; // - - для A5 //----------------------------------------------------------------------------------------------------------- DigitalIn buttonUp(D3); // Up DigitalIn buttonDown(D4); // Down DigitalIn buttonEnter(D5); // Enter int Screen=1; // по умолчанию грузим первое меню int complit=0; // в начале меню не прорисовано int pb=0; // для прорисовки кнопки int kline=15; // номер начальной строки в меню калибровки экран 4 int mline=15; // номер начальной строки в меню Настройки главная экран 5 int mline2=0; //в главном меню строка 2 не выбрана int nline=8; // номер начальной строки в меню установки времени экран 3 int pmenu=0; //в главном меню изменение выбраной строки не действительно int powerProtect=1; //защита от кз int pp=0; //защита от кз для прорисовки меню float brightness = 1.0f; //яркость экрана int cc=0; // значит идет C.V int pm=0; // для одной прорисовки сс и сv PwmOut pinbrightness(D15); // выход на ключ регулировки яркости экрана //----------------------------------------------------------------------------------------------------------- DigitalOut powerMosfet(D2); // выход управления нагрузкой AnalogIn ainA0(A0); AnalogIn ainA1(A1); AnalogIn ainA2(A2); AnalogIn ainA3(A3); AnalogIn ainA4(A4); AnalogIn ainA5(A5); //BusOut unused(A5,A2,A3,A4); //------------------------------------------------------------------------------------------------------------ //-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- //------------------------------------------------------------------------------------------------------------ void bootCold(void) { powerMosfet = 0; // при включении выход выключен TFT.claim(stdout); // send stdout to the TFT display set_time(1414838392); // Set RTC time to Wed, 28 Oct 2009 11:35:37 tstart = treal = time(NULL); pinbrightness.period(0.001); // задаём частоту Шим подсветки 0.001 - 1000 герц TFT.set_orientation(3); TFT.background(Black); TFT.cls(); wait(0.2); pinbrightness = brightness; // включаем подсветку } //------------------------------------------------------------------------------------------------------------ int main() //--------- Главная функция ---------// { bootCold(); // холодный старт button.fall(&powerButton); // прерывание кнопки включения нагрузки запускает функцию while(1) { dataProcessing(); // обработка и подготовка данных с аналоговых входов buttonUse(); // обработка нажатий кнопок if (Screen == 1) drawScreen1(); if (Screen == 2) drawScreen2(); if (Screen == 3) drawScreen3(); if (Screen == 4) drawScreen4(); if (Screen == 5) drawScreen5(); if (Screen == 6) drawScreen6(); if (Screen == 7) drawScreen7(); if (Screen == 8) drawScreen8(); } } //--------- Главная функция ---------// //------------------------------------------------------------------------------------------------------------ //-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- //------------------------------------------------------------------------------------------------------------ void drawScreen1(void) // экран 1 { if (complit==0) { pb=0; pp=0; TFT.set_orientation(3); TFT.background(Black); TFT.cls(); TFT.rect(0,0,319,239,0xECA7); //рамка TFT.rect(10,62,309,76,0xECA7); //аналоговая 1 TFT.rect(10,137,309,151,0xECA7); //авалоговая 2 //grid(); //int y = 51; //TFT.line(5,y,310,y, White); TFT.background(Black); TFT.foreground(0xECA7); // цвет слов TFT.set_font((unsigned char*) Consolas26x49); TFT.locate(193, 13); TFT.printf("v"); // U= TFT.locate(165, 88); TFT.printf("ma"); // I= complit = 1; // прорисовали! TFT.fillrect(11,161,104,183,0x09E1); // подвал левый квадрат верхний заливка TFT.rect(10,160,105,232,0xECA7); // левый TFT.line(11,184,104,184,0xECA7); // левый разделительная линия вверхняя TFT.line(11,208,104,208,0xECA7); // левый разделительная линия нижняя TFT.rect(112,160,207,232,0xECA7); //средний рамка и линия TFT.line(113,195,206,195,0xECA7); TFT.rect(214,160,309,232,0xECA7); //правый рамка TFT.background(0x09E1); TFT.foreground(White); TFT.set_font((unsigned char*) Lucida13x21); TFT.locate(11, 209); TFT.printf(" 42 'C "); } //----------------------------------------------------------------------------- if (powerProtect==0 & pp==0) { // защита от кз TFT.fillrect(113,161,206,194,0x4208); TFT.background(0x4208); TFT.foreground(0xA514); TFT.set_font((unsigned char*) Lucida13x21); TFT.locate(113, 168); TFT.printf("Protect"); pp=1; } if (powerProtect==1 & pp==0) { TFT.fillrect(113,161,206,194,0x0180); TFT.background(0x0180); TFT.foreground(Green); TFT.set_font((unsigned char*) Lucida13x21); TFT.locate(113, 168); TFT.printf("Protect"); pp=1; } fps.reset(); fps.start(); TFT.background(Black); if (cc==1){ //если C.C то меняем цвет значения напряжения TFT.foreground(Red); }else{ TFT.foreground(Green); } TFT.set_font((unsigned char*) digi36x44); TFT.locate(10, 10); if(Ureal<0) Ureal=0; if (Ureal<9.995f){ TFT.fillrect(10,10,46,54,Black); TFT.locate(46, 10); TFT.printf("%4.2f", Ureal); // выводим значение с A0 (напряжение) }else{ TFT.locate(10, 10); TFT.printf("%5.2f", Ureal); // выводим значение с A0 (напряжение) } TFT.pixel(82, 53, Black); TFT.pixel(117, 53, Black); TFT.locate(10, 85); TFT.foreground(Green); TFT.printf("%04.0f", Ireal); // выводим значение с A1 (ток) TFT.background(0x2104); // выводим мощность TFT.foreground(0xE71C);//текст TFT.set_font((unsigned char*) Lucida13x21); TFT.locate(11, 162); TFT.printf("%05.2f W", Ureal*Ireal/1000); TFT.background(0x2104); // выводим время включеной нагрузки t.read() TFT.foreground(0xE71C);//текст TFT.set_font((unsigned char*) Lucida13x21); TFT.locate(11, 185); timeConvert(); TFT.printf("%02d:%02d:%02d", h, m, s); if (powerMosfet==0 & pb==0) { // выводим OFF TFT.background(0x4208); TFT.foreground(0xA514); TFT.fillrect(215,161,308,231,0x4208); TFT.set_font((unsigned char*) Consolas26x49); TFT.locate(226, 174); TFT.printf("OFF"); pb=1; } if (powerMosfet==1 & pb==0) { // выводим ON TFT.background(0x0339); TFT.foreground(Green); TFT.fillrect(215,161,308,231,0x0339);//0x0339 0x0180 TFT.set_font((unsigned char*) Consolas26x49); TFT.locate(237, 174); TFT.printf("ON"); pb=1; } int xscale1 = map(Ureal, 0, 25, 0, 298); if (xscale1>297) xscale1=298; TFT.fillrect(11, 63, (xscale1+10), 75, 0x3320); //0x04C9 // аналоговая шкала Напряжение TFT.fillrect((xscale1+12), 63, 308, 75, Black); int xscale2 = map(Ireal, 0, 2200, 0, 298); if (xscale2>297) xscale2=298; TFT.fillrect(11, 138, (xscale2+10), 150, 0x9A60); //0x9A60 // аналоговая шкала Ток TFT.fillrect((xscale2+12), 138, 308, 150, Black); fps.stop(); TFT.set_font((unsigned char*) Courier8x13); // FPS TFT.locate(140,205); printf("%0.2f", (1/fps.read())); if(cc==1 & pm==0){ // c.c TFT.fillrect(240,10,304,53,Black);//c.v стереть TFT.fillrect(240,85,304,128,0x6000);//c.c TFT.background(0x6000); TFT.foreground(Red); TFT.set_font((unsigned char*) Consolas19x35); TFT.locate(246, 89); TFT.printf("C.C"); pm=1; } if(cc==0 & pm==0){ // c.v TFT.fillrect(240,85,304,128,Black);//c.c стереть TFT.fillrect(240,10,304,53,0x0180);//c.v TFT.background(0x0180); TFT.foreground(Green); TFT.set_font((unsigned char*) Consolas19x35); TFT.locate(246, 14); TFT.printf("C.V"); pm=1; } } //------------------------------------------------------------------------------------------------------------ void drawScreen2(void) // экран 2 Data analo in, noise { if (complit==0) { TFT.background(back2); TFT.foreground(text2); TFT.cls(); complit = 1; // прорисовали! } TFT.background(back2); TFT.foreground(text2); TFT.set_font((unsigned char*) Courier8x13); TFT.locate(0, 0); printf("--------- Data Analog In --------- \n"); printf("U.real A0 noise= %0.2f, avg= %0.5f \n", noisea0, in0); printf("U= %06.4f coeff. k=%0.4f, a=%0.6f \n", Ureal, a0k, a0a); // A0 U real printf("---------------------------------- \n"); printf("I.real A1 noise= %0.2f, avg= %0.5f \n", noisea1, in1); printf("I= %06.2f coeff. k=%0.0d, a=%0.4f \n", Ireal, a1k, a1a); // A1 I real printf("---------------------------------- \n"); printf("U.set A2 noise= %0.2f, avg= %0.5f \n", noisea2, in2); printf("U= %06.3f coeff. k=%0.0f, a=%0.4f \n", Uset, a2k, a2a); // A2 U set printf("---------------------------------- \n"); printf("I.set A3 noise= %0.2f, avg= %0.5f \n", noisea3, in3); printf("I= %06.1f coeff. k=%0.0f, a=%0.4f \n", Iset, a3k, a3a); // A3 I set printf("---------------------------------- \n"); printf("U.usb A4 noise= %0.2f, avg= %0.5f \n", noisea4, in4); printf("U= %06.3f coeff. k=%0.0f, a=%0.4f \n", Uusb, a4k, a4a); // A4 U usb printf("---------------------------------- \n"); printf("I.usb A5 noise= %0.2f, avg= %0.5f \n", noisea5, in5); printf("I= %06.1f coeff. k=%0.0d, a=%0.4f \n", Iusb, a5k, a5a); // A5 I usb } //------------------------------------------------------------------------------------------------------------ void drawScreen3(void) // экран 3 установка часов { if (complit==0) { TFT.background(back5); TFT.foreground(text5); TFT.cls(); complit = 1; // прорисовали! } TFT.background(back5); TFT.foreground(text5); TFT.set_font((unsigned char*) Lucida13x21); char buffer[32]; seconds=time(NULL); strftime(buffer, 32, "%H:%M:%S %d.%m.%Y", localtime(&seconds)); TFT.locate (0,0); printf("------- Set Time --------\n"); TFT.background(back5_i); TFT.foreground(text5_i); TFT.locate (30,25); printf("%s", buffer); //вывод реального времени TFT.background(back5); TFT.foreground(text5); TFT.locate (28,86); printf("%02d:%02d:%02d %02d.%02d.%04d",hour, min, sec, day, mon, year); //вывод то что установим //-----------------------------------1 if (nline==1) { if (pmenu==1) { TFT.background(back5_iset); TFT.foreground(text5_i); } else { TFT.background(back5_i); TFT.foreground(text5_i); } TFT.locate(28,64); printf(" "); } else { TFT.locate(28,64); TFT.background(back5); TFT.foreground(back5); printf(" "); } //-----------------------------------2 if (nline==2) { if (pmenu==1) { TFT.background(back5_iset); TFT.foreground(text5_i); } else { TFT.background(back5_i); TFT.foreground(text5_i); } TFT.locate(64,64); printf(" "); } else { TFT.locate(64,64); TFT.background(back5); TFT.foreground(back5); printf(" "); } //-----------------------------------3 if (nline==3) { if (pmenu==1) { TFT.background(back5_iset); TFT.foreground(text5_i); } else { TFT.background(back5_i); TFT.foreground(text5_i); } TFT.locate(100,64); printf(" "); } else { TFT.locate(100,64); TFT.background(back5); TFT.foreground(back5); printf(" "); } //-----------------------------------4 if (nline==4) { if (pmenu==1) { TFT.background(back5_iset); TFT.foreground(text5_i); } else { TFT.background(back5_i); TFT.foreground(text5_i); } TFT.locate(135,64); printf(" "); } else { TFT.locate(135,64); TFT.background(back5); TFT.foreground(back5); printf(" "); } //-----------------------------------5 if (nline==5) { if (pmenu==1) { TFT.background(back5_iset); TFT.foreground(text5_i); } else { TFT.background(back5_i); TFT.foreground(text5_i); } TFT.locate(170,64); printf(" "); } else { TFT.locate(170,64); TFT.background(back5); TFT.foreground(back5); printf(" "); } //-----------------------------------6 if (nline==6) { if (pmenu==1) { TFT.background(back5_iset); TFT.foreground(text5_i); } else { TFT.background(back5_i); TFT.foreground(text5_i); } TFT.locate(205,64); printf(" "); } else { TFT.locate(205,64); TFT.background(back5); TFT.foreground(back5); printf(" "); } //-----------------------------------7 if (nline==7) { if (pmenu==1) { TFT.background(back5_iset); TFT.foreground(text5_i); } else { TFT.background(back5_i); TFT.foreground(text5_i); } TFT.locate(30,120); printf("Set!"); } else { TFT.locate(30,120); TFT.background(back5); TFT.foreground(text5); printf("Set!"); } //----------------------------------- //-----------------------------------7 if (nline==8) { if (pmenu==1) { TFT.background(back5_iset); TFT.foreground(text5_i); } else { TFT.background(0xFB2C); TFT.foreground(text5_i); } TFT.locate(30,170); printf("Exit"); } else { TFT.locate(30,170); TFT.background(back5); TFT.foreground(text5); printf("Exit"); } //----------------------------------- } //------------------------------------------------------------------------------------------------------------ void drawScreen4(void) // экран 4 калибровка { if (complit==0) { TFT.background(back4); TFT.foreground(text4); TFT.cls(); complit = 1; // прорисовали! } //---------------------------------------------------------------- text4 back4 text4_i back4_i TFT.background(back4); TFT.foreground(text4); TFT.locate(0, 0); TFT.set_font((unsigned char*) Courier8x13); printf(" Calibration. Enter - set. \n"); printf("--------------------------- \n"); //---------------------------------------------------------------- if (kline==1) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" U real = %06.3f set zero \n", Ureal); // U real A0 zero //---------------------------------------------------------------- if (kline==2) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" U real = %06.3f set up dot \n", Ureal); // U real A0 hi //---------------------------------------------------------------- if (kline==3) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" I real = %06.1f set zero \n", Ireal); // I real A1 zero //---------------------------------------------------------------- if (kline==4) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" I real = %06.1f set up dot \n", Ireal); // I real A1 hi //---------------------------------------------------------------- if (kline==5) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" U set = %06.3f set zero \n", Uset); // U set A2 zero //---------------------------------------------------------------- if (kline==6) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" U set = %06.3f set up dot \n", Uset); // U set A2 hi //---------------------------------------------------------------- if (kline==7) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" I set = %06.1f set zero \n", Iset); // I set A3 zero //---------------------------------------------------------------- if (kline==8) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" I set = %06.1f set up dot \n",Iset); // I set A3 hi //---------------------------------------------------------------- if (kline==9) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" U usb = %06.3f set up dot \n", Uusb); // U usb A4 zero //---------------------------------------------------------------- if (kline==10) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" U usb = %06.3f set zero \n", Uusb); // U usb A4 hi //---------------------------------------------------------------- if (kline==11) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" I usb = %06.1f set up dot \n", Iusb); // I usb A5 zero //---------------------------------------------------------------- if (kline==12) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" I usb = %06.1f set up dot \n", Iusb); // I usb A5 hi //---------------------------------------------------------------- if (kline==13) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" Load Default \n"); //---------------------------------------------------------------- if (kline==14) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" Save all to flash memory \n"); //---------------------------------------------------------------- if (kline==15) { TFT.background(back4_i); TFT.foreground(text4_i); } else { TFT.background(back4); TFT.foreground(text4); } printf(" Exit \n"); //---------------------------------------------------------------- TFT.background(back4); TFT.foreground(text4); printf("--------------------------- \n"); } //------------------------------------------------------------------------------------------------------------ void drawScreen5(void) //экран 5 Настройки главная { if (complit==0) { TFT.background(back5); TFT.foreground(text5); TFT.cls(); complit = 1; // прорисовали! } //---------------------------------------------------------------- TFT.background(back5); TFT.foreground(text5); TFT.locate(0, 0); TFT.set_font((unsigned char*) Courier8x13); printf(" Settings \n"); printf("--------------------------- \n"); //---------------------------------------------------------------- if (mline==1) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" Set Time \n"); // 1 //---------------------------------------------------------------- if (mline==2) { if (pmenu==1) { TFT.background(back5_iset); TFT.foreground(text5_i); } else { TFT.background(back5_i); TFT.foreground(text5_i); } } else { TFT.background(back5); TFT.foreground(text5); } printf(" Backlight brightness = %03.0f \n", brightness*100); // 1 //------------------------------------*--------------------------- if (mline==3) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" Sound beep \n"); // 1 //------------------------------------*--------------------------- if (mline==4) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" Screen saver \n"); // 1 //------------------------------------*--------------------------- if (mline==5) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" Fan start - t 'c \n"); // 1 //------------------------------------*--------------------------- if (mline==6) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" Fan full speed - t 'c \n"); // 1 //------------------------------------*--------------------------- if (mline==7) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" Voltmeter adjustment on R \n"); // 1 //------------------------------------*--------------------------- if (mline==8) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" Current sense shunt, R om \n"); // 1 //------- -----------------------------*--------------------------- if (mline==9) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" Calibration I, U \n"); // 1 //------------------------------------*--------------------------- if (mline==10) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" Data analog in, noise \n"); // 1 //------------------------------------*--------------------------- if (mline==11) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" U max \n"); // 1 //------------------------------------*--------------------------- if (mline==12) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" 1 \n"); // 1 //------------------------------------*--------------------------- if (mline==13) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" 1 \n"); // 1 //------------------------------------*--------------------------- if (mline==14) { TFT.background(back5_i); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf("pmenu=%d, mline2=%d, mline=%d \n", pmenu, mline2, mline); // 1 //------------------------------------*--------------------------- if (mline==15) { TFT.background(0xFB2C); TFT.foreground(text5_i); } else { TFT.background(back5); TFT.foreground(text5); } printf(" Exit \n"); //--------------------------------------*------------------------- TFT.background(back5); TFT.foreground(text5); printf("--------------------------- \n"); } //------------------------------------------------------------------------------------------------------------ void drawScreen6(void) //экран 6 { if (complit==0) { TFT.background(Blue); TFT.foreground(Black); TFT.cls(); complit = 1; // прорисовали! } } //------------------------------------------------------------------------------------------------------------ void drawScreen7(void) //экран 7 { if (complit==0) { TFT.background(Blue); TFT.foreground(Black); TFT.cls(); complit = 1; // прорисовали! } } //------------------------------------------------------------------------------------------------------------ void drawScreen8(void) //экран 8 { if (complit==0) { TFT.background(Blue); TFT.foreground(Black); TFT.cls(); complit = 1; // прорисовали! } } //------------------------------------------------------------------------------------------------------------ float map(float x, float in_min, float in_max, float out_min, float out_max) // функция масштабирования { return (x - in_min) * (out_max - out_min) / (in_max - in_min) + out_min; } //------------------------------------------------------------------------------------------------------------ float avgAin0() // функция среднего значения с входа A0 { int m = 100; float value[m]; float max; float min; double itg; max = itg = 0.0; min = 3.3; for (int i=0; i<m; i++) { value[i] = ainA0; if (value[i] > max) max = value[i]; if (value[i] < min) min = value[i]; itg += value[i]; } noisea0 = (max - min)*1000; return itg/m; } //------------------------------------------------------------------------------------------------------------ float avgAin1() // функция среднего значения с входа A1 { float value[100]; float max; float min; double itg; max = itg = 0.0; min = 3.3; for (int i=0; i<100; i++) { value[i] = ainA1; if (value[i] > max) max = value[i]; if (value[i] < min) min = value[i]; itg += value[i]; } noisea1 = (max - min)*1000; return itg/100; } //------------------------------------------------------------------------------------------------------------ float avgAin2() // функция среднего значения с входа A2 { float value[100]; float max; float min; double itg; max = itg = 0.0; min = 3.3; for (int i=0; i<100; i++) { value[i] = ainA2; if (value[i] > max) max = value[i]; if (value[i] < min) min = value[i]; itg += value[i]; } noisea2 = (max - min)*1000; return itg/100; } //------------------------------------------------------------------------------------------------------------ float avgAin3() // функция среднего значения с входа A3 { float value[100]; float max; float min; double itg; max = itg = 0.0; min = 3.3; for (int i=0; i<100; i++) { value[i] = ainA3; if (value[i] > max) max = value[i]; if (value[i] < min) min = value[i]; itg += value[i]; } noisea3 = (max - min)*1000; return itg/100; } //------------------------------------------------------------------------------------------------------------ float avgAin4() // функция среднего значения с входа A4 { float value[100]; float max; float min; double itg; max = itg = 0.0; min = 3.3; for (int i=0; i<100; i++) { value[i] = ainA4; if (value[i] > max) max = value[i]; if (value[i] < min) min = value[i]; itg += value[i]; } noisea4 = (max - min)*1000; return itg/100; } //------------------------------------------------------------------------------------------------------------ float avgAin5() // функция среднего значения с входа A5 { float value[100]; float max; float min; double itg; max = itg = 0.0; min = 3.3; for (int i=0; i<100; i++) { value[i] = ainA5; if (value[i] > max) max = value[i]; if (value[i] < min) min = value[i]; itg += value[i]; } noisea5 = (max - min)*1000; return itg/100; } /*/------------------------------------------------------------------------------------------------------------ void drawMainScale(void) { a int a = avg*1000; b = mapIOIO(c, 0, 100, 0, 220); TFT.fillrect(10, 10, (b+10), 20, Red); // аналоговая шкала 1 TFT.fillrect((b+10), 10, 230, 20, Black); } //------------------------------------------------------------------------------------------------------------*/ void powerButton(void) // при нажатии кнопки питания { powerMosfet=!powerMosfet; if (powerMosfet==1) { tstart = treal = time(NULL); h=m=s=0; } if (powerMosfet==0) { } pb=0; } //------------------------------------------------------------------------------------------------------------ void dataProcessing(void) // обработка и подготовка данных с аналоговых входов { /*t.reset();// FPS t.start();// FPS*/ in0 = avgAin0(); in1 = avgAin1(); in2 = avgAin2(); in3 = avgAin3(); in4 = avgAin4(); in5 = avgAin5(); // A0 U real U = (avgAin0() - a0a) * a0k // A1 I real I = (avgAin1() - a1a) * a1k // A2 U set U = (avgAin2() - a2a) * a2k // A3 I set I = (avgAin3() - a3a) * a3k // A4 U usb U = (avgAin4() - a4a) * a4k // A5 I usb I = (avgAin5() - a5a) * a5k Ureal = a0k*(in0-a0a); Ireal = a1k*(in1-a1a); Uset = a2k*(in2-a2a); Iset = a3k*(in3-a3a); Uusb = a4k*(in4-a4a); Iusb = a5k*(in5-a5a); /*t.stop();// FPS TFT.background(Black);// FPS TFT.foreground(Green);// FPS TFT.set_font((unsigned char*) Courier8x13);// FPS TFT.locate(260,225);// FPS TFT.printf("%0.2f", (1/t.read()));// FPS*/ } //------------------------------------------------------------------------------------------------------------ void buttonUse(void) // обработка нажатий кнопок { int one=0; // для обработки одной кнопки за раз //------------------------------------------------------------------ if (Screen==1 & one==0) { //главный экран if (buttonEnter==0) { // Enter //wait(1); Screen=5; // 5 главная настройки complit=0; } if (buttonDown==0) { // Down Screen=3; // 2 complit=0; } if (buttonUp==0) { // Up powerProtect=!powerProtect; cc=!cc; // для проверки pm=0; // С.C и C.V pp=0; wait(0.2); } one=1; } //------------------------------------------------------------------ if (Screen==2 & one==0) { //экран 2 analog in, noise if (buttonEnter==0) { // Enter //wait(1); Screen=5; //3 complit=0; } one=1; } //------------------------------------------------------------------ if (Screen==3 & one==0) { //экран 3 if(nline==7 & pmenu==1){ wait(0.2); pmenu=0; } if (buttonEnter==0 & pmenu==0) { // Enter pmenu=1; wait(0.2); if(nline==7){ mon=mon-1; SetDateTime(); mon=mon+1; } if(nline==8){ pmenu=0; Screen=5; complit=0; } } if (buttonUp==0 & pmenu==0) { // Up nline--; wait(0.2); if (nline==0) nline=8; } if (buttonDown==0 & pmenu==0) { // Down nline++; wait(0.2); if (nline==9) nline=1; } if (pmenu==1) { if (buttonEnter==0) { pmenu=0; wait(0.2); } if (buttonUp==0) { if (nline==1) { hour++; wait(0.1); } if (nline==2) { min++; wait(0.1); } if (nline==3) { sec++; wait(0.1); } if (nline==4) { day++; wait(0.1); } if (nline==5) { mon++; wait(0.1); } if (nline==6) { year++; wait(0.1); } } if (buttonDown==0) { if (nline==1) { hour--; wait(0.1); } if (nline==2) { min--; wait(0.1); } if (nline==3) { sec--; wait(0.1); } if (nline==4) { day--; wait(0.1); } if (nline==5) { mon--; wait(0.1); } if (nline==6) { year--; wait(0.1); } } one=1; } } //------------------------------------------------------------------ if (Screen==4 & one==0) { //экран меню Калибровка if (buttonEnter==0) { // Enter set! if (kline==1) a0a = in0 - 0.0001f; if (kline==2) a0k = 20/(in0-a0a); if (kline==3) Screen=5; if (kline==4) Screen=5; if (kline==5) Screen=5; if (kline==6) Screen=5; if (kline==7) Screen=5; if (kline==8) Screen=5; if (kline==9) Screen=5; if (kline==10) Screen=5; if (kline==11) Screen=5; if (kline==12) Screen=5; if (kline==13) Screen=5; if (kline==14) Screen=5; if (kline==15) Screen=5; complit=0; } if (buttonUp==0) { // Up kline--; //- if (kline==0) kline=15; } if (buttonDown==0) { // Down kline++; //+ if (kline==16) kline=1; } one=1; } //------------------------------------------------------------------ if (Screen==5 & one==0) { //экран 5 Настройки главная------------------------------------------------------- if (buttonEnter==0 & pmenu==0) { // Enter if (mline==1) { Screen=3; complit=0; } if (mline==2) { mline2=1; pmenu=1; one=1; wait(0.2); } if (mline==3) Screen=1; if (mline==4) Screen=1; if (mline==5) Screen=1; if (mline==6) Screen=1; if (mline==7) Screen=1; if (mline==8) Screen=1; if (mline==9) { // меню калибровки Screen=4; complit=0; } if (mline==10) { // меню analog in, noise Screen=2; complit=0; } if (mline==11) Screen=1; if (mline==12) Screen=1; if (mline==13) Screen=1; if (mline==14) Screen=1; if (mline==15) { Screen=1; complit=0; } } if (buttonUp==0 & pmenu==0) { // Up mline--; //- if (mline==0) mline=15; } if (buttonDown==0 & pmenu==0) { // Down mline++; //+ if (mline==16) mline=1; } //---------подменю яркость подсветки if (mline2==1) { int i=0; if (buttonUp==0 & brightness<1) { if(brightness >= 0.09f & i==0) { brightness+=0.1f; pinbrightness=brightness; i=1; } if(brightness < 0.09f & i==0) { brightness+=0.01f; pinbrightness=brightness; i=1; } } if (buttonDown==0 & brightness>0.01f) { if(brightness <= 0.1f & i==0) { brightness-=0.01f; pinbrightness=brightness; i=1; } if(brightness > 0.1f & i==0) { brightness-=0.1f; pinbrightness=brightness; i=1; } } if (buttonEnter==0) { mline2=0; pmenu=0; } } //------------------------------------ one=1; } //------------------------------------------------------------------ if (Screen==6 & one==0) { //экран 6 if (buttonEnter==0) { // Enter } if (buttonUp==0) { // Up } if (buttonDown==0) { // Down } one=1; } //------------------------------------------------------------------ if (Screen==7 & one==0) { //экран 7 if (buttonEnter==0) { // Enter } if (buttonUp==0) { // Up } if (buttonDown==0) { // Down } one=1; } //------------------------------------------------------------------ if (Screen==8 & one==0) { //экран 8 if (buttonEnter==0) { // Enter } if (buttonUp==0) { // Up } if (buttonDown==0) { // Down } one=1; } //------------------------------------------------------------------ } //------------------------------------------------------------------------------------------------------------ void grid(void) { TFT.cls(); for (int i=0; i<240; i=i+5) { TFT.line(0,i,320,i, White); } for (int i=2; i<240; i=i+5) { TFT.line(4,i,320,i, White); } for (int i=3; i<240; i=i+5) { TFT.line(4,i,320,i, White); } } //------------------------------------------------------------------------------------------------------------ void timeConvert(void) //показывает час с минуты с секундами начинают идти с часа и одной минуты { if (powerMosfet==1) treal = time(NULL); t = treal - tstart; h= t/3600; m= (t-h*3600)/60; s= (t-h*3600)-m*60; if (t == 359999) tstart=treal; } //------------------------------------------------------------------------------------------------------------ void SetDateTime (void) { struct tm Clock; Clock.tm_year = year - 1900; Clock.tm_mon = mon; Clock.tm_mday = day; Clock.tm_hour = hour; Clock.tm_min = min; Clock.tm_sec = sec; time_t epoch = mktime(&Clock); set_time(epoch); } //------------------------------------------------------------------------------------------------------------