5
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

KDDIテクノロジーAdvent Calendar 2024

Day 3

測距センサーMIDIデバイス+ブラウザ(WebAudio)でテルミン風楽器を作ってみよう!

Last updated at Posted at 2024-12-02

この投稿はKDDIテクノロジーアドベントカレンダーの12/03分の記事です。
他の記事はこちらです。
https://qiita.com/advent-calendar/2024/kddi-technology

sensor-midi.jpg

サンデープログラマーです。日曜にほっとくと変な工作を始めます。

今回は、テルミンみたいな楽器には憧れ非接触で音が変わるってかっこいい!というわけで、作ってみた変なモノの作り方の紹介です。

さて、この変なモノ、超ざっくり言うと

  • センサーをMIDIに変換して流すデバイス
  • そのデバイスから受けた情報をAudioに変換して鳴らすWebアプリ

というものなのですが、これ何で呼べば良いのかな?
デバイス?Webアプリ?音が出るのでこの組み合わせで「楽器」ということにしました。

さっそく制作方法を紹介します。
興味を持った方はぜひ制作してみてください。
多少電子工作ありますが、ちょこっとしか配線もないので簡単です!

微妙に反応は悪いので演奏用というより効果音用

先に言い訳。

MIDI→WebAudioで鳴らす構造からか、反応は悪いです。
ちゃんと「演奏」できる感じのデバイスではないですが、効果音には使えそう?ということで紹介します!

MIDIよりもWebAudioの反応が悪い気がする。別途検証予定。

必要なモノ

  • PC(Arduinoでソフト書き込んだり、Webアプリ動かしたりするやつ。USB端子がついてて、Arduino IDEとブラウザが動けばOKです。ブラウザはChromeで!)
  • 3Dプリンタ(ケースを作らなければ不要!というか、別の方法で違うモノをケースにしてもいいかもです!)
  • RP2040-Zero x 1(Raspberry Pi Picoとその互換機で代用可能ですがケースや配線は変わります)
  • VL53L0Xモジュール x 1(いろんな形のやつが売ってます。これと同じようなやつが必要)
  • 抵抗(4.7kΩ)x 2 (リード付きの1/6wのやつが小さくて工作しやすそう。頑張れる人はチップ抵抗でも!)
  • 被覆つきリード線 5cmくらい x 4
  • はんだごてとハンダ(まーなんでもいいです)
  • 外部スピーカー(大きな音で鳴らさないならPCのスピーカーで十分)

ケース用の3Dデータ(ケース作る人のみ)

ケース用の3Dデータは下記からDLしてください。というか、TinkerCadなのでコピーすれば編集できます。
プリンターによってはサポートつけたりが必要になるので、適宜ご利用のプリンターに合わせてやっちゃってください。

私は光造形プリンターを使ってるので、斜めにしてサポートつけてからスライスしてます。

Arduinoのファームウエア

RP2040-Zero用のファームウエアは下記に置いてあります。

A. センサーMIDIデバイスの制作

A-1. RP2040にファームウェアをアップロード

Arduino IDE に下記ソフトウエアを追加してください。

導入方法は各ソフトウエアのサイトを見ていただくとして、概要を書くとこんな感じです。

  • 上記追加のソフトウエアをArduino IDEにインストールする。
  • ボード設定で、RP2040 Coreの中から Waveshare RP2040 Zero を選ぶ
  • USB StackでAdafruit TinyUSB を選ぶ
  • RP2040 Zeroをアップロードモード(BOOTスイッチを押しながら電源入れる)でPCに接続したあとに、スケッチをアップロードする

これでファームが書き込めます。

A-2. RP2040とVL53L0Xを配線

RP2040-ZeroとVL53L0Xモジュールを図のように配線してください。
ケースに入れる方は基板などは使わずケーブルで配線してくださいね!

schematics.png

I2C接続なのでプルアップ抵抗が必要です。4.7Kはセンサー側につけましょう。

これで、MIDI Control Changeを送りまくるMIDIデバイスが動くようにはなりますが、センサーをうまく固定しないと使いにくいと思います。

A-3. ケースを制作(ケース作らない方は飛ばしてください)

3Dプリンターで ケースデータの出力を行なってください。

img1.jpg

3つの丸いパーツと、小さなパーツ(9個)が出力されたはずです。

写真のように、配線したRP2040を載せます。

img2.jpg

次に、中間用のパーツを上に重ねます。
小さなキャップは固定用のキャップです。重ねた時に飛び出した軸にうまく押し込んで固定してください。

img3.jpg

最後に一番上のパーツを重ねて、中央にセンサーを固定すれば完成です。

B. Webアプリの用意

Webアプリのソースコードは下記にあります。

https://github.com/tadfmac/laser-synth を git clone or zipダウンロード後展開後、

cd laser-synth
npm i
node ./app.mjs

その後、ブラウザで http://localhost:3000 にアクセスすればOKです。

と、書きましたが、Webアプリのデプロイ先がないと開発用PCでしか遊べませんね。
下記にデプロイしていますので、アクセスして遊んでみてください。

Webアプリの解説

さすがにDLして動かせ!だけだとひどいので、概要を簡単に。
見ての通り、画面はほとんど作ってませんので、音を鳴らすための方法など。

1. MIDIの有効化

MIDIの有効化は requestMIDIAccess()を呼び出すと自動的にブラウザがユーザーに対してポップアップを出して利用許可を促してくれます。

requestMIDIAccess()は、laser.mjsの先でpomidi.mjsの中で呼ばれています。

これらのモジュールは下記のように役割分担しています。

  • laser.mjs : 今回作った測距センサーデバイス専用のライブラリ
  • pomidi.mjs : 汎用WebMIDIAPIラッパー
2. デバイスの接続/外され検知

laser.mjsでデバイスの接続/外されの検知を行なっています。

Web MIDI API では、statechangeイベントでポートの接続状態の変化検知を行うことができます。

この変化検知時にイベントで通知されるportを走査して対象デバイスがあるかどうかを監視しています。

3. WebAudioのresume

最初にやってることは「はじめる」ボタンをユーザーに押してもらうことです。WebAudioはユーザー操作がないと音を出すことができません。
昔はサイトにアクセスした瞬間から音が鳴っちゃうサイトがありましたが、さすがにそれは迷惑ですからね。

「はじめる」ボタンを押した時に、AudioContext.resume()を呼び出しています。これで音が出るようになります。

4. 対象となるMIDIイベントが来たら音を鳴らす

作成したMIDIデバイスは距離情報をCC(コントロールチェンジ)80とCC81を使って流します。
このイベントが来たらコールバックする処理を laser.mjsで提供する setOnTrig()で設定しています。

setOnTrig()に設定する関数で、WebAudioを使って音を鳴らしています。
また、setOnGone()では、測距センサーの測定範囲外になった時にも呼び出すコールバックが指定できるようになっています。
このトリガーを使って、WebAudioの音の鳴動を止めています。

C. テスト

Webアプリ起動したら、USBケーブルで制作したセンサーデバイスとPCを接続しましょう。

センサーに手をかざして音が鳴れば成功です!

動画

まとめ

  • 微妙に反応は悪いがセンサーを使ってテルミンのような(?)音のなるデバイスというかWebアプリというかの制作方法をまとめました。
  • 筆者は普段は真面目に仕事しています!(こんな記事ばかり上げてるから遊んでばかりだと思われそうなので言い訳!www)
5
2
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
5
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?