version panneau d'octobre 2018 pour TR de S2 et projet de S3

Dependencies:   mbed

Fork of duj401 by dujardin stephane

Committer:
dujardin
Date:
Tue May 10 11:50:12 2016 +0000
Revision:
1:95a7e179a181
Parent:
0:3cb0bc1eb7fa
Child:
2:1af4d847d589
version TR mai 2016

Who changed what in which revision?

UserRevisionLine numberNew contents of line
dujardin 1:95a7e179a181 1 // duj401 pour TR de s2
dujardin 1:95a7e179a181 2 // sans serie wdt ou autre
dujardin 1:95a7e179a181 3 // lieu de programmation >>> dans le draw !!
dujardin 1:95a7e179a181 4
dujardin 0:3cb0bc1eb7fa 5 #include "mbed.h"
dujardin 0:3cb0bc1eb7fa 6 #define LOW 0
dujardin 0:3cb0bc1eb7fa 7 #define HIGH 1
dujardin 0:3cb0bc1eb7fa 8 #define R 0
dujardin 0:3cb0bc1eb7fa 9 #define V 1
dujardin 0:3cb0bc1eb7fa 10 #define B 2
dujardin 0:3cb0bc1eb7fa 11 DigitalOut sd(PC_9);
dujardin 0:3cb0bc1eb7fa 12 Serial serie(NC, PC_7); // tx, rx
dujardin 0:3cb0bc1eb7fa 13 BusOut ABCD(PA_14,PB_0,PA_15,PC_1); // version 32/32 nucleo f401
dujardin 0:3cb0bc1eb7fa 14 BusOut RVB(PA_7,PA_5,PA_4,PA_1,PA_6,PA_0); // RVB ( R a droite )un seul a ecrire
dujardin 0:3cb0bc1eb7fa 15 DigitalOut CLK(PC_2); // Data clock - rising edge
dujardin 0:3cb0bc1eb7fa 16 DigitalOut LAT(PC_0); // Data latch - active low (pulse up after data load)
dujardin 0:3cb0bc1eb7fa 17 DigitalOut OE(PC_3); // Output enable - active low (hold high during data load, bring low after LAT pulse)
dujardin 0:3cb0bc1eb7fa 18
dujardin 0:3cb0bc1eb7fa 19 char T[32][16][4]; // Tampon affichage 4 temps R1R2V1V2B1B2 32x32 (2*16 )
dujardin 0:3cb0bc1eb7fa 20 char I[32][32][3]; // Y X rvb .. Image 32x32 en RVB 0 à 15 0: noir
dujardin 0:3cb0bc1eb7fa 21 int L; int M ; int O ; // variables globales idiotes
dujardin 0:3cb0bc1eb7fa 22 char J; char K ; char Q; char S ; char D; char F; // variables à la con
dujardin 0:3cb0bc1eb7fa 23 char G; char H ; char GG;
dujardin 0:3cb0bc1eb7fa 24 char T0 ; char T1 ; char T2 ; char T3;
dujardin 0:3cb0bc1eb7fa 25 int arr ; int prim ; int ptdat ;// arr char arrivé, prim temoin inactivité; ptdata nombre d'octet a recevoir ..
dujardin 0:3cb0bc1eb7fa 26 char rect[55]; // rec et commende 55 octets max
dujardin 0:3cb0bc1eb7fa 27 char tabc[1024] ; // pour y placer 256x4 = r+v+b+1
dujardin 0:3cb0bc1eb7fa 28 char tabp[200][200]; // pour y placer les pixels arrives ici 200/200
dujardin 0:3cb0bc1eb7fa 29 long ptfin ; // pointeur fin ( 2 + 256 3 + 256*256* 4 )
dujardin 0:3cb0bc1eb7fa 30 int pt1 ; int pt2 ; int pt3 ;int pt4 ;
dujardin 0:3cb0bc1eb7fa 31 int pttr ; int pttv ; int pttb;
dujardin 0:3cb0bc1eb7fa 32 int etat ; // etat des actions a faire .. draw .. bmp .. ..
dujardin 0:3cb0bc1eb7fa 33 int com ; int com1 ; int com2 ; int com3 ; int com4 ; int ordrefait ; // com et passage parrametre commande
dujardin 0:3cb0bc1eb7fa 34 int longtempsa0 ; int trop ; // indique très longtemps sans RX ?? que faire ? on verra
dujardin 0:3cb0bc1eb7fa 35 int Li ; int Hi ;// indicateurs : taille, largeur, hauteur
dujardin 0:3cb0bc1eb7fa 36 int dx ; int dy ; // position du 32/32 dans l'image li hi
dujardin 0:3cb0bc1eb7fa 37 int ax ; int ay ; int comf ; // ax offset en plus de dx et dy
dujardin 0:3cb0bc1eb7fa 38 char pixt ; int rr; int vv ; int bb ; // pour des couleurs
dujardin 0:3cb0bc1eb7fa 39 int ptx; int pty ; int xx ; int yy ; // utile dans recv > 1078
dujardin 0:3cb0bc1eb7fa 40 int bcl ;
dujardin 0:3cb0bc1eb7fa 41
dujardin 0:3cb0bc1eb7fa 42 #include "LED.h" // transferts LED <>401
dujardin 1:95a7e179a181 43 #include "char.h" // transfert RX 401<>1768
dujardin 0:3cb0bc1eb7fa 44 #include "draw.h" // le tableau effectue un programme dans draw
dujardin 0:3cb0bc1eb7fa 45
dujardin 0:3cb0bc1eb7fa 46 //***************************************************fin wdt
dujardin 0:3cb0bc1eb7fa 47 void init ()
dujardin 0:3cb0bc1eb7fa 48 {
dujardin 0:3cb0bc1eb7fa 49
dujardin 0:3cb0bc1eb7fa 50 prim = 3; // compteur de vides de rx
dujardin 0:3cb0bc1eb7fa 51 ptfin = 54 ; // preset au cas ou trame de commande
dujardin 0:3cb0bc1eb7fa 52 dx = 0 ; dy = 0 ; // recherche adresse du tableau dans un 8*8
dujardin 0:3cb0bc1eb7fa 53 ax = 0 ; ay = 0; // offset a ajouter a dx et dy pour mouvement
dujardin 1:95a7e179a181 54 // etat = 'd' ; // d draw état natif au reveil
dujardin 0:3cb0bc1eb7fa 55 Tr(); // efface T
dujardin 0:3cb0bc1eb7fa 56 Ir(); // efface I
dujardin 0:3cb0bc1eb7fa 57 ordrefait = 0;
dujardin 0:3cb0bc1eb7fa 58 }
dujardin 0:3cb0bc1eb7fa 59
dujardin 0:3cb0bc1eb7fa 60 int main()
dujardin 0:3cb0bc1eb7fa 61 {
dujardin 0:3cb0bc1eb7fa 62 init(); // initialisations importantes
dujardin 0:3cb0bc1eb7fa 63
dujardin 0:3cb0bc1eb7fa 64 //
dujardin 1:95a7e179a181 65 while(1) // boucle sans fin ( temps d'execution 30 ms )
dujardin 0:3cb0bc1eb7fa 66 {
dujardin 1:95a7e179a181 67 draw(); // dans draw.h c'est le lieu de votre programme en Tr
dujardin 0:3cb0bc1eb7fa 68
dujardin 1:95a7e179a181 69 IversT(); // recharge votre image I vers T
dujardin 1:95a7e179a181 70 Taffi(); // passe T vers les LEDs
dujardin 1:95a7e179a181 71 Ir(); // efface le dessin dans image I
dujardin 0:3cb0bc1eb7fa 72 }
dujardin 0:3cb0bc1eb7fa 73 }