Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
Dependencies: TS_DISCO_F746NG mbed LCD_DISCO_F746NG BSP_DISCO_F746NG lvgl_RB FastPWM millis
Diff: main.cpp
- Revision:
- 0:cf6b1eca3e67
- Child:
- 1:404ee28a0b60
--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/main.cpp Wed Jan 15 19:23:14 2020 +0000
@@ -0,0 +1,1319 @@
+#include "mbed.h"
+#include "TS_DISCO_F746NG.h"
+#include "LCD_DISCO_F746NG.h"
+#include "lvgl/lvgl.h"
+#include "lv_conf.h"
+#include "millis.h"
+#include "FastPWM.h"
+#include <string>
+
+Ticker ticker; //Initialize system tick
+LCD_DISCO_F746NG lcd; //Initialize display driver
+TS_DISCO_F746NG ts; //Initialize touchpad driver
+TS_StateTypeDef TS_State; //Initialize touch state sctruct
+
+Serial serial(USBTX, USBRX);
+
+/*********************
+ * ENTREES SORTIES
+ *********************/
+//TENSION BATTERIE
+AnalogIn AI_TENSION_BAT(A4);
+
+//PWM
+FastPWM fastpwm(D12,1); //steup pwm output on pin d12 with a prescaler of 1
+
+//COMPTEUR IMPULSION
+DigitalIn DI_CPTPuls(D7);
+//InterruptIn DI_CPTPuls(D7); //
+
+/**********************
+ * VARIABLES GENERALES
+ **********************/
+int X;
+int Y;
+Timer tempo;
+bool Top1ms;
+bool Top10ms;
+bool Top100ms;
+bool Top1s;
+bool Top5s;
+bool Top1min;
+char text[100];
+char text2[100];
+int Langue=1;
+char* Message(int Num);
+
+float TensionBat;
+float MoyTensBat[101];
+int CsgPompe=0;
+
+uint64_t Micros=0;
+uint64_t CalcTpsCy=0;
+float TpsCy=0;
+
+uint64_t MemMicros0=0;
+uint64_t MemMicros1=0;
+uint64_t MemMicros2=0;
+uint64_t MemMicros3=0;
+uint64_t MemMicros4=0;
+uint64_t MemMicros5=0;
+
+
+int CalcFmPuls;
+int CalcFdPuls;
+bool FmCPTPuls;
+uint64_t TimerPuls=0;
+uint64_t TpsPuls=0;
+float Calcul=0;
+uint64_t MemTpsPuls=0;
+uint64_t MemTps16Puls=0;
+int NumDent=0;
+uint64_t CptPuls=0;
+uint64_t CalcDebit=0;
+float Debit;
+float TpsEntre2Puls[20];
+float TpsMinEntre2Puls;
+float TpsMaxEntre2Puls;
+float Volume;
+float VolParTour=1200;//en ml
+
+int hres = 480;
+int vres = 272;
+
+
+uint64_t test=0;
+
+//VARIABLES GESTION MOT DE PASSE
+
+
+/*********************
+ * OBJET PAGES
+ *********************/
+static lv_obj_t * BandeauHaut;
+static void AFFBandeauHaut(int Num);
+static lv_obj_t * SousMenu;
+static void AFFSousMenu(int Num);
+static lv_obj_t * Page;
+static void AFFPage(int Num);
+
+static lv_obj_t * PopupMDP;
+static void AFFPopupMDP();
+
+static void init_all_themes(uint16_t hue);
+
+/*********************
+ * OBJET GENERAUX
+ *********************/
+static lv_obj_t *mbox;
+
+/*****************************
+ * VARIABLES/OBJETS CONNEXION
+ *****************************/
+static lv_obj_t * SelectID;
+static lv_obj_t * MDP;
+static void SelectID_ACT(lv_obj_t * obj, lv_event_t event);
+uint32_t TpsMdpEnCours=0;
+struct Personne
+{
+ string Nom;
+ string MDP; //mot de passe à 4 chiffres
+ int Niveau; //0:aucun 1:Opérateur 2:superviseur 3:constructeur
+ int Tps; //Temps de connexion
+};
+Personne User[100];
+Personne UserEC;
+static void BpValidMDP_ACT(lv_obj_t * btn, lv_event_t event);
+static void BpAnnulMDP_ACT(lv_obj_t * btn, lv_event_t event);
+static void mboxMdp_ACT(lv_obj_t * btn, lv_event_t event);
+static void mboxMdp_ACT2(lv_obj_t * btn, lv_event_t event);
+
+/*********************
+ * OBJETS BP MENU
+ *********************/
+static lv_obj_t * M100;
+static lv_obj_t * M200;
+static lv_obj_t * M300;
+static lv_obj_t * M400;
+static lv_obj_t * M500;
+static lv_obj_t * M600;
+
+static lv_obj_t * SM101;
+static lv_obj_t * SM102;
+static lv_obj_t * SM103;
+static lv_obj_t * SM104;
+static lv_obj_t * SM105;
+static lv_obj_t * SM106;
+
+static lv_obj_t * SM201;
+static lv_obj_t * SM202;
+static lv_obj_t * SM203;
+static lv_obj_t * SM204;
+static lv_obj_t * SM205;
+static lv_obj_t * SM206;
+
+//FONCTIONS ASSOCIEES
+static void M100_ACT(lv_obj_t * btn, lv_event_t event);
+static void M200_ACT(lv_obj_t * btn, lv_event_t event);
+static void M300_ACT(lv_obj_t * btn, lv_event_t event);
+static void M400_ACT(lv_obj_t * btn, lv_event_t event);
+static void M500_ACT(lv_obj_t * btn, lv_event_t event);
+static void M600_ACT(lv_obj_t * btn, lv_event_t event);
+
+static void SM101_ACT(lv_obj_t * btn, lv_event_t event);
+static void SM102_ACT(lv_obj_t * btn, lv_event_t event);
+static void SM103_ACT(lv_obj_t * btn, lv_event_t event);
+static void SM104_ACT(lv_obj_t * btn, lv_event_t event);
+static void SM105_ACT(lv_obj_t * btn, lv_event_t event);
+
+static void SM201_ACT(lv_obj_t * btn, lv_event_t event);
+static void SM202_ACT(lv_obj_t * btn, lv_event_t event);
+static void SM203_ACT(lv_obj_t * btn, lv_event_t event);
+static void SM204_ACT(lv_obj_t * btn, lv_event_t event);
+static void SM205_ACT(lv_obj_t * btn, lv_event_t event);
+
+/*********************
+ * OBJETS
+ *********************/
+static lv_obj_t *FondGris ;
+static lv_obj_t *FondGris2 ;
+
+/*********************
+ * MATRICE DE BOUTONS
+ *********************/
+static const char * PAVE_NUMERIQUE_MAP[] = {"7", "8", "9","\n",
+ "4", "5","6", "\n",
+ "1", "2", "3","\n",
+ "0", LV_SYMBOL_BACKSPACE, ""};
+/*********************
+ * STYLES
+ *********************/
+static lv_style_t Style_texte1;
+static lv_style_t Style_texte2;
+static lv_style_t Style_BPM;
+static lv_style_t Style_BPSM;
+static lv_style_t Style_BPSMInactif;
+static lv_style_t Style_BP;
+
+
+
+/*********************
+ * FONCTION
+ *********************/
+void initialisation();
+void interruptCompteur();
+
+static void BPRAZ_ACT(lv_obj_t * btn, lv_event_t event);
+static lv_theme_t * th_act;
+static lv_obj_t * label;
+static lv_obj_t * label1;
+
+
+static lv_obj_t * AffTensionBat;
+static lv_obj_t * AffTpsCy;
+static lv_obj_t * AffCptPuls;
+static lv_obj_t * AffDebit;
+static lv_obj_t * Aff1TpsEntre2Puls;
+static lv_obj_t * Aff2TpsEntre2Puls;
+static lv_obj_t * AffTpsMinEntre2Puls;
+static lv_obj_t * AffTpsMaxEntre2Puls;
+static lv_obj_t * AffVolume;
+static lv_obj_t * BPRAZ;
+
+uint8_t NumSousMenu=1;
+
+LV_FONT_DECLARE(arial_20) //Declare a font
+
+void lv_ticker_func();
+void my_disp_flush(lv_disp_drv_t* disp_drv, const lv_area_t* area, lv_color_t* color_p);
+bool my_touchpad_read(lv_indev_drv_t * indev_driver, lv_indev_data_t * data);
+static void event_handler(lv_obj_t * obj, lv_event_t event);
+//void btn_event_cb(lv_obj_t * btn, lv_event_t event);
+
+
+
+static void ddlist_event_cb(lv_obj_t * ddlist, lv_event_t event);
+static lv_obj_t * slider;
+
+int PosX_MenuDepart = 0;
+int PosX_MenuCible = 0;
+bool DdeAlignMenu = 0;
+
+int PosY_AnimSousMenu = 0;
+int AnimSousMenu=0;
+int TpsAvFermSousMenu=2000;
+bool SousMenuActif;
+
+static void Reglage_R_RGB(lv_obj_t * obj, lv_event_t event);
+
+int TestAff = 0;
+
+
+static lv_obj_t * Val_R;
+
+static lv_obj_t * R;
+
+
+int Reglage_R;
+uint8_t Reglage_G;
+uint8_t Reglage_B;
+uint32_t Reglage_RGB;
+
+
+uint8_t R1=255,G1=255,B1=255,
+ R2=0 ,G2=0 ,B2=0,
+ R3=255 ,G3=255 ,B3=255,
+ R4=0,G4=0,B4=0,
+ R5=145,G5=145,B5=145,
+ R6=255,G6=255,B6=255,
+ R7=0,G7=0,B7=0,
+ R8=73,G8=143,B8=64,
+ R9=0,G9=255,B9=0,
+ R10=155,G10=238,B10=131,
+ R11=145,G11=145,B11=145,
+ R12=51,G12=37,B12=22,
+ R13=255,G13=255,B13=255,
+ R14=153,G14=158,B14=117,
+ R15=107,G15=154,B15=199,
+ R16=107,G16=154,B16=199,
+ R17=107,G17=154,B17=199,
+ R18=107,G18=154,B18=199,
+ R19=107,G19=154,B19=199;
+
+
+int NumCouleur=0;
+
+lv_obj_t * th_roller ;
+
+
+
+static const char * th_options = {
+#if LV_USE_THEME_DEFAULT
+ "Default"
+#endif
+
+#if LV_USE_THEME_NIGHT
+ "\nNight"
+#endif
+
+#if LV_USE_THEME_MATERIAL
+ "\nMaterial"
+#endif
+
+#if LV_USE_THEME_ALIEN
+ "\nAlien"
+#endif
+
+#if LV_USE_THEME_ZEN
+ "\nZen"
+#endif
+
+#if LV_USE_THEME_NEMO
+ "\nNemo"
+#endif
+
+#if LV_USE_THEME_MONO
+ "\nMono"
+#endif
+
+
+ ""
+};
+
+static lv_theme_t * themes[8];
+
+
+int main()
+{
+ //demarrage communication avec PC
+ serial.baud(9600);
+ serial.printf("DEBUT DE PROGRAMME\r\n");
+ //Entree impulsion
+ DI_CPTPuls.mode(PullUp);
+
+ //lcd.DisplayStringAt(0, LINE(5), (uint8_t *)"LittlevGL DEMO", CENTER_MODE);
+ ticker.attach(&lv_ticker_func,0.005);// Appel de la fonction LittlVGL toutes les 5ms
+ wait(0.5);
+ lv_init(); //Initialize the LittlevGL
+
+ static lv_disp_buf_t disp_buf;
+ static lv_color_t buf[LV_HOR_RES_MAX * 10]; //Declare a buffer for 10 lines
+ lv_disp_buf_init(&disp_buf, buf, NULL, LV_HOR_RES_MAX * 10); //Initialize the display buffer
+
+ //Implement and register a function which can copy a pixel array to an area of your display
+ lv_disp_drv_t disp_drv; //Descriptor of a display driver
+ lv_disp_drv_init(&disp_drv); //Basic initialization
+ disp_drv.flush_cb = my_disp_flush; //Set your driver function
+ disp_drv.buffer = &disp_buf; //Assign the buffer to the display
+ lv_disp_drv_register(&disp_drv); //Finally register the driver
+
+ //Implement and register a function which can read an input device. E.g. for a touch pad
+ ts.Init(lcd.GetXSize(), lcd.GetYSize()); //ST touch initialization
+ lv_indev_drv_t indev_drv; //Descriptor of a input device driver
+ lv_indev_drv_init(&indev_drv); //Basic initialization
+ indev_drv.type = LV_INDEV_TYPE_POINTER; //Touch pad is a pointer-like device
+ indev_drv.read_cb = my_touchpad_read; //Set your driver function
+ lv_indev_drv_register(&indev_drv); //Finally register the driver
+
+
+ initialisation();
+ AFFBandeauHaut(0);
+ AFFPage(0);
+
+ //demarrage tempo générale
+ tempo.start();
+ //Interruption compteur
+ // DI_CPTPuls.rise(&interruptCompteur);
+
+ while(1) {
+
+ //TEMPO GENERALE
+ Micros=tempo.read_high_resolution_us();
+ //TOP base de temps
+ Top1ms=false; if (Micros>=MemMicros0+1000) { Top1ms=true; MemMicros0=MemMicros0+1000; }
+ Top10ms=false; if (Micros>=MemMicros1+10000) { Top10ms=true; MemMicros1=MemMicros1+10000; }
+ Top100ms=false; if (Micros>=MemMicros2+100000) { Top100ms=true; MemMicros2=MemMicros2+100000; }
+ Top1s=false; if (Micros>=MemMicros3+1000000) { Top1s=true; MemMicros3=MemMicros3+1000000; }
+ Top5s=false; if (Micros>=MemMicros4+5000000) { Top5s=true; MemMicros4=MemMicros4+5000000; }
+ Top1min=false; if (Micros>=MemMicros5+60000000) { Top1min=true; MemMicros5=MemMicros5+60000000; }
+
+ //CALCUL TEMPS DE CYCLE
+ CalcTpsCy++;
+ if (Top1s){
+ TpsCy=1000000000/CalcTpsCy;
+ TpsCy=TpsCy/1000;
+ test=CalcTpsCy;
+ CalcTpsCy=0;
+ }
+ //Raffraichissement affichage toutes les 10ms
+ if (Top10ms){
+ lv_task_handler();
+ }
+
+ //MISE A JOUR DES VARIABLES AFFICHEES
+ if (Top1s){
+ // serial.printf("MICROS %d \r\n",Micros);
+ sprintf(text, "Temps de cycle = %3.3f us",TpsCy); lv_label_set_text(AffTpsCy, text);
+ sprintf(text, "Tension= %3.3f V ",TensionBat ); lv_label_set_text(AffTensionBat, text);
+ sprintf(text, "Nombre d'impulsion= %d ",CptPuls ); lv_label_set_text(AffCptPuls, text);
+ sprintf(text, "Volume = %3.3f L",Volume ); lv_label_set_text(AffVolume, text);
+ sprintf(text, "Debit= %3.3f L/min ",Debit ); lv_label_set_text(AffDebit, text);
+ sprintf(text, "%3.0f / %3.0f / %3.0f / %3.0f / %3.0f / %3.0f / %3.0f / %3.0f ",TpsEntre2Puls[1],TpsEntre2Puls[2],TpsEntre2Puls[3],TpsEntre2Puls[4],TpsEntre2Puls[5],TpsEntre2Puls[6],TpsEntre2Puls[7],TpsEntre2Puls[8]); lv_label_set_text(Aff1TpsEntre2Puls, text);
+ sprintf(text, "%3.0f / %3.0f / %3.0f / %3.0f / %3.0f / %3.0f / %3.0f / %3.0f ",TpsEntre2Puls[9],TpsEntre2Puls[10],TpsEntre2Puls[11],TpsEntre2Puls[12],TpsEntre2Puls[13],TpsEntre2Puls[14],TpsEntre2Puls[15],TpsEntre2Puls[16]); lv_label_set_text(Aff2TpsEntre2Puls, text);
+ sprintf(text, "Temps mini entre 2 impulsions = %d ",Micros ); lv_label_set_text(AffTpsMinEntre2Puls, text);
+ sprintf(text, "Temps maxi entre 2 impulsions = %d",test ); lv_label_set_text(AffTpsMaxEntre2Puls, text);
+ }
+
+ //DETECTION IMPULSION
+ if (DI_CPTPuls and Top1ms){ CalcFdPuls=0;CalcFmPuls++;}
+ if (not DI_CPTPuls and Top1ms){ CalcFmPuls=0;CalcFdPuls++;}
+ if (CalcFmPuls>20 and not FmCPTPuls){interruptCompteur();FmCPTPuls=true;}
+ if (CalcFdPuls>20 and FmCPTPuls){FmCPTPuls=false;}
+ if (CalcFmPuls>500){CalcFmPuls=500;}
+ if (CalcFdPuls>500){CalcFdPuls=500;}
+
+ //MESURE TENSION BATTERIE
+ if (Top10ms){
+ MoyTensBat[0]=AI_TENSION_BAT.read()*3.3*2;
+ TensionBat=0;
+ for (int i=100;i>0;i--){
+ MoyTensBat[i]=MoyTensBat[i-1];
+ TensionBat=TensionBat+MoyTensBat[i];
+ }
+ TensionBat=TensionBat/100;
+ }
+
+ //COMMANDE POMPE PWM
+ if (Top100ms){
+ CsgPompe=Reglage_R;
+ fastpwm.period_ticks (10000); //setup the period for 100Khz
+ fastpwm.pulsewidth_ticks(CsgPompe);//setup duty cycle to 50%
+ }
+ //RAZ MOT DE PASSE
+ if (TpsMdpEnCours>0 and Top1s){
+ TpsMdpEnCours--;
+ if (TpsMdpEnCours==0){
+ mbox=lv_mbox_create(lv_disp_get_scr_act(NULL), NULL);
+ sprintf(text, "Fin de connexion pour %s",UserEC.Nom );
+ lv_mbox_set_text(mbox, text);
+ lv_obj_align(mbox, NULL, LV_ALIGN_CENTER, 0, 0);
+ lv_mbox_start_auto_close(mbox, 3000);
+ UserEC.Nom="";
+ UserEC.Niveau=0;
+ }
+ }
+
+ //ANIMATION MENU
+ if (Top1ms){
+ if (DdeAlignMenu) {
+ if (PosX_MenuDepart>PosX_MenuCible) {
+ PosX_MenuDepart=PosX_MenuDepart-1;
+ lv_obj_set_pos(BandeauHaut, PosX_MenuDepart, 0);
+ }
+ if (PosX_MenuDepart<PosX_MenuCible) {
+ PosX_MenuDepart=PosX_MenuDepart+1;
+ lv_obj_set_pos(BandeauHaut, PosX_MenuDepart, 0);
+ }
+ if (PosX_MenuDepart==PosX_MenuCible) {
+ DdeAlignMenu=0;
+ AFFSousMenu(NumSousMenu);//affichage page sous menu
+ }
+ }
+ }
+
+ //ANIMATION SOUS MENU
+ if (Top1ms){
+
+ //OUVERTURE SOUS MENU
+ if (AnimSousMenu>0) {
+ PosY_AnimSousMenu=PosY_AnimSousMenu+2;
+ lv_obj_set_size(SousMenu, 100, PosY_AnimSousMenu);
+ if (PosY_AnimSousMenu>=AnimSousMenu){AnimSousMenu=0;}
+ TpsAvFermSousMenu=4000;
+ SousMenuActif=true;
+ }
+ //TEMPS AVANT FERMEURE
+ if (SousMenuActif==true and TpsAvFermSousMenu>0){TpsAvFermSousMenu--;}
+ //FERMETURE SOUS MENU
+ if (SousMenuActif==true and TpsAvFermSousMenu<=0) {
+ PosY_AnimSousMenu=PosY_AnimSousMenu-2;
+ lv_obj_set_size(SousMenu, 100, PosY_AnimSousMenu);
+ if (PosY_AnimSousMenu<=0){SousMenuActif=false;lv_obj_del_async(SousMenu); }
+ }
+ }
+ if (SousMenuActif and X>0){TpsAvFermSousMenu=4000;}
+
+ /**/
+ }//FIN BOUCLE
+}//FIN MAIN
+
+
+//FONCTION INTERRUPTION COMPTEUR D'IMPULSION
+void interruptCompteur()
+{
+ //Timestamp pulsation
+ TimerPuls=tempo.read_high_resolution_us();
+
+ // Calcul temps entre 2 impulsions
+ TpsPuls=TimerPuls-MemTpsPuls;
+ MemTpsPuls=TimerPuls;
+
+ //Incrementation numéro de dent roue
+ NumDent++;
+
+ //Memorisation ecart entre chaque impulsion et Calcul des Min Max
+ Calcul=TpsPuls;
+ Calcul=Calcul/1000;
+ TpsEntre2Puls[NumDent]=Calcul;
+ if (Calcul<TpsMinEntre2Puls){TpsMinEntre2Puls=Calcul;}
+ if (Calcul>TpsMaxEntre2Puls){TpsMaxEntre2Puls=Calcul;}
+
+ //Calcul débit
+ if (NumDent>=16){
+ CalcDebit=VolParTour;
+ CalcDebit=60000000*CalcDebit/(TimerPuls-MemTps16Puls);
+ Debit=CalcDebit;
+ Debit=Debit/1000;
+ MemTps16Puls=TimerPuls;
+ NumDent=0;
+ }
+
+ //Nombre d'impulsion total
+ CptPuls++;
+
+ //Calcul Volume
+ Volume=CptPuls*VolParTour/16000;
+
+}
+
+void initialisation(void)
+{
+ // By doing this, we hide the first (empty) option.
+ if(th_options[0] == '\n') {
+ th_options++;
+ }
+
+ init_all_themes(0);
+ th_act = themes[0];
+ lv_theme_set_current(th_act);
+
+ lv_obj_t * scr = lv_obj_create(NULL, NULL);
+ lv_disp_load_scr(scr);
+
+ // CREATION OBJET BANDEAU HAUT
+ BandeauHaut = lv_cont_create(lv_disp_get_scr_act(NULL), NULL);
+ lv_obj_set_size(BandeauHaut,900,40);
+ lv_cont_set_fit2(BandeauHaut,LV_FIT_TIGHT, LV_FIT_NONE);
+ lv_obj_set_pos(BandeauHaut, 50, 0);
+ lv_obj_set_drag_dir(BandeauHaut, LV_DRAG_DIR_HOR);
+ lv_obj_set_drag_throw(BandeauHaut, true);
+
+ // CREATION PAGE CONTENU
+ Page = lv_page_create(lv_disp_get_scr_act(NULL), NULL);
+ lv_obj_set_size(Page, hres, vres);
+ lv_obj_set_pos(Page, 0, 40);
+
+ //INITIALISATION TABLEAU UTILISATEUR
+ User[1].Nom="Romain BECAN"; User[1].MDP="1234"; User[1].Niveau=3; User[1].Tps=1;
+ User[2].Nom="Guy HERVE"; User[2].MDP="5678"; User[2].Niveau=2; User[2].Tps=120;
+ User[3].Nom="Gabor KISS VAMOSI"; User[3].MDP="4321"; User[3].Niveau=3; User[3].Tps=2;
+ User[31].Nom="OPERATEUR 1"; User[31].MDP="4321"; User[31].Niveau=1; User[31].Tps=1;
+ User[32].Nom="OPERATEUR 2"; User[32].MDP="4321"; User[32].Niveau=1; User[32].Tps=60;
+ User[33].Nom="OPERATEUR 3"; User[33].MDP="4321"; User[33].Niveau=1; User[33].Tps=40;
+ User[34].Nom="OPERATEUR 4"; User[34].MDP="4321"; User[34].Niveau=1; User[34].Tps=30;
+ User[35].Nom="OPERATEUR 5"; User[35].MDP="4321"; User[35].Niveau=3; User[35].Tps=30;
+ User[36].Nom="OPERATEUR 6"; User[36].MDP="4321"; User[36].Niveau=3; User[36].Tps=30;
+ User[99].Nom="OPERATEUR 100"; User[99].MDP="4321"; User[99].Niveau=3; User[99].Tps=30;
+}
+
+
+
+static void AFFBandeauHaut(int Num)
+{
+
+ lv_obj_clean(BandeauHaut);
+ //MENU 1
+ M100 = lv_btn_create(BandeauHaut, NULL);
+ lv_btn_set_ink_in_time(M100, 200);
+ lv_btn_set_ink_wait_time(M100, 100);
+ lv_btn_set_ink_out_time(M100, 500);
+ lv_obj_t * label = lv_label_create(M100, NULL);
+ lv_label_set_text(label, "Mesures");
+ lv_obj_set_size(M100,100,40);
+ lv_obj_set_drag_parent(M100, true);
+ lv_obj_set_event_cb(M100, M100_ACT);
+
+ //MENU 2
+ M200 = lv_btn_create(BandeauHaut, NULL);
+ lv_btn_set_ink_in_time(M200, 200);
+ lv_btn_set_ink_wait_time(M200, 100);
+ lv_btn_set_ink_out_time(M200, 500);
+ label = lv_label_create(M200, NULL);
+ lv_label_set_text(label, "Parametres");
+ lv_obj_set_size(M200,100,40);
+ //lv_btn_set_toggle(M200, true);
+ // lv_btn_toggle(M200);
+ // lv_obj_set_drag(M200, true);
+ lv_obj_align(M200, M100, LV_ALIGN_OUT_RIGHT_MID, 0, 0);
+ lv_obj_set_drag_parent(M200, true);
+ lv_obj_set_event_cb(M200, M200_ACT);
+
+ //MENU 3
+ M300 = lv_btn_create(BandeauHaut, NULL);
+ label = lv_label_create(M300, NULL);
+ lv_label_set_text(label, "BPMENU3");
+ lv_obj_set_size(M300,100,40);
+ lv_obj_align(M300, M200, LV_ALIGN_OUT_RIGHT_MID, 0, 0);
+ lv_obj_set_drag_parent(M300, true);
+ lv_obj_set_event_cb(M300, M300_ACT);
+
+ //MENU 4
+ M400 = lv_btn_create(BandeauHaut, NULL);
+ label = lv_label_create(M400, NULL);
+ lv_label_set_text(label, "BPMENU4");
+ lv_obj_set_size(M400,100,40);
+ lv_obj_align(M400, M300, LV_ALIGN_OUT_RIGHT_MID, 0, 0);
+ lv_obj_set_drag_parent(M400, true);
+ lv_obj_set_event_cb(M400, M400_ACT);
+
+ //MENU 5
+ M500 = lv_btn_create(BandeauHaut, NULL);
+ label = lv_label_create(M500, NULL);
+ lv_label_set_text(label, "BPMENU5");
+ lv_obj_set_size(M500,100,40);
+ lv_obj_align(M500, M400, LV_ALIGN_OUT_RIGHT_MID, 0, 0);
+ lv_obj_set_drag_parent(M500, true);
+ lv_obj_set_event_cb(M500, M500_ACT);
+
+ //BP BPMENU6
+ M600 = lv_btn_create(BandeauHaut, NULL);
+ label = lv_label_create(M600, NULL);
+ lv_label_set_text(label, "BPMENU6");
+ lv_obj_set_size(M600,100,40);
+ lv_obj_align(M600, M500, LV_ALIGN_OUT_RIGHT_MID, 0, 0);
+ lv_obj_set_drag_parent(M600, true);
+ lv_obj_set_event_cb(M600, M600_ACT);
+
+}
+
+
+static void AFFSousMenu(int Num)
+{
+ //SI SOUS MENU DEJA AFFICHE : SUPPRIMER PAGE AVANT CREATION NOUVELLE
+ if(SousMenuActif){lv_obj_del(SousMenu);}
+ //GABOR: How to test if the object "SousMenu" already exist? I Think it will be a better way than i did it.(SET/RESET with a Bit)
+ //Something like: if(GetObjExist(SousMenu)==1){lv_obj_del(SousMenu);}
+
+ /*Create a list*/
+ SousMenu = lv_list_create(lv_scr_act(), NULL);
+ lv_obj_set_size(SousMenu, 100, 100);
+ lv_obj_set_pos(SousMenu, 0, 40);
+
+ lv_style_copy(&Style_BPSM, &lv_style_btn_rel);
+ // Style_BPSM.text.font = &lv_font_roboto_12;
+ // Style_BPSM.body.padding.top = LV_DPI / 40;
+ // Style_BPSM.body.padding.bottom = LV_DPI / 40;
+ // GABOR: How to change the height of button in a list ?
+
+ //SOUS MENU 100
+ if (Num==100){
+ AnimSousMenu=200;//TAILLE FENETRE
+ SM101 = lv_list_add_btn(SousMenu, NULL, "SM101");
+ if (UserEC.Niveau<0){lv_btn_set_state(SM101, LV_BTN_STATE_INA );}
+ lv_obj_set_event_cb(SM101, SM101_ACT);
+
+ SM102 = lv_list_add_btn(SousMenu, NULL, "SM102");
+ if (UserEC.Niveau<0){lv_btn_set_state(SM102, LV_BTN_STATE_INA );}
+ lv_obj_set_event_cb(SM102, SM102_ACT);
+
+ SM103 = lv_list_add_btn(SousMenu, NULL, "SM103");
+ if (UserEC.Niveau<1){lv_btn_set_state(SM103, LV_BTN_STATE_INA );}
+ lv_obj_set_event_cb(SM103, SM103_ACT);
+
+ SM104 = lv_list_add_btn(SousMenu, NULL, "NOM DE MENU LONG");
+ if (UserEC.Niveau<0){lv_btn_set_state(SM104, LV_BTN_STATE_INA );}
+ lv_obj_set_event_cb(SM104, SM104_ACT);
+
+ SM105 = lv_list_add_btn(SousMenu, NULL, "SM104");
+ if (UserEC.Niveau<0){lv_btn_set_state(SM105, LV_BTN_STATE_INA );}
+ lv_obj_set_event_cb(SM105, SM105_ACT);
+ }
+
+ //SOUS MENU 200
+ if (Num==200){
+ AnimSousMenu=100;//TAILLE FENETRE
+ SM201 = lv_list_add_btn(SousMenu, NULL, "SM201");
+ if (UserEC.Niveau<0){lv_btn_set_state(SM201, LV_BTN_STATE_INA );}
+ lv_obj_set_event_cb(SM201, SM201_ACT);
+
+ SM202 = lv_list_add_btn(SousMenu, NULL, "SM202");
+ if (UserEC.Niveau<0){lv_btn_set_state(SM202, LV_BTN_STATE_INA );}
+ lv_obj_set_event_cb(SM202, SM202_ACT);
+
+ }
+
+}
+
+
+static void AFFPage(int Num)
+{
+
+ // lv_obj_clean(Page);
+
+ lv_page_set_scrl_layout(Page, LV_LAYOUT_OFF);
+ lv_page_set_scrl_fit2(Page, LV_FIT_FLOOD, LV_FIT_TIGHT);
+
+ lv_coord_t max_w = lv_page_get_fit_width(Page);
+
+ //affichage données
+ int i=0;
+ AffTensionBat = lv_label_create(Page, NULL);
+ lv_obj_set_pos(AffTensionBat, 50, i);
+
+ AffTpsCy = lv_label_create(Page, NULL);
+ i=i+16;lv_obj_set_pos(AffTpsCy, 50, i);
+
+ AffCptPuls = lv_label_create(Page, NULL);
+ i=i+16;lv_obj_set_pos(AffCptPuls, 50, i);
+
+ AffVolume = lv_label_create(Page, NULL);
+ i=i+16;lv_obj_set_pos(AffVolume, 50, i);
+
+ AffDebit = lv_label_create(Page, NULL);
+ i=i+16;lv_obj_set_pos(AffDebit, 50, i);
+
+ Aff1TpsEntre2Puls = lv_label_create(Page, NULL);
+ i=i+16;lv_obj_set_pos(Aff1TpsEntre2Puls, 50, i);
+
+ Aff2TpsEntre2Puls = lv_label_create(Page, NULL);
+ i=i+16;lv_obj_set_pos(Aff2TpsEntre2Puls, 50, i);
+
+ AffTpsMinEntre2Puls = lv_label_create(Page, NULL);
+ i=i+16;lv_obj_set_pos(AffTpsMinEntre2Puls, 50, i);
+
+ AffTpsMaxEntre2Puls = lv_label_create(Page, NULL);
+ i=i+16;lv_obj_set_pos(AffTpsMaxEntre2Puls, 50, i);
+
+ //BP BPMENU4
+ BPRAZ = lv_btn_create(Page, NULL);
+ i=i+30;lv_obj_set_pos(BPRAZ, 50, i);
+ label = lv_label_create(BPRAZ, NULL);
+ lv_label_set_text(label, "RAZ");
+ lv_obj_set_size(BPRAZ,60,40);
+ lv_obj_set_event_cb(BPRAZ, BPRAZ_ACT);
+
+ // SLIDER
+ static lv_style_t style_bg,style_knob;
+ static lv_style_t style_indic_R;
+
+
+ lv_style_copy(&style_bg, &lv_style_pretty);
+ style_bg.body.main_color = LV_COLOR_BLACK;
+ style_bg.body.grad_color = LV_COLOR_BLACK;
+ style_bg.body.radius = LV_RADIUS_CIRCLE;
+ style_bg.body.border.color = LV_COLOR_SILVER;
+
+ lv_style_copy(&style_indic_R, &lv_style_pretty_color);
+ style_indic_R.body.main_color = LV_COLOR_RED;
+ style_indic_R.body.grad_color = LV_COLOR_RED;
+ style_indic_R.body.radius = LV_RADIUS_CIRCLE;
+ style_indic_R.body.shadow.width = 4;
+ style_indic_R.body.shadow.color = LV_COLOR_RED;
+ style_indic_R.body.padding.left = 3;
+ style_indic_R.body.padding.right = 3;
+ style_indic_R.body.padding.top = 3;
+ style_indic_R.body.padding.bottom = 3;
+
+ lv_style_copy(&style_knob, &lv_style_pretty);
+ style_knob.body.radius = LV_RADIUS_CIRCLE;
+ style_knob.body.opa = LV_OPA_70;
+ style_knob.body.padding.top = 10 ;
+ style_knob.body.padding.bottom = 10 ;
+
+ /*Create a slider ROUGE*/
+ R = lv_slider_create(Page, NULL);
+ lv_obj_set_pos(R, 10, 40);
+ lv_obj_set_width(R, 30);
+ lv_obj_set_height(R, 180);
+ lv_slider_set_range(R, 0, 10000);
+ lv_slider_set_value(R, Reglage_R, false);
+ style_indic_R.body.main_color = LV_COLOR_RED;
+ style_indic_R.body.grad_color = LV_COLOR_RED;
+ style_indic_R.body.shadow.color = LV_COLOR_RED;
+ lv_slider_set_style(R, LV_SLIDER_STYLE_BG, &style_bg);
+ lv_slider_set_style(R, LV_SLIDER_STYLE_INDIC,&style_indic_R);
+ lv_slider_set_style(R, LV_SLIDER_STYLE_KNOB, &style_knob);
+ lv_obj_set_event_cb(R, Reglage_R_RGB);
+ Val_R = lv_label_create(Page, NULL);
+ lv_obj_align(Val_R, R, LV_ALIGN_OUT_TOP_MID, 0, -5);
+ sprintf(text, " %d ", lv_slider_get_value(R));
+ lv_label_set_text(Val_R, text);
+
+
+}
+
+
+
+static void init_all_themes(uint16_t hue)
+{
+ // NOTE: This must be adjusted if more themes are added.
+ int i = 0;
+#if LV_USE_THEME_DEFAULT
+ themes[i++] = lv_theme_default_init(hue, NULL);
+#endif
+
+#if LV_USE_THEME_NIGHT
+ themes[i++] = lv_theme_night_init(hue, NULL);
+#endif
+
+#if LV_USE_THEME_MATERIAL
+ themes[i++] = lv_theme_material_init(hue, NULL);
+#endif
+
+#if LV_USE_THEME_ALIEN
+ themes[i++] = lv_theme_alien_init(hue, NULL);
+#endif
+
+#if LV_USE_THEME_ZEN
+ themes[i++] = lv_theme_zen_init(hue, NULL);
+#endif
+
+#if LV_USE_THEME_NEMO
+ themes[i++] = lv_theme_nemo_init(hue, NULL);
+#endif
+
+#if LV_USE_THEME_MONO
+ themes[i++] = lv_theme_mono_init(hue, NULL);
+#endif
+
+
+}
+//********************
+// POPUP CONNEXION MDP
+//********************
+static void AFFPopupMDP(){
+ //FOND GRISE
+ static lv_style_t modal_style;
+ lv_style_copy(&modal_style, &lv_style_plain_color);
+ modal_style.body.main_color = modal_style.body.grad_color = LV_COLOR_BLACK;
+ modal_style.body.opa = LV_OPA_50;
+ FondGris = lv_obj_create(lv_scr_act(), NULL);
+ lv_obj_set_style(FondGris, &modal_style);
+ lv_obj_set_pos(FondGris, 0, 0);
+ lv_obj_set_size(FondGris, LV_HOR_RES, LV_VER_RES);
+ lv_obj_set_opa_scale_enable(FondGris, true);
+
+ // CREATION POPUP CONNEXION MDP
+ PopupMDP = lv_obj_create(FondGris, NULL);
+ lv_obj_set_size(PopupMDP,400,260);
+ lv_obj_align(PopupMDP, FondGris, LV_ALIGN_CENTER, 0, 0);
+ lv_obj_set_opa_scale_enable(PopupMDP, true);
+ lv_obj_set_opa_scale(PopupMDP, 240);
+
+ //TITRE
+ label = lv_label_create(PopupMDP, NULL);
+ lv_label_set_text(label, "IDENTIFICATION");
+ lv_obj_align(label, PopupMDP, LV_ALIGN_IN_TOP_MID, 0, 3);
+ lv_obj_set_opa_scale_enable(label, true);
+ lv_obj_set_opa_scale(label, LV_OPA_COVER);
+
+ //CREATION LISTE UTILISATEUR POUR AFFICHAGE
+ //GABOR: Mabye you have a better solution than:
+ int i;
+ int j;
+ int k=0;
+ char p[2200];
+ for (i = 1; i < 2200; i++) { p[i]=='\0';}
+ for (i = 1; i < 100; i++) {
+ string s=User[i].Nom;
+ if (s.length()>0){
+ for (j = 0; j < s.length(); j++) {
+ p[k] = s[j];
+ k++;
+ }
+ p[k]='\n';
+ k++;
+ }
+ }
+ p[k+1]='\0';
+ char * ListeUser= p ;
+
+ //SELECTEUR UTILISATEUR
+ SelectID = lv_roller_create(PopupMDP, NULL);
+ lv_roller_set_options(SelectID,ListeUser,LV_ROLLER_MODE_NORMAL);
+ lv_roller_set_visible_row_count(SelectID, 9);
+ lv_roller_set_fix_width(SelectID, 170);
+ lv_obj_align(SelectID, PopupMDP, LV_ALIGN_IN_TOP_LEFT, 10, 20);
+ //GABOR: is it possible to put the selection on the second line of the roller , not at the middle ?
+
+ //CHAMPS MOT DE PASSE
+ MDP = lv_ta_create(PopupMDP, NULL);
+ lv_ta_set_text(MDP, "");
+ lv_ta_set_pwd_mode(MDP, true);
+ lv_ta_set_one_line(MDP, true);
+ lv_obj_set_width(MDP, 170);
+ lv_obj_align(MDP, PopupMDP, LV_ALIGN_IN_TOP_RIGHT, -10, 20);
+ lv_obj_set_opa_scale_enable(MDP, true);
+ lv_obj_set_opa_scale(MDP, LV_OPA_COVER);
+ lv_ta_set_max_length(MDP, 4);
+
+ // PAVE NUMERIQUE SAISIE MOT DE PASSE
+ static lv_style_t rel_style, pr_style; //STYLE CLAVIER
+ lv_style_copy(&rel_style, &lv_style_btn_rel);
+ rel_style.body.radius = 0;
+ rel_style.body.border.width = 1;
+ lv_style_copy(&pr_style, &lv_style_btn_pr);
+ pr_style.body.radius = 0;
+ pr_style.body.border.width = 1;
+
+ lv_obj_t * PaveNumerique = lv_kb_create(PopupMDP, NULL);
+ lv_obj_set_size(PaveNumerique,170,170);
+ lv_btnm_set_map(PaveNumerique, PAVE_NUMERIQUE_MAP);
+ lv_btnm_set_btn_width(PaveNumerique, 10, 2);
+ lv_obj_align(PaveNumerique, PopupMDP, LV_ALIGN_IN_TOP_RIGHT, -10, 50);
+ lv_obj_set_opa_scale_enable(PaveNumerique, true);
+ lv_obj_set_opa_scale(PaveNumerique, LV_OPA_COVER);
+ lv_kb_set_cursor_manage(PaveNumerique, true);
+ lv_kb_set_style(PaveNumerique, LV_KB_STYLE_BG, &lv_style_transp_tight);
+ lv_kb_set_style(PaveNumerique, LV_KB_STYLE_BTN_REL, &rel_style);
+ lv_kb_set_style(PaveNumerique, LV_KB_STYLE_BTN_PR, &pr_style);
+ lv_kb_set_ta(PaveNumerique, MDP); //ASSOCIATION CLAVIER ET CHAMPS MDP
+
+ // STYLE DES BOUTONS
+ lv_style_copy(&Style_BP, &lv_style_btn_rel);
+ Style_BP.text.font = &lv_font_roboto_12;
+ Style_BP.body.main_color = LV_COLOR_MAKE(R3, G3, B3);
+
+ //BP VALIDER
+ lv_obj_t * BpValidMDP=lv_btn_create(PopupMDP, NULL);
+ lv_btn_set_style(BpValidMDP, LV_BTN_STYLE_REL,&Style_BP);
+ lv_obj_set_size(BpValidMDP,100,30);
+ lv_obj_align(BpValidMDP, PopupMDP, LV_ALIGN_IN_BOTTOM_MID, -60, -5);
+ label = lv_label_create(BpValidMDP, NULL);
+ lv_label_set_text(label, "Valider");
+ lv_obj_set_drag_parent(BpValidMDP, true);
+ lv_obj_set_event_cb(BpValidMDP, BpValidMDP_ACT);
+ lv_obj_set_opa_scale_enable(BpValidMDP, true);
+ lv_obj_set_opa_scale(BpValidMDP, LV_OPA_COVER);
+
+ //BP ANNULER
+ lv_obj_t * BpAnnulMDP=lv_btn_create(PopupMDP, NULL);
+ lv_btn_set_style(BpAnnulMDP, LV_BTN_STYLE_REL,&Style_BP);
+ lv_obj_set_size(BpAnnulMDP,100,30);
+ lv_obj_align(BpAnnulMDP, PopupMDP, LV_ALIGN_IN_BOTTOM_MID, 60, -5);
+ label = lv_label_create(BpAnnulMDP, NULL);
+ //lv_label_set_text(label, "Annuler");
+ lv_label_set_text(label, Message(1)); //GABOR: Multiligual : see the function "message"
+
+ lv_obj_set_drag_parent(BpAnnulMDP, true);
+ lv_obj_set_event_cb(BpAnnulMDP, BpAnnulMDP_ACT);
+ lv_obj_set_opa_scale_enable(BpAnnulMDP, true);
+ lv_obj_set_opa_scale(BpAnnulMDP, LV_OPA_COVER);
+
+}
+
+static void BpValidMDP_ACT(lv_obj_t * obj, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ //RECUPERATION DU NOM DE L'UTILISATEUR SELECTIONNE
+ char NomSelect[20];
+ lv_roller_get_selected_str(SelectID, NomSelect, sizeof(NomSelect));
+
+ //RECUPERATION MOT DE PASSE SAISIE
+ string MdpSaisie;
+ MdpSaisie = lv_ta_get_text(MDP);
+
+ //FOND GRISE
+ static lv_style_t modal_style;
+ lv_style_copy(&modal_style, &lv_style_plain_color);
+ modal_style.body.main_color = modal_style.body.grad_color = LV_COLOR_BLACK;
+ modal_style.body.opa = LV_OPA_50;
+ FondGris2 = lv_obj_create(lv_scr_act(), NULL);
+ lv_obj_set_style(FondGris2, &modal_style);
+ lv_obj_set_pos(FondGris2, 0, 0);
+ lv_obj_set_size(FondGris2, LV_HOR_RES, LV_VER_RES);
+ lv_obj_set_opa_scale_enable(FondGris2, true);
+ //COMPARAISON AVEC LISTE
+ static const char * btns2[] = {"Ok", ""};
+ for (int i = 1; i < 100; i++) {
+ if (User[i].Nom==NomSelect)
+ if (User[i].MDP==MdpSaisie){
+ mbox=lv_mbox_create(FondGris2, NULL);
+ lv_mbox_add_btns(mbox, btns2);
+ if (User[i].Niveau==1){sprintf(text2, "qu'operateur" );}
+ if (User[i].Niveau==2){sprintf(text2, "que superviseur");}
+ if (User[i].Niveau==3){sprintf(text2, "que constructeur");}
+ sprintf(text, "Connexion autorisee a %s en tant %s pour une duree de %d min",User[i].Nom ,text2,User[i].Tps );
+ lv_mbox_set_text(mbox, text);
+ lv_obj_align(mbox, NULL, LV_ALIGN_CENTER, 0, 0);
+ lv_obj_set_event_cb(mbox, mboxMdp_ACT);
+ TpsMdpEnCours=User[i].Tps*60;
+ UserEC=User[i];
+ //RECLASSEMENT DU TABLEAU DES UTILISATEURS POUR AVOIR LE DERNIER CONNECTé EN PREMIER
+ User[0]=User[i];
+ for (int j = i; j >0; j--) { //DECALAGE TABLEAU
+ User[j]=User[j-1];
+ }
+ return;
+ }
+ }
+ mbox=lv_mbox_create(FondGris2, NULL);
+ lv_mbox_add_btns(mbox, btns2);
+ lv_mbox_set_text(mbox, "MOT DE PASSE ERRONE");
+ lv_obj_align(mbox, NULL, LV_ALIGN_CENTER, 0, 0);
+ lv_obj_set_event_cb(mbox, mboxMdp_ACT2);
+ }
+}
+static void BpAnnulMDP_ACT(lv_obj_t * obj, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ // lv_obj_del_async(PopupMDP);
+ lv_obj_del_async(FondGris);
+ }
+}
+
+static void mboxMdp_ACT(lv_obj_t * obj, lv_event_t event)
+{
+ lv_obj_del_async(FondGris);
+ lv_obj_del_async(FondGris2);
+
+
+}
+static void mboxMdp_ACT2(lv_obj_t * obj, lv_event_t event)
+{
+ lv_obj_del_async(FondGris2);
+ lv_ta_set_text(MDP, "");
+}
+
+
+//**************************
+// ACTION BOUTONS MENUS
+//**************************
+
+static void Reglage_R_RGB(lv_obj_t * obj, lv_event_t event)
+{
+ if(event == LV_EVENT_PRESSING) {
+ Reglage_R= lv_slider_get_value(obj);
+ sprintf(text, " %d ",Reglage_R );
+ lv_label_set_text(Val_R, text);
+ }
+}
+
+static void BPRAZ_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ TpsMinEntre2Puls=999999;
+ TpsMaxEntre2Puls=0;
+ CptPuls=0;
+ Volume=0;
+ for (NumDent=20;NumDent>0;NumDent--){
+ TpsEntre2Puls[NumDent]=0;
+ MemTpsPuls=0;
+ MemTps16Puls=0;
+ }
+ }
+}
+static void M100_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ PosX_MenuDepart = lv_obj_get_x(BandeauHaut);
+ PosX_MenuCible = -lv_obj_get_x(M100);
+ DdeAlignMenu=1;
+ NumSousMenu=100;
+ }
+}
+static void M200_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ PosX_MenuDepart = lv_obj_get_x(BandeauHaut);
+ PosX_MenuCible = -lv_obj_get_x(M200);
+ DdeAlignMenu=1;
+ NumSousMenu=200;
+ }
+}
+static void M300_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ PosX_MenuDepart = lv_obj_get_x(BandeauHaut);
+ PosX_MenuCible = -lv_obj_get_x(M300);
+ DdeAlignMenu=1;
+ NumSousMenu=300;
+ }
+}
+static void M400_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ PosX_MenuDepart = lv_obj_get_x(BandeauHaut);
+ PosX_MenuCible = -lv_obj_get_x(M400);
+ DdeAlignMenu=1;
+ NumSousMenu=400;
+ }
+}
+static void M500_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ PosX_MenuDepart = lv_obj_get_x(BandeauHaut);
+ PosX_MenuCible = -lv_obj_get_x(M500);
+ DdeAlignMenu=1;
+ NumSousMenu=500;
+ }
+}
+static void M600_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ PosX_MenuDepart = lv_obj_get_x(BandeauHaut);
+ PosX_MenuCible = -lv_obj_get_x(M600);
+ DdeAlignMenu=1;
+ NumSousMenu=600;
+ }
+}
+//**************************
+// ACTION BOUTONS SOUS MENUS
+//**************************
+static void SM101_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ //VERIFICATION AUTORISATION ACCES
+ uint8_t EtatBp = lv_btn_get_state(btn);
+ if (EtatBp==LV_BTN_STATE_INA){
+ AFFPopupMDP();
+ }
+ else{
+ TpsAvFermSousMenu=0;
+ }
+ }
+}
+
+static void SM102_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ //VERIFICATION AUTORISATION ACCES
+ uint8_t EtatBp = lv_btn_get_state(btn);
+ if (EtatBp==LV_BTN_STATE_INA){
+ AFFPopupMDP();
+ }
+ else{
+ TpsAvFermSousMenu=0;
+ }
+ }
+}
+static void SM103_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ //VERIFICATION AUTORISATION ACCES
+ uint8_t EtatBp = lv_btn_get_state(btn);
+ if (EtatBp==LV_BTN_STATE_INA){
+ AFFPopupMDP();
+ }
+ else{
+ TpsAvFermSousMenu=0;
+ }
+ }
+}
+static void SM104_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ //VERIFICATION AUTORISATION ACCES
+ uint8_t EtatBp = lv_btn_get_state(btn);
+ if (EtatBp==LV_BTN_STATE_INA){
+ AFFPopupMDP();
+ }
+ else{
+ TpsAvFermSousMenu=0;
+ }
+ }
+}
+static void SM105_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ //VERIFICATION AUTORISATION ACCES
+ uint8_t EtatBp = lv_btn_get_state(btn);
+ if (EtatBp==LV_BTN_STATE_INA){
+ AFFPopupMDP();
+ }
+ else{
+ TpsAvFermSousMenu=0;
+ }
+ }
+}
+
+static void SM201_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ //VERIFICATION AUTORISATION ACCES
+ uint8_t EtatBp = lv_btn_get_state(btn);
+ if (EtatBp==LV_BTN_STATE_INA){
+ AFFPopupMDP();
+ }
+ else{
+ TpsAvFermSousMenu=0;
+ }
+ }
+}
+static void SM202_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ //VERIFICATION AUTORISATION ACCES
+ uint8_t EtatBp = lv_btn_get_state(btn);
+ if (EtatBp==LV_BTN_STATE_INA){
+ AFFPopupMDP();
+ }
+ else{
+ TpsAvFermSousMenu=0;
+ }
+ }
+}
+static void SM203_ACT(lv_obj_t * btn, lv_event_t event)
+{
+ if(event == LV_EVENT_CLICKED) {
+ //VERIFICATION AUTORISATION ACCES
+ uint8_t EtatBp = lv_btn_get_state(btn);
+ if (EtatBp==LV_BTN_STATE_INA){
+ AFFPopupMDP();
+ }
+ else{
+ TpsAvFermSousMenu=0;
+ }
+ }
+}
+
+//GABOR: is it a Good way to make a multilingual application?
+//********************
+// MULTILANGUE
+//********************
+//Message multilangue
+char * Message(int Num){
+ if (Num<900){
+ if (Langue==1){Num=Num+1000;}//FRANCAIS
+ if (Langue==2){Num=Num+2000;}//ANGLAIS
+ if (Langue==3){Num=Num+3000;}//?????
+ if (Langue==4){Num=Num+4000;}//?????
+ }
+
+ switch (Num) {
+ //FRANCAIS// //ANGLAIS// //????// //????//
+ case 1000: return "";break; case 2000: return "";break; case 3000: return "";break; case 4000: return "";break;
+ case 1001: return "ANNULER";break; case 2001: return "CANCEL";break; case 3001: return "VOLUME";break; case 4001: return "VOLUME MESURE";break;
+ case 1002: return "TEMPERATURE 1";break; case 2002: return "TEMPERATURE 1";break; case 3002: return "TEMPERATURE 1";break; case 4002: return "TEMPERATURE 1";break;
+ case 1003: return "PRESSION 1";break; case 2003: return "VOLUME";break; case 3003: return "VOLUME";break; case 4003: return "VOLUME MESURE";break;
+ case 1004: return "HYGROMETRIE 1";break; case 2004: return "VOLUME";break; case 3004: return "VOLUME";break; case 4004: return "VOLUME MESURE";break;
+ case 1005: return "Masse volumique calculee (T1 P1 H1)";break; case 2005: return "VOLUME";break; case 3005: return "VOLUME";break; case 4005: return "VOLUME MESURE";break;
+ case 1006: return "Debit massique calcule(1 tour): /";break; case 2006: return "VOLUME";break; case 3006: return "VOLUME";break; case 4006: return "VOLUME MESURE";break;
+ case 1007: return "Normolitre/min: (DIN1343)";break; case 2007: return "VOLUME";break; case 3007: return "VOLUME";break; case 4007: return "VOLUME MESURE";break;
+ case 1008: return "Normolitre/min: (ISO2533)";break; case 2008: return "VOLUME";break; case 3008: return "VOLUME";break; case 4008: return "VOLUME MESURE";break;
+ case 1009: return "Normolitre/min: (Ref Personnalisee)";break; case 2009: return "VOLUME";break; case 3009: return "VOLUME";break; case 4009: return "VOLUME MESURE";break;
+ case 1010: return "Debit massique calcule(10 tours): / 10";break; case 2010: return "VOLUME";break; case 3010: return "VOLUME";break; case 4010: return "VOLUME MESURE";break;
+ case 1011: return "DEBIT MASSIQUE MESURE";break; case 2011: return "VOLUME";break; case 3011: return "VOLUME";break; case 4011: return "VOLUME MESURE";break;
+ case 1012: return "Masse calculee";break; case 2012: return "VOLUME";break; case 3012: return "VOLUME";break; case 4012: return "VOLUME MESURE";break;
+ case 1013: return "TEMPERATURE 2";break; case 2013: return "VOLUME";break; case 3013: return "VOLUME";break; case 4013: return "VOLUME MESURE";break;
+ case 1014: return "PRESSION 2";break; case 2014: return "VOLUME";break; case 3014: return "VOLUME";break; case 4014: return "VOLUME MESURE";break;
+ case 1015: return "HYGROMETRIE 2";break; case 2015: return "VOLUME";break; case 3015: return "VOLUME";break; case 4015: return "VOLUME MESURE";break;
+ case 1016: return "Masse volumique calculee (T2 P2 H2)";break; case 2016: return "VOLUME";break; case 3016: return "VOLUME";break; case 4016: return "VOLUME MESURE";break;
+ case 1017: return "Debit volumique calcule (T2 P2 H2)";break; case 2017: return "VOLUME";break; case 3017: return "VOLUME";break; case 4017: return "VOLUME MESURE";break;
+ case 1018: return "NOMBRE D'IMPULSIONS";break; case 2018: return "VOLUME";break; case 3018: return "VOLUME";break; case 4018: return "VOLUME MESURE";break;
+ case 1019: return "TOTALISATEUR";break; case 2019: return "VOLUME";break; case 3019: return "VOLUME";break; case 4019: return "VOLUME";break;
+ case 1020: return "RAZ VOLUME EN COURS";break; case 2020: return "VOLUME";break; case 3020: return "VOLUME";break; case 4020: return "VOLUME MESURE";break;
+ case 1021: return "RAZ VOLUME EN COURS ET TOTALISATEUR";break; case 2021: return "VOLUME";break; case 3021: return "VOLUME";break; case 4021: return "VOLUME MESURE";break;
+}
+}
+
+//********************
+// FONCTIONS GENERALES
+//********************
+void lv_ticker_func()
+{
+ lv_tick_inc(5); //Call lv_tick_inc(x) every x milliseconds in a Timer or Task (x should be between 1 and 10). It is required for the internal timing of LittlevGL.
+}
+
+//FONCTION D'AFFICHAGE
+void my_disp_flush(lv_disp_drv_t* disp_drv, const lv_area_t* area, lv_color_t* color_p)
+{
+ //The most simple case (but also the slowest) to put all pixels to the screen one-by-one
+ uint16_t x, y;
+ for(y = area->y1; y <= area->y2; y++) {
+ for(x = area->x1; x <= area->x2; x++) {
+
+ lcd.DrawPixel( x, y, color_p->full);
+ color_p++;
+ }
+ }
+
+ // IMPORTANT!!!
+ // Inform the graphics library that you are ready with the flushing
+ lv_disp_flush_ready(disp_drv);
+}
+
+//FONCTION RECUPERATION COORDONNEES APPUI
+bool my_touchpad_read(lv_indev_drv_t * indev_driver, lv_indev_data_t * data)
+{
+ static lv_coord_t last_x = 0;
+ static lv_coord_t last_y = 0;
+
+ //Save the state and save the pressed coordinate
+ ts.GetState(&TS_State);
+
+ if(TS_State.touchDetected == 1) {
+ data->state = LV_INDEV_STATE_PR;
+ } else {
+ data->state = LV_INDEV_STATE_REL;
+ }
+
+ //data->state = tttt ? LV_INDEV_STATE_PR : LV_INDEV_STATE_REL;
+ // if(data->state == LV_INDEV_STATE_PR){
+ if(data->state == LV_INDEV_STATE_PR) {
+ //touchpad_get_xy(&last_x, &last_y);
+ last_x = TS_State.touchX[0];
+ last_y = TS_State.touchY[0];
+ }
+
+ //Set the coordinates (if released use the last pressed coordinates)
+ data->point.x = last_x;
+ data->point.y = last_y;
+
+ X = TS_State.touchDetected ;
+
+
+
+ return false; //Return `false` because we are not buffering and no more data to read
+}
+