Только-только я разогнался с измерением всех расстояний в правом механизме и с разработкой печатных плат, оказалось, что в мае заказать платы не получится.
Так что моя прекрасная плата датчиков для 1 и 2 ряда правой клавиатуры (см. рис. 1) останется до конца мая только в виде 3D модели, т.к. www.pcbnn.ru до конца мая заказы не принимает. 🙁
Печаль печальная.
А где ещё можно заказать печатные платы в 2024 году?
Приехал ко мне мой баян из ремонта. Хочу сказать, что это совершенно однозначно были не зря потраченные деньги. Механика приведена в прекрасное состояние. Пожалуй, лучше, чем было с завода. Компрессия — моё почтение.
И я сразу ломанулся смотреть, влезут ли датчики левой клавиатуры в пространство под плоскими рычагами (см. рис. 1).
Как и думал, места под ними вполне достаточно. И сами рычаги при нажатии клавиш опускаются достаточно низко, как раз настолько, чтобы магнит был точно напротив датчика при нажатой клавише, и чтобы магнит полностью убирался из чувствительной зоны датчика при отпущенной клавише.
Датчики размещать придётся именно под рычагами. Потому что над рычагами просто нет места, если установить на место механизм с клавишами аккордов. Если в положении «выборная клавиатура» доступ к рычагам ещё есть:
то в положении «готовые аккорды» толкатели выборки полностью перекрывают доступ к рычагам:
Поэтому у меня есть и хорошая, и плохая новость одновременно. Хорошая: место под рычагами подходит для размещения датчиков идеально. Плохая: для того, чтобы туда установить плату с датчиками, нужно будет отпилить часть задней стенки корпуса (см. показанное красной стрелкой на рис. 2) и сделать её съёмной. Буду думать, как это сделать максимально аккуратно.
Приехали магниты, которые я заказал, когда заподозрил, что 4*2 — сильноваты (как потом и оказалось).
Эти — 3*1. В смысле, 3 мм диаметр и 1 мм толщина (на самом деле даже не 1, а 0.75). На рис.1 — все 200 штук.
Собрал я схемку с датчиком, чтобы проверить, как он будет срабатывать с таким магнитом. Ну, могу сказать, что для плотного монтажа они тоже могут оказаться сильноваты. Но уже есть надежда, что датчики не будут срабатывать от соседних магнитов. Надо было сразу брать 2*1, как в оригинальной статье. Зря я боялся, что они слабые.
Мой баян уже в Нижнем Новгороде, только пока ещё не доехал до пункта выдачи СДЭК. Может, вечером заберу, если повезёт.
Конечно, окончательное понимание на тему разбиения системы на блоки/платы придёт только после того, как я пойму, как в точности будут располагаться датчики Холла.
Но схемы всё равно придётся рисовать. А управляющая панель (см. рис. 1) скорее всего уже не изменится, или изменится минимально.
Когда я писал про «множко попрограммировать», я, похоже, не шутил. В исходниках уже 1666 строк кода (см. рис. 1). Это, конечно, пока ещё прототип, один класс (клавиатуры и управляющие кнопки) ещё не оформлен как надо. Прошивка уже умеет воспринимать «мызыкальные» клавиши и посылать в синтезатор соответствующие команды, и умеет показывать на основном экране основные параметры своего состояния (см. видео ниже). То есть, в принципе, «голая игралка» уже есть; и если присобачить к клавиатурам баяна датчики и подключить к макетке, то можно даже играть. Теоретически.
А практически осталось дописать:
Настройку параметров для каждой клавиатуры (всего их четыре: правая, левый бас, левый аккорд, и выборный режим левой клавиатуры, когда нет ни баса, ни аккорда, а есть только одиночные ноты, как на правой клавиатуре). Это будет прокручиваемый список на 4 столбца и на 15 строк; первые 3 строки из этого списка показываются на главном экране.
Настройку системных параметров
включение/выключение датчика давления
включение/выключение режима «Running Status»
выбор типа подключенного синтезатора (либо «General MIDI», либо «ATemp»)
Это программа-минимум. А максимум — это ещё пара интересных режимов, как, например, подключение канала ударных инструментов для баса/аккорда; эта фишка во всех электронных баянах, что я видел, её надо сделать.
Дизайн «GUI» баяна* я рисую… в экселе (см. рис. 1). Для меня он оказался самым дешевым и быстродоступным средством визуализации. Чтобы понять, что и как надо будет разместить на экране.
С индикаторами я ещё не определился. Да и не дошли ещё руки до них. Довольно много времени ушло на то, чтобы окончательно понять, как работать со строками, расположенными в PROGMEM. Как всегда, оказалось, что руководства и прочие документы пишутся для того, чтобы им следовать и делать, как написано, а не для того, чтобы на них посмотреть и сделать по-своему. Ну и затупил на ровном месте пару раз (как же без этого).
Наша служба и опасна и трудна,
И на первый взгляд, как будто не видна.
Это как раз про написание кода, который пока не производит видимых эффектов.
Я тут переконфигурил макетку для работы с дисплеем. Теперь кнопки — это не музыкальные клавиши, а управляющие кнопки с панели управления (хорошо, что это очень легко перенастраивается в прошивке). Зато теперь у меня есть кнопки, которые можно назначить на «вверх», «вниз», «вправо», «влево» и ещё 2 кнопки, которые будут в разное время выполнять разные роли.
И заодно немного причесал ранее написанное. Оформил в полноценную нормальную ардуино-библиотеку класс, работающий со светодиодами. Вытащил в отдельные .h/.cpp файлы класс с очередью событий приложения.
И доработал класс «кнопки/клавиши», чтобы можно было для управляющих кнопок включать режим «быстрого автоповтора», как на обычной компьютерной клавиатуре. Т.е. при удерживании кнопки (но не сразу, а через 0.7 с после начала удерживания), кнопка автоматически генерирует события «нажато»/»отпущено» с частотой примерно по 20 событий в секунду. Самое то, что нужно, для настройки численных параметров с помощью стрелок.
И я немного офигел, когда увидел, что библиотека для работы с экраном сожрала аж целый килобайт с лишним ОЗУ (под буфер обмена с дисплеем). Для моих нужд мне осталось всего порядка 300 байт теперь. Ну, по идее, этого должно хватить, учитывая, что я всё-всё, что можно размещаю во флеш-памяти (см. ключевое слово PROGMEM). Экран нужен, и русские буквы на нём тоже нужны; придётся терпеть.
По плану, следующий шаг — это утащить во флэш-память кое-какие константы для клавиатурного класса. Планирую освободить в ОЗУ порядка 20 байт, может чуть больше.
Получил я сегодня сообщение от почты, что я уже могу идти забирать датчики Холла.
И я в очередной раз задумался на тему максимально правильного их размещения. В правой механике места много, и при желании их там можно смонтировать как внутри герметичного объёма, так и со стороны механики. А вот слева не так всё просто.
Какие вообще есть варианты размещения датчиков со стороны механики? Сами клапаны там закрыты тягами и прочими металлическими штуками. Но есть там одно интересное место, показанное красной рамкой и стрелкой на рис. 1. Этот ряд «лепестков», по идее, и есть самое правильное место для установки датчиков. Клавиши сначала давят на эти лепестки, лепестки двигаются вниз и открывают связанные с ними клапаны. Проблема в том, что расстояние между ними очень маленькое, и вряд ли получится там разместить датчики хоть как-то (не говоря о том, чтобы разместить их там оптимально с точки зрения чувствительности).
В общем, получу баян из капремонта — обязательно примерюсь к этому месту. По фотографиям можно только гадать.