Cours:TPS 2103 tp horlogeI2c : Différence entre versions
(→Contexte : l'afficheur LCD alphanumérique) |
|||
Ligne 19 : | Ligne 19 : | ||
*les codes de 128 à 255 sont les {{Rouge|codes étendus}} | *les codes de 128 à 255 sont les {{Rouge|codes étendus}} | ||
− | '''Remarque''' : le code ASCII est rarement utilisé directement, les | + | '''Remarque''' : le code ASCII est rarement utilisé directement, les insctructions suivantes sont équivalentes : |
<source lang=cpp> | <source lang=cpp> | ||
char c; | char c; | ||
Ligne 28 : | Ligne 28 : | ||
</source> | </source> | ||
+ | |||
+ | {| class="wikitable" | ||
+ | |- | ||
+ | | Pour utiliser cet afficheur avec une carte Arduino, il nous faudrait 11 broches (RS, R/W, E, D0, D1, D2, D3, D4, D5, D6, D7). | ||
+ | Pour limiter le nombre de broche, on peut mettre la broche R/W à la masse car on veut uniquement écrire dans l’afficheur. | ||
+ | Les constructeurs proposent deux modes de configuration au démarrage soit de travailler avec un bus 8 bits soit avec un bus 4 bits. | ||
+ | L’avantage d’un bus 4 bits (D7, D6, D5, D4) c’est que l’on diminue par deux le nombre de broche, par contre notre code ASCII sera envoyé en deux fois pour faire 8 bits donc le temps de transmission sera deux fois plus long. | ||
+ | Nous utiliserons le mode 4 bits, il nous faudra donc que six broches (RS, E, D7, D6, D5, D4), si possible on utilisera le même PortX, ce qui simplifiera la programmation. | ||
+ | Comme nous utiliserons des libraires pour la programmation, elles ont habituellement une configuration par défaut. | ||
+ | || | ||
Le connecteur de brochage de l’affichage (partie haute de l’image ci-dessus) | Le connecteur de brochage de l’affichage (partie haute de l’image ci-dessus) | ||
Ligne 82 : | Ligne 92 : | ||
|} | |} | ||
− | + | |} | |
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
− | |||
=écran LCD et GPIO expander= | =écran LCD et GPIO expander= |
Version du 3 avril 2024 à 09:20
Sommaire
Contexte : l'afficheur LCD alphanumérique
Ce type d'afficheur permet d'afficher un certain nombre de caractères ( lettre, chiffre, caractères spéciaux).
Ces afficheurs se distinguent principalement par :
- le nombre de caractères par ligne
- le nombre de lignes
- la couleur de rétroéclairage
- sa dimension
L'afficheur est donc découpé en cases, chacune étant un caractère de la table ASCII (American Standard Code for Information Interchange) :
- chaque caractère est associé à un nombre
- les codes ASCII de 0 à 127 sont les codes standards
- les codes de 128 à 255 sont les codes étendus
Remarque : le code ASCII est rarement utilisé directement, les insctructions suivantes sont équivalentes :
char c;
c='A';
c=0x41;
c=65;
c=0b01000001;
Pour utiliser cet afficheur avec une carte Arduino, il nous faudrait 11 broches (RS, R/W, E, D0, D1, D2, D3, D4, D5, D6, D7).
Pour limiter le nombre de broche, on peut mettre la broche R/W à la masse car on veut uniquement écrire dans l’afficheur. Les constructeurs proposent deux modes de configuration au démarrage soit de travailler avec un bus 8 bits soit avec un bus 4 bits. L’avantage d’un bus 4 bits (D7, D6, D5, D4) c’est que l’on diminue par deux le nombre de broche, par contre notre code ASCII sera envoyé en deux fois pour faire 8 bits donc le temps de transmission sera deux fois plus long. Nous utiliserons le mode 4 bits, il nous faudra donc que six broches (RS, E, D7, D6, D5, D4), si possible on utilisera le même PortX, ce qui simplifiera la programmation. Comme nous utiliserons des libraires pour la programmation, elles ont habituellement une configuration par défaut. |
Le connecteur de brochage de l’affichage (partie haute de l’image ci-dessus)
|
écran LCD et GPIO expander
Nous allons utiliser le shield i2c utilisé lors du TP précédent pour connecter l'écran sur la carte arduino Nano que nous allons programmer.
Ce ShieldLCD comporte un écran LCD avec son potentiomètre de réglage du contraste ainsi 6 boutons poussoirs. Il est fait pour être utilisé avec une carte Arduino UNO mais fonctionne aussi sur un Arduino MEGA.
Ici nous allons utiliser une librairie modifiée pour l'utilisation au travers d'un MCP23017.
Télécharger la librairie donnée dans la partie ressources, et exécuter le programme d'exemple pour vérifier le bon fonctionnement
horloge i2c : DS1307
Nous allons ajouter une horloge i2c, et utiliser l'écran LCD pour afficher l'heure sous la forme
Lun 28 Mar 2022 05 :36 :54
Attention :
- il conviendra d'ajouter au besoin un 0 pour conserver un affichage de chaque champ (heure/minute/seconde) sur 2 caractères.
- jour/mois seront affichés sur 3/4 caractères
Connecter cette target i2c et lister à l'aide d'un logiciel "i2c scanner" les périphériques i2c.
En utilisant ladatasheet du circuit DS1307 en déduire l'adresse configurée du composant
Ecrire un programme permettant d'afficher la date sous la forme demandée
Remarques :
- le bit CH doit être mis à 0 pour que l'horloge fonctionne
- il est judicieux d'utiliser un tableau de chaînes de caractères pour les jours/mois
- const char* jours[]={"Lun","Mar",....};
- Le codage BCD est utilisé :
- pour coder en binaire le nombre 45
- on code 5 en binaire : 0101
- on code 4 en binaire : 0100
- le code bcd de 45 sur 8 bits est : 01000101
- le chiffre des dizaines n'est pas nécessairement codé sur 4 bits (dépend de la valeur maximale)
- pour convertir un nombre bcd en code ascii :
- trouver la valeur des unités en masquant les bits des dizaines.
- trouver la valeur des dizaines en masquant les unités et en faisant un décalage
- pour convertir un nombre en code ASCII, ajouter 0x30 : char c=n+0x30;
- pour coder en binaire le nombre 45
- Vous pouvez vous servir de la date de compilation de votre programme pour initialiser l'horloge, ci dessous un programme d'exemple affichant l'heure et la date de compilation sur la liaison série.
char Month[12];
uint16_t Year;
uint8_t Day, monthIndex;
const char *monthName[12] = {
"Jan", "Feb", "Mar", "Apr", "May", "Jun",
"Jul", "Aug", "Sep", "Oct", "Nov", "Dec"
};
sscanf(__DATE__, "%s %d %d", Month, &Day, &Year);
for (monthIndex = 0; monthIndex < 12; monthIndex++) {
if (strcmp(Month, monthName[monthIndex]) == 0) break;
}
Serial.print(Month);
Serial.print(" : ");
Serial.println(monthIndex);
Serial.println(Day);
Serial.println(Year);
uint16_t Hour, Min, Sec;
sscanf(__TIME__, "%d:%d:%d", &Hour, &Min, &Sec);
Serial.println(Hour);
Serial.println(Min);
Serial.println(Sec);
Réglage de l'heure
Les boutons sont reliés directement à la carte Arduino via la nappe I2C.
Pour limiter le nombre d’entrée pour les cinq boutons, on utilise qu’une seule entrée analogique A2 (A0 si le Shield LCD est branché directement sur une carte Arduino UNO).
Chaque bouton modifie un pont diviseur de tension.
Suivant la valeur de la tension mesurée on sait quel bouton est appuyé.
Le bouton Reset est relié directement à l’entrée numérique D13. (ne fonctionne pas !!)
Utiliser les boutons pour permettre un réglage de l'heure
Ressources
- Librairie arduino pour l'afficheur i2c Fichier:Adafruit RGB LCD i2cShield.zip
- datasheet DS1307