-
-
Notifications
You must be signed in to change notification settings - Fork 15
Renderer Class
This is the module that is resposible for drawing the waveforms and the notes.
Caution
this class is not bundled with the npm package, you must copy it over by cloning this repo: src/spessasynth_lib/website/ui/renderer folder
import {Renderer} from "./website/js/renderer.js";
const renderer = new Renderer(channelColors, synth, canvas)
- channelColors - an array of 16 strings with css colors for each channel.
- synth - an instance of Synthetizer class. Used for rendering its waveforms.
- canvas - an HTMLCanvasElement. The canvas to render to.
Renders a single frame. Usually only internal
renderer.render(auto);
- auto - if set to false, the renderer won't clear the canvas or requestAnimationFrame.
Useful for integrating into other drawing scripts. Defaults to
true
The MIDI sequence data that is used for the rendering. Supplied by the Sequencer class. It's stored as an array of 16 channels, each channel being an array of events and the index of the first event in the frame. Each event has its MIDI note, absolute start time and length, both in seconds.
renderer.noteTimes = [
{
renderStartIndex: 0,
notes: [
{
midiNote: 64, // the MIDI note of the event
start: 3.4253, // absolute start time in seconds
length: 0.543 // the length of the note in seconds
},
/*... a whole lot more events go here*/
]
},
/*... 15 more of these*/
]
the noteTimes
is undefined until the sequencer suppliers it with its connectRenderer
method.
A boolean, indicating if the renderer should render the waveforms of the channels.
Defaults to true
.
A boolean, indicating if the renderer should render the notes stored in renderer.noteTimes
variable.
Defaults to true
.
In miliseconds, how long should the note take to fall from the top to the trigger area.
Sum with noteAfterTriggerTimeMs
to get the full falling time. Defaults to 1000ms.
renderer.noteFallingTimeMs = 1000; // notes will take one second to fall.
In miliseconds, how long should the note fall after being triggered. For example, if timeMs is 1000ms and afterTriggerTimeMs is 1000ms,
the total falling time will be 2000ms and the notes will be triggered (IE. lit up) in the middle.
Sum with noteFallingTimeMs
to get the full falling time.
Defaults to 0ms.
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!