Skip to content

Latest commit

 

History

History
82 lines (71 loc) · 4.88 KB

README.md

File metadata and controls

82 lines (71 loc) · 4.88 KB

easy-web-midi-synth-template

Demo

  • Demo
  • 音を鳴らすには、Usageを参照ください

Features

  • 開発者用のシンプルなテンプレート
    • webpageを開くだけでソフトシンセを鳴らせます
    • Tone.jsにより、リッチな音色を簡単に実装できます
    • ソースコードをテンプレートとして利用しやすい、小規模、シンプル、easyな構成

Requirement

  • 音を鳴らすには:
    • Windows + loopMIDI + ブラウザ
      • 物理MIDIキーボードシーケンサがあれば、loopMIDIなしでもOK
      • Chromeで動作確認しています
  • 開発するには:
    • Node.js

Usage

  • 音を鳴らすには:
    • loopMIDIのinstallと、port設定
      • portは一つ + ボタンで登録すれば十分です。
      • うまくいかない場合はOS再起動もお試しください。
    • MIDIシーケンサの接続
    • 演奏
      • あとは当アプリを開いて playボタン をクリックすれば演奏されます

Installation

  • 開発するには:
    • Node.js をinstallしてください
    • 当アプリのinstallは npm -i
    • 開発は npm run dev

Note

webpageを開くだけでソフトシンセを鳴らせます

  • Web MIDI のすべてのportから Note On を受信します

ソースコードをテンプレートとして利用しやすい、小規模、シンプル、easyな構成

  • テンプレートとしてのソースコード利用を楽にすることを優先しています。
  • ですので、最低限のシンプルなシンセのソースコードを用意しています。

MIDI INを受信するだけなので、シーケンサ部分は別アプリ

  • 逆を言えば、
    • MIDI OUT できるwebpageがあれば、なんでもOK、当アプリを鳴らせます
    • 物理MIDI鍵盤や、DAWのMIDI OUTなどもOK

複数 Midi Device すべてからNote Onを受信する

  • 以下は今後の課題です
    • ドロップダウンリストで選択(Shared PianoMidi Device 設定のように)
    • 自動サジェスト
      • Shared Pianoを踏襲する。なので、自動設定まではしない。
        • かわりに、サジェストにとどめる。
      • 例えば当アプリを synth_in という識別子で識別として、それを含むportをわかりやすくドロップダウンリストの上位に表示する。
      • ドロップダウンリストのメニューとしては、
        • 先頭とデフォルトはShared Pianoを踏襲して All inputs とする
        • 次に Auto : ~、例えば Auto : seq_out ___ synth_in
        • その次に、今あるportを列挙
        • 末尾はShared Piano同様 None
          • MIDI IN以外に入力のない当アプリの場合は鳴らす手段がなくなる。Shared Piano踏襲を優先する。

当projectが目指すこと

  • MIDI IN からNote Onを受信する
  • シーケンサ演奏開始し、webpageを開き、playボタンを押すだけで、音が鳴る
  • シンプルで利用しやすいソースコードにする
    • 例えばシンプルなSine Wave
  • 鳴らなくなったら、できるだけ鳴るように行動することを優先します
    • 鳴らすための調査をしやすくするためにも、シンプルで小規模なソースコードにします

当projectが目指さないこと

  • Web MIDI 未対応ブラウザや、Midi Deviceを検出しなかった場合に、代替の入力を得る方法の検討と実装と提供
  • Web MIDI 未対応ブラウザの調査と対応
  • Note On Note Off 以外の MIDIメッセージ の受信サンプル
    • 今後、Control Change 74 (カットオフ周波数)は対応予定
      • 用途は、Easy Web MIDI Knob からのCC74受信のサンプル用
  • 和音を鳴らす、ch.1だけでなくch.2~ch.16を識別して別の音色を鳴らす、複数MIDI portを利用して32ch.演奏する、その他
  • 豊富なプリセット音色、別の音色にする、音色を洗練する、その他
  • 音色データをtextarea等からedit可能にする
  • スタンダードMIDIファイルMMLほか各種音色データを音色ライブラリとして利用可能に