|

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/

Publications similaires

Laisser un commentaire

Votre adresse e-mail ne sera pas publiée. Les champs obligatoires sont indiqués avec *