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

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

Перевод: Максим Кузьмин (Cubewriter)
Перевел 1819 статей для сайта.

Контакты:

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


Функция 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)

См.также

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

  1. shiftIn()