Skip to content

GyverLibs/GyverMIDI

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

8 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

latest PIO Foo Foo Foo

Foo

GyverMIDI

Проигрыватель MIDI-файлов из конвертера

  • Виртуальная и программная реализация
  • Поддержка многоканальных дорожек

Перкуссия (каналы 9 и 10) идёт не частотами, а MIDI-нотами

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

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

Зависимости

GyverIO

Содержание

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

Описание классов

GyverMIDI

// базовый класс
GyverMIDI();
GyverMIDI(const Note* notes, size_t len, bool pgm = true);

// подключить ноты
void setNotes(const Note* notes, size_t len, bool pgm = true);

// запустить воспроизведение
void start();

// остановить воспроизведение
void stop();

// воспроизводится
bool isPlaying();

// тикер, вызывать в loop. Вернёт true в конце воспроизведения
virtual bool tick();

GyverMIDISoft

// наследует GyverMIDI
// программная пищалка
GyverMIDISoft(uint8_t pin, const Note* notes, size_t len, bool pgm = true);

// тикер, вызывать в loop. Вернёт true в конце воспроизведения
bool tick();

GyverMIDIMulti

// многоканальный плеер
GyverMIDIMulti(uint8_t channels);

// подключить канал
void setChannel(uint8_t n, GyverMIDI& midi);

// обработчик конца воспроизведения вида void f()
void onEnd(EndCallback cb);

// запустить воспроизведение
void start();

// остановить воспроизведение
void stop();

// воспроизводится
bool isPlaying();

// тикер, вызывать в loop
void tick();

Версии

  • v1.0

Установка

  • Библиотеку можно найти по названию GyverMIDI и установить через менеджер библиотек в:
    • 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: найти библиотеку как при установке и нажать "Обновить"
  • Вручную: удалить папку со старой версией, а затем положить на её место новую. "Замену" делать нельзя: иногда в новых версиях удаляются файлы, которые останутся при замене и могут привести к ошибкам!

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

При нахождении багов создавайте Issue, а лучше сразу пишите на почту [email protected]
Библиотека открыта для доработки и ваших Pull Request'ов!

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

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