Skip to content

Библиотека для программного управления Servo (на базе millis/micros)

License

Notifications You must be signed in to change notification settings

GyverLibs/SoftServo

Repository files navigation

latest PIO Foo Foo Foo

Foo

SoftServo

Библиотека для программного управления Servo (на базе millis/micros)

  • Не использует дополнительный аппаратный таймер
  • Работает на millis() и micros()
  • Синтаксис как у Servo.h
  • Режим работы асинхронный и с delay
  • Повышенная произвводительность для AVR

Совместимость

Совместима со всеми Arduino платформами (используются Arduino-функции)

Содержание

Установка

  • Библиотеку можно найти по названию SoftServo и установить через менеджер библиотек в:
    • Arduino IDE
    • Arduino IDE v2
    • PlatformIO
  • Скачать библиотеку .zip архивом для ручной установки:
    • Распаковать и положить в C:\Program Files (x86)\Arduino\libraries (Windows x64)
    • Распаковать и положить в C:\Program Files\Arduino\libraries (Windows x32)
    • Распаковать и положить в Документы/Arduino/libraries/
    • (Arduino IDE) автоматическая установка из .zip: Скетч/Подключить библиотеку/Добавить .ZIP библиотеку… и указать скачанный архив
  • Читай более подробную инструкцию по установке библиотек здесь

Обновление

  • Рекомендую всегда обновлять библиотеку: в новых версиях исправляются ошибки и баги, а также проводится оптимизация и добавляются новые фичи
  • Через менеджер библиотек IDE: найти библиотеку как при установке и нажать "Обновить"
  • Вручную: удалить папку со старой версией, а затем положить на её место новую. "Замену" делать нельзя: иногда в новых версиях удаляются файлы, которые останутся при замене и могут привести к ошибкам!

Инициализация

SoftServo myservo;

Использование

void attach(int pin, int min = 500, int max = 2400);    // подключить с указанием мин и макс импульса
void detach();          // отключить
void asyncMode();       // переключить в асинхронный режим
void delayMode();       // переключить в режим задержки (по умолч)
bool tick();            // тикер, вызывать как можно чаще, в асинхронном режиме вернёт true во время отработки импульса
void write(int value);  // поставить на угол
void writeMicroseconds(int us); // поставить на импульс
int read();             // вернуть текущий угол
int readMicroseconds(); // вернуть текущий импульс
bool attached();        // true если серво подключена

Пример

Остальные примеры смотри в examples!

#include "SoftServo.h"

SoftServo myservo;

void setup() {
  myservo.attach(5);
  
  // asyncMode - вызов tick не блокирует код на величину импульса (0.7-2.5 мс)
  // но работа будет нестабильной при наличии задержек в коде
  // в этом режиме tick вернёт true на период импульса, можно запрещать
  // тяжёлые функции на этот период 
  myservo.asyncMode();
  
  // delayMode - вызов tick блокирует код на величину импульса (0.7-2.5 мс) - по умолчанию  
  myservo.delayMode();  
}

int val = 0;
void loop() {
  // тикер - вызывать как можно чаще для каждого экземпляра
  myservo.tick();
  
  // двигаем туда сюда
  static uint32_t tmr;
  if (millis() - tmr >= 50) {
    tmr = millis();    
    static int dir = 5;
    val += dir;    
    if (val >= 180 || val <= 0) dir = -dir;   // разворачиваем
    myservo.write(val);
  }
}

Версии

  • v1.0
  • v1.1 - переделан FastIO
  • v1.1.1 - убран FastIO
  • v1.2 - мелкие фиксы

Баги и обратная связь

При нахождении багов создавайте Issue, а лучше сразу пишите на почту alex@alexgyver.ru
Библиотека открыта для доработки и ваших Pull Request'ов!

При сообщении о багах или некорректной работе библиотеки нужно обязательно указывать:

  • Версия библиотеки
  • Какой используется МК
  • Версия SDK (для ESP)
  • Версия Arduino IDE
  • Корректно ли работают ли встроенные примеры, в которых используются функции и конструкции, приводящие к багу в вашем коде
  • Какой код загружался, какая работа от него ожидалась и как он работает в реальности
  • В идеале приложить минимальный код, в котором наблюдается баг. Не полотно из тысячи строк, а минимальный код

About

Библиотека для программного управления Servo (на базе millis/micros)

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages