Skip to content
This repository has been archived by the owner on May 2, 2022. It is now read-only.

WebMIDI integration #25

Closed
ColemanGariety opened this issue Feb 23, 2016 · 5 comments
Closed

WebMIDI integration #25

ColemanGariety opened this issue Feb 23, 2016 · 5 comments

Comments

@ColemanGariety
Copy link

We're working on a way to build web app which takes a .mid file and basically just "plays" it in a variety of soundfonts.

This repo makes use of new AudioContext() but not navigator.requestMidiAccess.

Is there a way your "synth host" can be hooked up to, say, a midi file reader like this? https://github.com/nfroidure/MIDIPlayer

@ColemanGariety
Copy link
Author

The problem is that, as you mentioned in this issue: WebAudio/web-midi-api#45

New OSs make users jump through hoops to open a virtual MIDI port. It's a usability disaster.

So I found this which opens virtual ports: https://github.com/justinlatimer/node-midi

But it has no synths, obviously. I'm trying to put the puzzle pieces together here, can you help?

node-midi seems unable to create a real virtual output port! Does yours?

@notator
Copy link
Owner

notator commented Feb 24, 2016

https://github.com/notator/residentSf2Synth contains the code for a synth that should work for you. All you have to do is include the code for the synth on your website [1], load it with the soundfont of choice, and then send it MIDI messages. You'll have to construct those by reading the .mid file of course. The Resident Sf2 Synth works fine [2], but its by no means perfect. See the issues in its repo.

Think of it like this: Your app is the host. The synth itself implements the API for Web MIDI output devices, so you don't need the browser's implementation of the Web MIDI API, and you don't need to call navigator.requestMidiAccess. And you don't need to go through complicated low level stuff like opening virtual output ports! :-)

[1] for an example of how to do that, see
http://james-ingram-act-two.de/open-source/SimpleSoundFontSynthHost/host.html
[2] I'm using it in my own app at http://james-ingram-act-two.de/open-source/assistantPerformer/assistantPerformer.html -- see the instructions there.

@ColemanGariety
Copy link
Author

thanks!

@notator
Copy link
Owner

notator commented Feb 25, 2016

Please let me know here if you get it working. Thanks.

@ColemanGariety
Copy link
Author

@notator absolutely, although, we may go the Timidity++ route.

Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants