Arduino:Справочник языка Arduino/Функции/Дополнительные функции ввода/вывода/shiftIn()

Материал из Онлайн справочника
Версия от 11:28, 8 июля 2023; EducationBot (обсуждение | вклад)
(разн.) ← Предыдущая версия | Текущая версия (разн.) | Следующая версия → (разн.)
Перейти к навигацииПерейти к поиску

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


Функция shiftIn()[1]

Выполняет побитовый сдвиг — по одному биту за раз. Начинает с самого (то есть левого) или наименее (то есть правого) значимого бита. Процесс проходит следующим образом: тактовый контакт переключается в состояние HIGH, из линии данных считывается очередной бит, а затем тактовый контакт переключается обратно в положение LOW.

Если вы работаете с девайсом, который синхронизируется по переднему фронту импульса, перед вызовом shiftIn() нужно обязательно перевести тактовый контакт в положении LOW. Сделать это можно, например, при помощи функции

digitalWrite(clockPin, LOW).

Примечание

Функция shiftIn() является программной реализацией. Но в Arduino есть библиотека SPI, которая использует аппаратную реализацию — она быстрее, но работает только со специальными контактами.

Синтаксис

byte incoming = shiftIn(dataPin, clockPin, bitOrder)

Параметры

dataPin  контакт, с которого будут считываться биты (тип данных  int)
clockPin  тактовый контакт, который будет переключатся с LOW на HIGH и наоборот, чтобы задавать «ритм» для считывания с dataPin
bitOrder  порядок, в котором будут сдвигаться биты (MSBFIRST  Most Significant Bit First, т.е. «первым  самый значимый бит»; LSBFIRST  Most Significant Bit First, т.е. «первым  наименее значимый бит»)

Что возвращает

Считанное значение (тип данных  byte)

См.также

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