======== Programmes Arduino pour 74HC595 ========
[[https://timodenk.com/blog/shift-register-arduino-library/|Librairie Shift-register_74HC595]]
==== ShiftRegister74HC595 Bibliothèque Arduino====
La bibliothèque Arduino ShiftRegister74HC595 simplifie l'utilisation des registres à décalage. Il vous permet de définir des broches individuelles de votre registre à décalage sur haut ou bas, tout comme les broches Arduino normales. Il supprime ainsi la surcharge de décalage des octets qui ont été créés avec des opérations compliquées au niveau des bits. Le réglage par exemple de la deuxième broche de votre registre à décalage ressemblerait simplement à
sr.set(2, HIGH);// mettre à 1 la sortie 2 du 74HC595
/*
ShiftRegister74HC595 - Bibliothèque pour un contrôle simplifié des registres à décalage 74HC595.
Développé et maintenu par Timo Denk et ses contributeurs, depuis novembre 2014.
Des informations supplémentaires sont disponibles sur https://timodenk.com/blog/shift-register-arduino-library/
Lâché dans le domaine public.
*/
#include
// create a global shift register object
// parameters: (data pin, clock pin, latch pin)
ShiftRegister74HC595<1> sr(0, 1, 2);
void setup() {
}
void loop() {
// setting all pins at the same time to either HIGH or LOW
sr.setAllHigh(); // set all pins HIGH
delay(500);
sr.setAllLow(); // set all pins LOW
delay(500);
// setting single pins
for (int i = 0; i < 8; i++) {
sr.set(i, HIGH); // set single pin HIGH
delay(250);
}
// set all pins at once
uint8_t pinValues[] = { B10101010 };
sr.setAll(pinValues);
delay(1000);
// read pin (zero based, i.e. 6th pin)
uint8_t stateOfPin5 = sr.get(5);
sr.set(6, stateOfPin5);
// set pins without immediate update
sr.setNoUpdate(0, HIGH);
sr.setNoUpdate(1, LOW);
// at this point of time, pin 0 and 1 did not change yet
sr.updateRegisters(); // update the pins to the set values
}
==== Programmation d un 74HC595 avec la librairie Shifty ====
[[https://github.com/johnnyb/Shifty| Librairie Shifty]]
Un gestionnaire 74HC595 flexible pour Arduino
La bibliothèque Shifty pour Arduino est un moyen très flexible de gérer les registres à décalage 74HC595. Il vous permet d'écrire sur des sorties individuelles, tout comme "digitalWrite", vous permet de connecter en guirlande des registres à décalage et, si vous le câblez conformément aux instructions de ce document, vous permet d'utiliser votre registre à décalage pour l' entrée et la sortie. broches avec une seule broche supplémentaire utilisée. Cela le rend idéal pour une utilisation avec un ATTiny, bien qu'il utilise un peu d'espace sur l'appareil.
#include
// Declare the shift register
Shifty shift;
void setup() {
// Set the number of bits you have (multiples of 8)
shift.setBitCount(8);
// Set the clock, data, and latch pins you are using
// This also sets the pinMode for these pins
shift.setPins(11, 12, 8);
}
void loop() {
// writeBit works just like digitalWrite
shift.writeBit(1, HIGH);
delay(500);
shift.writeBit(3, HIGH);
delay(500);
shift.writeBit(1, LOW);
delay(500);
shift.writeBit(3, LOW);
delay(500);
}
==== Programme pour 74HC595 sans librairie =====
int SER_Pin = 8; //pin 14 sur le 75HC595
int RCLK_Pin = 9; //pin 12 sur le 75HC595
int SRCLK_Pin = 10; //pin 11 sur le 75HC595
#define number_of_74hc595s 1 //Combien combinez-vous de 74HC595 ? Ne pas toucher si 1 seul
#define numOfRegisterPins number_of_74hc595s * 8
boolean registers[numOfRegisterPins];
void setup(){
pinMode(SER_Pin, OUTPUT);
pinMode(RCLK_Pin, OUTPUT);
pinMode(SRCLK_Pin, OUTPUT);
//Reset tous les pins du 74HC595
clearRegisters();
writeRegisters();
}
//Place tous les pins du 74HC595 à l'état "OFF"
void clearRegisters(){
for(int i = numOfRegisterPins - 1; i >= 0; i--){
registers[i] = LOW;
}
}
//Enregistrer et afficher les valeurs dans le registre
//Executer uniquement APRES que toutes les valeurs aient été programmées
void writeRegisters(){
digitalWrite(RCLK_Pin, LOW);
for(int i = numOfRegisterPins - 1; i >= 0; i--){
digitalWrite(SRCLK_Pin, LOW);
int val = registers[i];
digitalWrite(SER_Pin, val);
digitalWrite(SRCLK_Pin, HIGH);
}
digitalWrite(RCLK_Pin, HIGH);
}
//Place un pin du 74HC595 à l'état HAUT ou BAS
void setRegisterPin(int index, int value){
registers[index] = value;
}
void loop(){
setRegisterPin(2, HIGH);
setRegisterPin(3, HIGH);
setRegisterPin(4, LOW);
setRegisterPin(5, HIGH);
setRegisterPin(7, HIGH);
writeRegisters(); //Doit être exécuté pour appliquer les changements
//Executer seulement une fois que toutes les valeurs ont été enregistrées comme vous le souhaitiez.
}
==== Programmation 74HC595 en utilisant les bits du registre plus rapide mais plus compliqué ====
// Broche connectée au ST_CP du 74HC595
const int verrou = 11;
// Broche connectée au SH_CP du 74HC595
const int horloge = 12;
// Broche connectée au DS du 74HC595
const int data = 10;
void setup()
{
// On met les broches en sortie
pinMode(verrou, OUTPUT);
pinMode(horloge, OUTPUT);
pinMode(data, OUTPUT);
}
void loop()
{
// on affiche les nombres de 0 à 255 en binaire
for (char i = 0; i<256; i++)
{
// On active le verrou le temps de transférer les données
digitalWrite(verrou, LOW);
// on envoi toutes les données grâce à notre belle fonction
envoi_ordre(data, horloge, 1, ~i);
// et enfin on relâche le verrou
digitalWrite(verrou, HIGH);
// une petite pause pour constater l'affichage
delay(1000);
}
}
void envoi_ordre(int dataPin, int clockPin, boolean sens, char donnee)
{
// on va parcourir chaque bit de l'octet
for(int i=0; i<8; i++)
{
// on met l'horloge à l'état bas
digitalWrite(clockPin, LOW);
// on met le bit de donnée courante en place
if(sens)
{
digitalWrite(dataPin, donnee & 0x01 << i);
}
else
{
digitalWrite(dataPin, donnee & 0x80 >> i);
}
// enfin on remet l'horloge à l'état haut pour
// faire prendre en compte cette dernière
digitalWrite(clockPin, HIGH);
}
}