Arduino:Примеры/ShftIn11: различия между версиями
Материал из Онлайн справочника
Перейти к навигацииПерейти к поиску
Myagkij (обсуждение | вклад) Нет описания правки |
Нет описания правки |
||
Строка 9: | Строка 9: | ||
==Код== | ==Код== | ||
<syntaxhighlight lang="c" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS | <syntaxhighlight lang="c" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS"> | ||
/**************************************************************// | /**************************************************************// | ||
// Название : Простой ввод данных // | // Название : Простой ввод данных // |
Текущая версия от 18:19, 14 мая 2023
Содержание | Знакомство с Arduino | Продукты | Основы | Справочник языка Arduino | Примеры | Библиотеки | Хакинг | Изменения | Сравнение языков Arduino и Processing |
Перевод: Максим Кузьмин
Проверка/Оформление/Редактирование: Мякишев Е.А.
Простой ввод данных[1]
Это скетч для платы Arduino и одного сдвигового регистра CD4021B. Он считывает данные с переключателей, подключенных к сдвиговому регистру, а затем выводит их на монитор порта.
Код
/**************************************************************//
// Название : Простой ввод данных //
// Автор : Кэрлин Мо //
// Дата : 25 января 2007 года //
// Версия : 1.0 //
// Примечания : Скетч для использования со сдвиговым //
// : регистром CD4021B //
//****************************************************************
// задаем номера для интерфейсных контактов:
int latchPin = 8;
int dataPin = 9;
int clockPin = 7;
// задаем переменные, которые будут хранить данные для
// сдвигового регистра; в целях отладки лучше начать
// со значений без «0»:
byte switchVar1 = 72; //01001000
void setup() {
// запускаем последовательную коммуникацию:
Serial.begin(9600);
// задаем режимы для интерфейсных контактов:
pinMode(latchPin, OUTPUT);
pinMode(clockPin, OUTPUT);
pinMode(dataPin, INPUT);
}
void loop() {
// подаем импульс на контакт-защелку;
// чтобы собрать параллельные данные, задаем ему значение «1»:
digitalWrite(latchPin,1);
// ждем:
delayMicroseconds(20);
// задаем ему «0», чтобы передать последовательные данные:
digitalWrite(latchPin,0);
// пока сдвиговый регистр переключен в последовательный режим,
// собираем все его данные в байт; сначала это делает регистр,
// подключенный к чипу:
switchVar1 = shiftIn(dataPin, clockPin);
// показываем результат; если первый контакт получит значение HIGH,
// то «0», стоящий в старшей части байта (7, 6, 5 и т.д.),
// будет удален:
Serial.println(switchVar1, BIN);
// пустое место:
Serial.println("-------------------");
// вставляем задержку, чтобы все как следует допечаталось:
delay(500);
}
//-----------------------------------------------конец главного цикла
////////// ----------------------------------- функция shiftIn()
///// в качестве аргументов ей требуются лишь контакт для данных
///// и контакт-защелка; возвращает байт, у которого каждый бит
///// соответствует какому-либо контакту сдвигового регистра:
///// 7-ой бит – это 7-ой контакт, 0-ой бит – это 0-ой контакт
byte shiftIn(int myDataPin, int myClockPin) {
int i;
int temp = 0;
int pinState;
byte myDataIn = 0;
pinMode(myClockPin, OUTPUT);
pinMode(myDataPin, INPUT);
// 8 раз подаем на тактовый контакт значение HIGH (0,..,7),
// т.е. при каждом прохождении цикла for();
// в начале каждого цикла задаем тактовому контакту значение LOW;
// это нужно для последующего перехода из LOW в HIGH, чтобы сдвиговый
// регистр поменял состояние на основе значения в следующем бите
// последовательного потока данных;
// регистр передает информацию о контактах в порядке с 7-го по 0-ой,
// поэтому наша функция ведет отсчет в обратном порядке:
for (i=7; i>=0; i--)
{
digitalWrite(myClockPin, 0);
delayMicroseconds(0.2);
temp = digitalRead(myDataPin);
if (temp) {
pinState = 1;
// несмотря ни на что, задаем биту значение «0»:
myDataIn = myDataIn | (1 << i);
}
else {
pinState = 0;
}
// печатаем отладочную информацию (если отладка не нужна,
// оставьте эти строчки закоментированными):
//Serial.print(pinState);
//Serial.print(" ");
//Serial.println (dataIn, BIN);
digitalWrite(myClockPin, 1);
}
// печатаем пустое место, разделяющее проверочные данные:
//Serial.println();
//Serial.println(myDataIn, BIN);
return myDataIn;
}
См.также
Внешние ссылки
Arduino продукты | |
---|---|
Начальный уровень | Arduino Uno • Arduino Leonardo • Arduino 101 • Arduino Robot • Arduino Esplora • Arduino Micro • Arduino Nano • Arduino Mini • Arduino Starter Kit • Arduino Basic Kit • MKR2UNO • TFT-дисплей Arduino |
Продвинутые функции | Arduino Mega 2560 • Arduino Zero • Arduino Due • Arduino Mega ADK • Arduino Pro • Arduino Motor Shield • Arduino USB Host Shield • Arduino Proto Shield • MKR Proto Shield • MKR Proto Large Shield • Arduino ISP • Arduino USB 2 Serial Micro • Arduino Mini USB Serial Adapter |
Интернет вещей | Arduino Yun • Arduino Ethernet • Arduino MKR1000 • Arduino WiFi 101 Shield • Arduino GSM Shield V2 • Arduino WiFi Shield • Arduino Wireless SD Shield • Arduino Wireless Proto Shield • Arduino Ethernet Shield V2 • Arduino Yun Shield • Arduino MKR1000 Bundle |
Носимые устройства | Arduino Gemma • Lilypad Arduino Simple • Lilypad Arduino Main Board • Lilypad Arduino USB • LilyPad Arduino SimpleSnap |
3D-печать | Arduino Materia 101 |
Устаревшие устройства | - |
Примеры Arduino | |
---|---|
Стандартные функции | |
Основы |
|
Цифровой сигнал |
|
Аналоговый сигнал |
|
Связь |
|
Управляющие структуры |
|
Датчики |
|
Дисплей |
Примеры, объясняющие основы управления дисплеем:
|
Строки |
|
USB (для Leonardo, Micro и Due плат) |
В этой секции имеют место примеры, которые демонстрируют использование библиотек, уникальных для плат Leonardo, Micro и Due.
|
Клавиатура |
|
Мышь |
|
Разное |
Категории:
- Страницы, использующие повторяющиеся аргументы в вызовах шаблонов
- Справочник языка Arduino
- Arduino
- Перевод от Сubewriter
- Проверка:myagkij
- Оформление:myagkij
- Редактирование:myagkij
- Страницы, где используется шаблон "Навигационная таблица/Телепорт"
- Страницы с телепортом
- Пример
- Примеры
- Пример программирования Arduino
- Примеры программирования Arduino