shiftOut()
Description :
Décale un octet de données bit par bit. L’opération commence par le bit de poids fort (le plus à gauche) ou le bit de poids faible (le plus à droite). Chaque bit est écrit successivement sur une broche de données, puis une broche d’horloge est pulsée (passée à l’état haut, puis à l’état bas) pour indiquer que le bit est disponible.
Remarque : Si vous interagissez avec un périphérique cadencé par fronts montants, vous devez vous assurer que la broche d’horloge est à l’état bas avant d’appeler shiftOut(), par exemple digitalWrite(clockPin, LOW).
Il s’agit d’une implémentation logicielle ; voir également la bibliothèque SPI, qui propose une implémentation matérielle plus rapide, mais qui ne fonctionne que sur certaines broches.
Syntaxe :
Utilisez la fonction suivante pour écrire des données de manière synchrone via une broche :
shiftOut(dataPin, clockPin, bitOrder, value)
Paramètres :
La fonction admet les paramètres suivants :
- dataPin : broche sur laquelle chaque bit doit être envoyé. Types de données autorisés : int.
- clockPin : broche qui fournit le signal de synchronisation. Types de données autorisés : int.
- bitOrder : ordre de décalage des bits : MSBFIRST ou LSBFIRST (bit de poids fort en premier ou bit de poids faible en premier).
- value : données à décaler. Types de données autorisés : byte.
Retours :
La fonction ne renvoie rien.
Exemple de code :
Pour le circuit d’accompagnement, consultez le tutoriel sur le contrôle d’un registre à décalage 74HC595.
//**************************************************************//
// Name : shiftOutCode, Hello World //
// Author : Carlyn Maw,Tom Igoe //
// Date : 25 Oct, 2006 //
// Version : 1.0 //
// Notes : Code for using a 74HC595 Shift Register //
// : to count from 0 to 255 //
//****************************************************************
//Broche connectée à ST_CP of 74HC595
int latchPin = 8;
//Broche connectée à SH_CP of 74HC595
int clockPin = 12;
////Broche connectée à DS of 74HC595
int dataPin = 11;
void setup() {
//définir les broches en sortie car elles sont adressées dans la boucle principale
pinMode(latchPin, OUTPUT);
pinMode(clockPin, OUTPUT);
pinMode(dataPin, OUTPUT);
}
void loop() {
//count up routine
for (int j = 0; j < 256; j++) {
//Verrou latchPin et maintenu bas aussi longtemps que vous transmettez
digitalWrite(latchPin, LOW);
shiftOut(dataPin, clockPin, LSBFIRST, j);
//remettre latchPin haut pour signaler à la puce qu'elle
//n'a plus besoin d'écouter les informations
digitalWrite(latchPin, HIGH);
delay(1000);
}
}
Remarques et avertissements :
Les broches dataPin et clockPin doivent déjà être configurées comme sorties par un appel à pinMode().
shiftOut est actuellement écrit sur une sortie de 1 octet (8 bits). Il nécessite donc une opération en deux étapes pour générer des valeurs supérieures à 255.
// Faites ceci pour MSBFIRST en série int data = 500; // shift out highbyte shiftOut(dataPin, clock, MSBFIRST, (data >> 8)); // shift out lowbyte shiftOut(dataPin, clock, MSBFIRST, data); // Ou fais ça pour LSBFIRST en série data = 500; // shift out lowbyte shiftOut(dataPin, clock, LSBFIRST, data); // shift out highbyte shiftOut(dataPin, clock, LSBFIRST, (data >> 8));
Source : https://docs.arduino.cc/language-reference/en/functions/advanced-io/shiftOut/
