habrahabr

Аппаратный DIY аудиомикшер

  • пятница, 5 июля 2024 г. в 00:00:13
https://habr.com/ru/articles/826534/

Меня это задолбало - управлять громкостью, если источников звука больше одного, особенно больно, когда надо сделать тише/громче быстро, за пару секунд. Если играете в динамичные игры с дискордом, да ещё и музыку фоном включаете, думаю вы прекрасно знаете эти неудобства. И вот, в один прекрасный день я наткнулся на Deej...

Собственно результат
Собственно результат

А в чем собственно проблема?

Казалось бы, есть отличное решение для управления громкостью любого приложения - дефолтный микшер винды, какбы да, но нет. Это хорошая вещь, но для того, что бы им воспользоваться надо совершить следующий обряд:

  • Alt tab из текущего приложения, если курсор захвачен

  • ПКМ по значку громкости

  • Выбрать пункт выпадающего меню для открытия микшера

  • Иногда приходится выбирать устройство вывода звука, почему то иногда винда считает, что мне нужно управлять громкостью монитора, на который никогда ничего не выводилось

  • Найти нужное приложения пролистав горизонтальный список, или расширив окно

  • Ура! Наконец то можно поменять громкость

Естественно это занимает какое то время, и за это время в игре может произойти что угодно. Поэтому порой проще подвинуть ползунок в плеере, или в настройках приложения, а потом не понимаешь, почему звук тихий.

Способы поменять громкость
Способы поменять громкость

Deej

На просторах гитхаба есть один хороший проект - deej, он идеально решает поставленную задачу, собирается легко из ардуйни и картона, но это не спортивно, список приложений намертво прикручен к ползунам, хочешь больше приложения - либо накидывай больше слайдеров, либо биндь несколько приложений на один потенциометр и запоминай, где есть что. Да и выглядят типовые конструкции не очень - где любимая ЛГБТ RGB подсветка?

Типичный микшер на Deej - очень просто, но красота и удобство где-то потерялись. Я не хочу гадать, где нужный ползунок, и уж точно не хочу видеть это порождение экструдера на своем столе
Типичный микшер на Deej - очень просто, но красота и удобство где-то потерялись. Я не хочу гадать, где нужный ползунок, и уж точно не хочу видеть это порождение экструдера на своем столе

В общем было разработано следующее ТЗ:

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

  • Индикация приложения, которое регулируется, что бы не забивать память, куда же я там приложение забиндил

  • Наличие подсветки - не видел ни в одном из существующих микшеров. Что у DIY, что у профессиональных подсветки слайдеров нет. С моей точки зрения это должно выглядеть круто + технический челенж

  • Минимальные размеры, но не в ущерб удобству

  • По возможности минимальный бюджет

  • Задача со звездочкой - bluetooth. До сих пор не знаю, зачем, но звучит круто

Концепт

Изначально я хотел свести использование 3д печати к минимуму, и сделать всю конструкцию на печатных платах, но это никак не сочиталось с минимальным бюджетом, поэтому количество ПП было сведено к минимально необходимой двойке

Один из первых концептов, позднее от печатной платы для дисплеев отказался
Один из первых концептов, позднее от печатной платы для дисплеев отказался

В качестве платформы рассмативались контроллеры от nordic, espressif и rp2040 от raspberry, хотелось пощупать nRF, но экономически они дороже и достать чуть сложнее, rp2040 не имеет блюпупа, поэтому выбор пал на ESP32-C3, а точнее на модуль на его основе ESP32 C3 SUPER MINI.

Да как тебя впихнуть???

Оказалось, что вписаться в 100х100мм печатной платы (как правило ПП стоят дороже при выходе за эти пределы), запихав при этом туда пять слайдеров и кучу адресной ленты между ними не такая простая задача, как казалось на первый взгляд. Как ЭТО собирать я не представлял, но вроде должно впихнуться. Ах да, спереди есть выемка, туда же можно запихать аккумулятор для автономки по bluetooth!

100 адресных светодиодов аккуратно расположились между потенциометрами
100 адресных светодиодов аккуратно расположились между потенциометрами

5 дисплеев? На один контроллер I2C?

Перерыв половину алиэкспресса были найдены десятки дисплеев, но все не то, либо маленькие, либо большие, либо I2C only, либо надо городить внешний DC-DC для повышения напряжения. В итоге идеальный дисплей был найден, но вот незадача - он поддерживает только I2C, а бит выбора адреса всего один, то есть 3 устройства с одинаковым адресом будут в любом случае.

Что сделал бы нормальный человек в этом случае? Прочитать документацию на микроконтроллер? Воткнуть мультиплексер? Слишком скучно, надо велосипед, да ещё и с квадратными колесами. В итоге был рожден I2C с CS. Спойлер - он даже заработал, но нашлось решение поприличнее - ESP32C3 имеет pinmux, и можно тупо переназначать выводы для I2C в процессе работы

Принципиальная схема
Схема верхней платы
Схема верхней платы
Дисплей
Дисплей
Нижняя плата. Из-за нехватки пинов аналоговые входы работают и на потенциометры, и на кнопки
Нижняя плата. Из-за нехватки пинов аналоговые входы работают и на потенциометры, и на кнопки

В остальном, что схема, что топология примитивны, BOM минимальный, аккумулятор можно выкинуть, тогда схема становится вообще элементарной. Хотя и в такой простоте получилось наделать ошибок...

Топология
Верхняя плата
Верхняя плата
Нижняя плата. Не спрашивайте, голоса сказали делать ЛУТом
Нижняя плата. Не спрашивайте, голоса сказали делать ЛУТом

Сборка

Я же сказал, что не оценивал трудоемкость сборки? За компактность надо платить, а компонентов заказано на 4 изделия...

Много фоток процесса сборки
Слава разработчикам МГТФ!
Слава разработчикам МГТФ!
Ленты на 3 светодиодных блока
Ленты на 3 светодиодных блока
Собственно сам блок - светодиодная лента, приклеенная к брекетам
Собственно сам блок - светодиодная лента, приклеенная к брекетам
Брекет, установленный на верхнюю ПП, тут должна быть операция приклейки рассеивателей
Брекет, установленный на верхнюю ПП, тут должна быть операция приклейки рассеивателей
Нижняя печатная плата + корпус
Нижняя печатная плата + корпус
Соединение 2х частей. Аккумулятор от вейпа, хоть какая то польза от них
Соединение 2х частей. Аккумулятор от вейпа, хоть какая то польза от них

После пары часов мучений (далеко не последних), получается такая сборка

С отражателями вышло весело - изначально рассчитывали, что рассеиватели из PETG будут недостаточно прозрачными и надо делать их специальным образом, что бы добиться полной прозрачности. После десятков образцов пришли к тому, что светодиодная лента наоборот, слишком яркая и можно просто печатать прозрачным PETG без доп настроек. Почему нельзя было просто сразу приложить к ленте? Рассеиватели разрабатывались, когда компоненты ещё на почту не пришли.

Слева - затененный рассеиватель с промежуточным слоем белого пластика (оказалось, что беллый пластик на просвет вовсе не белый), центр - стоковые параметры, справа - "стеклянная" печать PETG
Слева - затененный рассеиватель с промежуточным слоем белого пластика (оказалось, что беллый пластик на просвет вовсе не белый), центр - стоковые параметры, справа - "стеклянная" печать PETG
С рассеивателями и без них
С рассеивателями и без них

Установка рассеивателей - тот ещё квест, это практически единственный компонент, который держится на клею

Прошивка

Так как проект хоббийный, я решил поэксперементировать и попробовать все же перелезть с чистого С на С++, собственно по этой причине прошивка представляет собой невнятный кусок говнокода, который в процессе разработки оброс extern'ами, и прочей ересью, если вы хоть раз начинали новый проект на новом стеке, я думаю прекрасно понимаете о чем речь...

Из интересного - в предыдущем пункте я писал, что светодиоды оказались слишком яркими, и оптимальная яркость - 5. Нет, не 5%, хуже, 5 уровней яркости из 256, в пространстве RGB это всего 125 цветов, что мало для плавных анимаций. Выход? Есть

Можно использовать ШИМ. Не совсем ШИМ конечно, но что-то очень похожее. Да, звучит как бред, шимировать адрессные светодиоды, но это работает. Всего светодиодов последовательно 101, надо передавать 24бит на один диод, соответственно надо передать 2424 бита данных, при частоте передачи 800кГц это значит, что можно обновлять все светодиоды 330 раз в секунду. Соответственно если передавать подряд 2 яркости попеременно, можно получить промежуточные значения, на глаз мерцание не заметно, зато дополнительный бит для каждого цвета дает увеличение цветового пространства в 8 раз! С палитрой из 1000 цветов анимации получаются гораздо плавнее.

Bluetooth все же после долгих попыток удалось завести - сначала я не понимал, почему в ESP32C3 нет bluetooth, хотя в примерах он должен быть... Да, я снова забил на документацию, и пропустил абзац, что в C3 нет bluetooth, есть только BLE. Ну чтож, привет новый стек. Вроде бы все отлично? Но почему то даже примеры из ESP-IDF не работали, спасибо китайцам за бракованный чип, в котором не работал радиомодуль, а через несколько недель он вообще откинулся, подкинув квест - разбирать и перепаивать на новый модуль. Так или иначе, BLE был побежден.

Потенциометры такого формата бывают абсолютно разные, одни линейные, другие логарифмические (или какие они, хз, но точно не линейные), да ещё и бывают с разными коэфициентами. У меня именно такие, логарифмические - документации естественно никакой нет, кроме шакальных изображений с размерами от продавца на али, и то, не всеми.

Поэтому есть процедура калибровки, исходя из крайних положений и средней точки можно программно любой потенциометр превратить в линейный (спасибо ChatGPT, без него на математику ушло бы явно больше времени, чем 3 минуты). При включении надо зажать кнопки сзади, и следовать инструкции на экране

Процесс калибровки. У среднего слайдера есть доп подтяжка пина к питанию, так как это вывод BOOT у ESP32, и разведена она на китайском модуле, но работе это никак не мешает
Процесс калибровки. У среднего слайдера есть доп подтяжка пина к питанию, так как это вывод BOOT у ESP32, и разведена она на китайском модуле, но работе это никак не мешает

Осталось дело за малым - написать софт для ПК

ПКшный софт

Тут мои полномочия все, писать под python что-то сложнее скриптов с помощью ChatGPT я не уметь. Благо работал над этим проектом не один, и софт под ПК писал не я. Понятия не имею, как оно работает внутри, но работает хорошо. Все что требуется от пользователя - нарисовать иконки для своих приложений и запустить EXE.

Набор иконок, приоритет и приложение указыватеся через __Приоритет__НазваниеПроцесса
Набор иконок, приоритет и приложение указыватеся через __Приоритет__НазваниеПроцесса
Прога в трее, не закончена, но основную задачу выполняет
Прога в трее, не закончена, но основную задачу выполняет

Протокол обмена сделан таким образом, что он полностью совместим с deej, правда вывод иконок работать не будет

BOM

Не уверен, что я учел все компоненты, ибо часть брал из своих запасов, но это копеечная мелочевка. Итоговая стоимость получилась ~3000Р на один экземпляр в рассчете на изготовление 4шт. Так что и этот пункт ТЗ удалось выполнить. Естественно, не включая стоимость 3д печати и времени потраченного на сборку.

Желтым отмечены компоненты на блок кнопок (пауза, следующий/предыдущий трек), в корпусе расположены магниты и контактные площадки для этого блока, но его делать лень. По задумке он должен прикрепляться слева и держаться на магнитах.

Таблица закупок
Таблица закупок

Режимы работы

По функционалу режимов работы всего 2 - BLE и проводной. BLE включен всегда, никой процедуры подключения не требует, и если на ПКшном клиенте включен режим блютуза, соединение произойдет автоматически. То же самое по проводу, USB-CDC драйверов не требует.

Так как ничего, кроме подсветки настраивать собственно нечего, все настройки микшера относятся именно к ней. Настроить можно практически любой переодичный/статичный эффект

Пример настройки
Пример настройки

К сожалению, не все идеи работают одинаково хорошо, на то, что бы визуализировать громкость процесса так, же как это делает стандартный микшер винды было протрачено очень много времени, но результат получился так себе, зато я точно понял, что не хочу писать под WinAPI

Отображение громкости каждого отдельного процесса + режим статического цвета
Отображение громкости каждого отдельного процесса + режим статического цвета

Финал

Осторожно, ЗВУК! Собственно, демонстрация работы в реальности, примерно в таком сценарии оно используется уже больше месяца и все прекрасно работает

Ссылки на репозитории

Основной репозиторий (Прошивка/железо/3Д модели)

Приложение для ПК

Пока планов на написание документации по сборке нет, так как не уверен, что это хоть кому то надо, если будет интерес, запилю.