Espruino:Справочник по API/Глобальные методы, переменные и объекты/Функция shiftOut()

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

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


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

Синтаксис

function shiftOut(pins, options, data)

Параметры

  • pins – контакт или массив контактов, которым надо передать данные
  • options – настройки тактовой частоты (см. ниже)
  • data – данные, которые надо сдвинуть и отправить (см. описание E.toUint8Array, чтобы посмотреть, в каком виде можно задать данные в этом аргументе)

Описание

Выполняет побитовый сдвиг и передачу битов заданным контактам, начиная с самого младшего бита.

Пример:

// сдвиг и передача битов на один контакт A0
// с использованием «clk» и «data»:
shiftOut(A0, { clk : A1 }, [1,0,1,0]);
// сдвиг и передача целого байта (типа программной SPI)
shiftOut(A0, { clk : A1, repeat: 8 }, [1,2,3,4]);
// сдвиг и передача данных 4 контактам:
shiftOut([A3,A2,A1,A0], { clk : A4 }, [1,2,3,4]);

Объект options устроен следующим образом:

{
  clk : pin,     // контакт для тактовой частоты
                 // (undefined = без контакта)
  clkPol : bool, // полярность тактового сигнала,
                 // по умолчанию – «0»,
                 // так что можно поставить «1»,
                 // а затем переключаться на «0» для передачи данных
  repeat : int,  // количество тиков на один элемент массива
}

Контактам будет передан каждый элемент массива data, и первым контактом, который будет получать данные, будет самый старший контакт в массиве контактов, а последним – самый младший. Тактовый сигнал будет работать с полярностью заданной в clkPol.

Значение в repeat – это то, сколько раз будут выполнены сдвиг и отправка данных каждому элементу массива. К примеру, если вам нужно сдвинуть и отправить 8 бит двум контактам, в repeat нужно задать «4».

См.также

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