Cat hungry.png
Здравствуйте! Собираем деньги на перевод материалов по электронике(https://www.allaboutcircuits.com/education/). Реквизиты указаны здесь.

Arduino:Примеры/Управление светодиодами с помощью сдвигового регистра 74HC595

Материал из Онлайн справочника
Перейти к: навигация, поиск

Проверка/Оформление/Редактирование: Мякишев Е.А.


Ambox content.png Черновик


Управление светодиодами с помощью сдвигового регистра 74HC595

Данный пример демонстрирует как управлять 8-ю светодиодами задействуя только 3 цифровых контакта Arduino. В этом нам поможет сдвиговый регистр 74HC595.

Сдвиговый регистр это синхронное устройство, он принимает данные по нарастающему фронту сигнала. В данном случае, когда мы подаем на вход SH_CP сдвигового регистра 74HC595 высокий уровень сигнала, все значения, хранящиеся в нем сдвигаются на одну позицию и происходит запись в первую ячейку значения которое установлено на входе DS сдвигового регистра 74HC595. Данные из последней ячейки или отбрасываются или передаются на выход Q7"(при каскадном подключении). За восемь тактов мы можем загрузить в регистр сдвига новые значения. При подаче на вход ST_CP сдвигового регистра 74HC595 высокого уровня напряжения, происходит вывод значений, хранящихся в ячейках, на выходы регистра.

В данном примере мы будем использовать встроенную функцию shiftOut для поразрядной выдачи данных на выход Arduino, которая упростит работу со сдвиговым регистром.

Она принимает в качестве аргументов:

  • номер контакта Arduino, подключенный к контакту DS ввода последовательных данных сдвигового регистра;
  • номер контакта Arduino, подключенный к тактовому контакту SH_CP сдвигового регистра;
  • порядок выдачи битов;
    • MSBFIRST - старший бит будет отправлен первым;
    • LSBFIRST - младший бит будет отправлен первым;
  • значение для вывода на выводы сдвигового регистра;

Необходимые компоненты

Схема

Arduino uno control led bar 74HC595 1.png


Распиновка сдвигового регистра 74HC595
Контакты 1-7, 15 Q0-Q7 Выходные контакты
Контакт 8 GND «Земля», Vss
Контакт 9 Q7’’ Контакт для вывода последовательных данных
Контакт 10 MR Контакт, позволяющий «очистить» значения на всех выходных контактах и выставить их на LOW (если подать на него LOW)
Контакт 11 SH_CP Тактовый контакт для сдвигового регистра
Контакт 12 ST_CP Тактовый контакт для регистра данных (контакт-защелка)
Контакт 13 OE Контакт, разрешающий вывод данных (если подать на него LOW)
Контакт 14 DS Контакт для ввода последовательных данных
Контакт 16 Vcc Контакт для питания напряжением с положительным зарядом

Код

  1. #define SER   8                            // Контакт для ввода последовательных данных в сдвиговый регистр
  2. #define LATCH 9                            // Тактовый контакт для регистра данных (контакт-защелка)
  3.                                            // служит для одновременного вывода полученных последовательных данных  
  4.                                            // на параллельные выходы сдвигового регистра
  5. #define CLK   10                           // Тактовый контакт для сдвигового регистра
  6.                                            // При подаче HIGH происходит запись одного бита в сдвиговый регистр
  7.  
  8. void setup()
  9. {
  10.   //Установка выводов как выходов
  11.   pinMode(SER, OUTPUT);
  12.   pinMode(LATCH, OUTPUT);
  13.   pinMode(CLK, OUTPUT);
  14.  
  15.   digitalWrite(LATCH, LOW);                // устанавливаем LATCH в LOW, чтобы значения на параллельных выходах
  16.                                            // сдвигового регистра не изменялись во время ввода последовательных
  17.                                            // данных
  18.   shiftOut(SER, CLK, MSBFIRST, B11101010); // ввод последовательных данных в сдвиговый регистр
  19.   digitalWrite(LATCH, HIGH);               // устанавливаем LATCH в HIGH для вывода значений
  20.                                            // на параллельные выводы сдвигового регистра
  21. }
  22.  
  23. void loop()
  24. {
  25.   // В этой секции мы ничего не делаем
  26. }

См.также

Внешние ссылки