This class handles the assignment of new MIDI notes to member channels of an active MPE zone. More...
#include <juce_MPEUtils.h>
Public Member Functions | |
MPEChannelAssigner (MPEZoneLayout::Zone zoneToUse) | |
Constructor. | |
MPEChannelAssigner (Range< int > channelRange=Range< int >(1, 17)) | |
Legacy mode constructor. | |
int | findMidiChannelForNewNote (int noteNumber) noexcept |
This method will use a set of rules recommended in the MPE specification to determine which member channel the specified MIDI note should be assigned to and will return this channel number. | |
int | findMidiChannelForExistingNote (int initialNoteOnNumber) noexcept |
If a note has been added using findMidiChannelForNewNote() this will return the channel to which it was assigned, otherwise it will return -1. | |
void | noteOff (int noteNumber, int midiChannel=-1) |
You must call this method for all note-offs that you receive so that this class can keep track of the currently playing notes internally. | |
void | allNotesOff () |
Call this to clear all currently playing notes. | |
This class handles the assignment of new MIDI notes to member channels of an active MPE zone.
To use it, create an instance passing in the MPE zone that it should operate on and then call use the findMidiChannelForNewNote() method for all note-on messages and the noteOff() method for all note-off messages.
MPEChannelAssigner::MPEChannelAssigner | ( | MPEZoneLayout::Zone | zoneToUse | ) |
Constructor.
This will assign channels within the range of the specified MPE zone.
Legacy mode constructor.
This will assign channels within the specified range.
|
noexcept |
This method will use a set of rules recommended in the MPE specification to determine which member channel the specified MIDI note should be assigned to and will return this channel number.
The rules have the following precedence:
noteNumber | the MIDI note number to be assigned to a channel |
|
noexcept |
If a note has been added using findMidiChannelForNewNote() this will return the channel to which it was assigned, otherwise it will return -1.
void MPEChannelAssigner::noteOff | ( | int | noteNumber, |
int | midiChannel = -1 ) |
You must call this method for all note-offs that you receive so that this class can keep track of the currently playing notes internally.
You can specify the channel number the note off happened on. If you don't, it will look through all channels to find the registered midi note matching the given note number.
void MPEChannelAssigner::allNotesOff | ( | ) |
Call this to clear all currently playing notes.