-
-
Notifications
You must be signed in to change notification settings - Fork 14
Sequencer Class
This is the module that plays the parsed MIDI files using the Synthetizer
class.
Tip
If you encounter any errors in this documentation, please open an issue!
import {Sequencer} from "./spessasynth_lib/sequencer/sequencer.js";
Important
The sequencer used to take a list of MIDI
but now it takes a list of ArrayBuffer
s and strings!
const sequencer = new Sequencer(midiBuffers, synth);
- midiBuffers - an array of the MIDI files to play. Objects with two properties:
binary
: theArrayBuffer
representation of the file.altName
- alternative name of the sequence if it doesn't have one. Can be undefined. - synth - the synthetizer to use. An instance of the
Synthetizer
class.
Loads a new song list.
sequencer.loadNewSongList(midiBuffers);
- midiBuffers - an array of the parsed MIDI files to play, Objects with two properties:
binary
: theArrayBuffer
representation of the file.altName
- alternative name of the sequence if it doesn't have one. Can be undefined.
![NOTE] If only one file is supplied, the
loop
will be set to false.
Starts playing the sequence. If the sequence was paused, it won't change any controllers, but if it wasn't (ex. the time was changed) then it will go through all the controller changes from the start before playing. This function does NOT modify the current playback time!
sequencer.play(resetTime);
- resetTime - boolean, if set to
true
then the playback will start from 0. Defaults tofalse
;
Pauses the playback of the sequence.
sequencer.pause();
Stops the playback of the sequence. Currently only used internally by the pause
function.
sequencer.stop();
Plays the next song in the list.
sequencer.nextSong();
Plays the previous song in the list.
sequencer.previousSong();
Connects a given MIDI output port and plays the sequence to it.
sequencer.connectMidiOutput(output);
- output - a
MIDIOutput
object, the output port to play to.
Tip
Pass undefined
to use SpessaSynth.
Hooks up a given callback function to the song change event.
sequencer.addOnSongChangeEvent(callback, id);
- callback - the function that gets called back, takes a
MidiData
instance (the new song). - id -
string
, unique identifier for the callback. Can be anything as long as it's unique.
Important
This is the MidiData
type, not MIDI
. It has all the properties of MIDI
, except the tracks
property,
which is the actual song data.
Hooks up a given callback function to the time change event.
sequencer.addOnTimeChangeEvent(callback, id);
- callback - the function that gets called back, takes a
number
(the new time, in seconds). - id -
string
, unique identifier for the callback. Can be anything as long as it's unique.
Gets the actual MIDI
sequence, complete with track data.
const data = await sequencer.getMIDI();
Important
This function is asynchronous.
Warning
The track data can potentially have hundreds of thousands of messages for complex MIDIs. Use sparingly!
Read-only boolean, indicating that if the sequencer's playback is paused.
if(sequencer.paused)
{
console.log("Sequencer paused!");
}
else
{
console.log("Sequencer playing or stopped!");
}
Indicates how fast the song plays (1 is normal, 0.5 is half speed etc.)
sequencer.playbackRate = 0.5; // the playback speed is half the normal speed
Boolean that controls if the sequencer loops.
sequencer.loop = false; // the playback will stop after reaching the end
Property used for changing and reading the current playback time.
Returns the current playback time in seconds.
console.log("The sequences is playing for"+sequencer.currentTime+" seconds.");
Sets the current playback time. Calls stop
and then play
internally.
sequencer.currentTime = 0; // go to the start
The data of the current sequence. Essentially MIDI
except for the tracks
property (the song data).
console.log(`This song is named "${sequencer.midiData.midiName}"`);
Tip
To get the actual MIDI data, use the getMIDI
method.
Length of the track in seconds. Equivalent of Audio.duration
;
console.log(`The track lasts for ${sequencer.duration} seconds!`);
The current index of the song that's playing
console.log(sequencer.songIndex); // 0
The amount of songs in the queue.
console.log(sequencer.songsAmount); // 3
A callback function if defined. Will be called on a text event, like lyrics.
sequencer.onTextEvent = (messageData, messageType) => {
const text = new TextDecoder("utf-8").decode(messageData.buffer);
console.log("Text event:", text)
}
Parameters:
- messageData -
Uint8Array
, the message's data (excluding the statusByte). - messageType - the Status byte of the meta message useful for derermining if the message is lyrics, or something else.
Tip
If you encounter any errors in this documentation, please open an issue!
Warning
Make sure you always update worklet_processor.min.js
along with the npm package!