Arduino:Примеры/Sweep: различия между версиями

Материал из Онлайн справочника
Перейти к навигацииПерейти к поиску
м (Замена текста — «<syntaxhighlight lang="c" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS">» на «<syntaxhighlight lang="c" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS" enclose="div">»)
 
Нет описания правки
 
(не показана 1 промежуточная версия этого же участника)
Строка 27: Строка 27:
==Код==
==Код==


<syntaxhighlight lang="c" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS" enclose="div">
<syntaxhighlight lang="c" line="GESHI_NORMAL_LINE_NUMBERS|GESHI_FANCY_LINE_NUMBERS">
// Вращение вала сервомотора
// Вращение вала сервомотора
// От BARRAGAN <http://barraganstudio.com>  
// От BARRAGAN <http://barraganstudio.com>  
Строка 72: Строка 72:


<references />
<references />
{{Навигационная таблица/Портал/Arduino}}
[[Категория:Пример]]
[[Категория:Пример]]
[[Категория:Примеры]]
[[Категория:Примеры]]
[[Категория:Пример программирования Arduino]]
[[Категория:Пример программирования Arduino]]
[[Категория:Примеры программирования Arduino]]
[[Категория:Примеры программирования Arduino]]

Текущая версия от 12:38, 8 июля 2023

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


Вращение вала сервомотора[1]

Вращение вала радиоуправляемого сервомотора вперед и назад на 180 градусов.

Этот пример использует библиотеку Servo.

Необходимое оборудование

  • Плата Arduino;
  • Сервомотор;
  • Провода-перемычки;

Цепь

Сервомоторы подключаются тремя проводами: питающим, заземляющим и сигнальным. Питающий провод обычно красного цвета, и его нужно подключить к 5-вольтовому контакту на Arduino. Заземляющий провод обычно черного или коричневого цвета, и его надо подключить к «земле» на Arduino. Сигнальный провод обычно желтого, оранжевого или белого цвета, и его нужно подключить к 9-ому цифровому контакту на плате Arduino.

Схема

Код

// Вращение вала сервомотора
// От BARRAGAN <http://barraganstudio.com> 
// Этот код не защищен авторским правом.


#include <Servo.h> 
 
Servo myservo;  // создаем экземпляр класса Servo, чтобы управлять сервомотором 
                // можно создать не более восьми Servo-объектов 
 
int pos = 0;    // переменная, в которой будет храниться позиция сервопривода 
 
void setup() 
{ 
  myservo.attach(9);  // привязываем сервопривод на 9-ом контакте к Servo-объекту 
} 
 
 
void loop() 
{ 
  for(pos = 0; pos < 180; pos += 1)  // вращаем с 0 градусов до 180 градусов 
  {                                  // (c шагом в один градус) 
    myservo.write(pos);              // говорим сервоприводу повернуться к позиции, хранящейся в переменной «pos» 
    delay(15);                       // ждем 15 миллисекунд, пока сервопривод повернется нужным образом 
  } 
  for(pos = 180; pos>=1; pos-=1)     // вращаем со 180 градусов до 0 градусов 
  {                                
    myservo.write(pos);              // говорим сервоприводу повернуться к позиции, хранящейся в переменной «pos»
    delay(15);                       // ждем 15 миллисекунд, пока сервопривод повернется нужным образом 
  } 
}

См.также

  1. attach()
  2. write()
  3. map()
  4. Servo library reference
  5. Knob - control the position of a servo with a potentiometer.

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