TypeScript library for parsing, building, serializing and debugging MIDI.
There are many JS / TS MIDI parsers online, this library is unique in that not only parses MIDI, it also allows you to construct MIDI from scratch, or alter existing MIDI, in a type-safe and strict fashion. This library will let you programatically build MIDI files and guide you along the way without allowing you to write invalid data. Almost no knowledge of the MIDI spec is required, simply install and start using the library.
- The Microtonal cyclic polyrhythm generator demonstrates generating MIDI and extending this libraries modules.
- Get your data into an
ArrayBuffer
- Instantiate a
new ReadStream
with yourArrayBuffer
- Instantiate a
new File
- Call
readBytes
passing in yourReadStream
- Instantiate a
new File
- Instantiate a
new Track
and push it to your filestracks
- Instantiate any subclasses of
Event
you need, egNoteOnEvent
- Push your events to the tracks
events
- You'll need a
File
either read in or created from scratch as described above - Instantiate a
new WriteStream
- Call
writeBytes
on yourFile
passing in yourWriteStream
- You can use
toArrayBuffer
from theWriteStream
then do whatever you need toDataURL
is also provided for convenience
This library was originally conceived to work purely with files and not with real-time streams. 1.1.0 introduces some changes that make working with real-time streams easier. MIDI delta time is a concept that relates strictly to files with tracks, as opposed to real-time streams do not use delta time on events at all - we simply need to send events down the stream and timing is left entirely up to the device sending.
With that in mind, 1.1.0 introduces some changes to the internal implementation of how streams read and write events. Delta time is now read and written by the track, during read operations this is then passed down to the event factory. This means that we can now work with pure events in the context of a stream without having to worry about workarounds to remove delta time.
This should not break any projects that use this library, but may break projects that extend our classes or depend on the implementation handling delta time at an event level.
Initial release.
Clone this repository and run npm install
.
Run npm run dev
during development to see TypeScript errors.
Run npm run test
to run the entire test suite.
To run individual tests, run npm run test -- -i ./tests/FileLibrary.test.ts -t "Reads tests\\files\\test-illegal-message-fe.mid"
replacing the argument for -t
with the name of the test you wish to run.
- With thanks to Recording Blogs, Teragon Audio and Mido for insight into the MIDI spec.
- With thanks to jazz-soft for the test files.