#include <mt32gm.h>
Classes | |
struct | ActiveNote |
struct | MidiChannelControlData |
struct | MidiSource |
struct | SysExData |
Public Member Functions | |
MidiDriver_MT32GM (MusicType midiType) | |
int | open () override |
virtual int | open (MidiDriver *driver, bool nativeMT32) |
void | close () override |
bool | isOpen () const override |
bool | isReady (int8 source=-1) override |
uint32 | property (int prop, uint32 param) override |
void | send (uint32 b) override |
void | send (int8 source, uint32 b) override |
void | sysEx (const byte *msg, uint16 length) override |
uint16 | sysExNoDelay (const byte *msg, uint16 length) override |
void | sysExQueue (const byte *msg, uint16 length, int8 source=-1) |
uint16 | sysExMT32 (const byte *msg, uint16 length, const uint32 targetAddress, bool queue=false, bool delay=true, int8 source=-1) |
void | metaEvent (int8 source, byte type, byte *data, uint16 length) override |
void | stopAllNotes (bool stopSustainedNotes=false) override |
void | clearSysExQueue () |
MidiChannel * | allocateChannel () override |
MidiChannel * | getPercussionChannel () override |
uint32 | getBaseTempo () override |
virtual bool | allocateSourceChannels (uint8 source, uint8 numChannels) |
void | deinitSource (uint8 source) override |
![]() | |
void | setSourceType (SourceType type) |
void | setSourceType (uint8 source, SourceType type) |
void | setSourceVolume (uint16 volume) |
void | setSourceVolume (uint8 source, uint16 volume) |
void | resetSourceVolume () |
void | resetSourceVolume (uint8 source) |
void | setSourceNeutralVolume (uint16 volume) |
void | setSourceNeutralVolume (uint8 source, uint16 volume) |
void | startFade (uint16 duration, uint16 targetVolume) |
void | startFade (uint8 source, uint16 duration, uint16 targetVolume) |
void | abortFade (FadeAbortType abortType=FADE_ABORT_TYPE_END_VOLUME) |
void | abortFade (uint8 source, FadeAbortType abortType=FADE_ABORT_TYPE_END_VOLUME) |
bool | isFading () |
bool | isFading (uint8 source) |
void | setControllerDefault (ControllerDefaultType type) |
void | setControllerDefault (ControllerDefaultType type, int16 value) |
void | setControllerDefaults (ControllerDefaultType type, int16 *values) |
void | clearControllerDefault (ControllerDefaultType type) |
void | setInstrumentRemapping (const byte *instrumentRemapping) |
void | syncSoundSettings () |
void | setTimerCallback (void *timer_param, Common::TimerManager::TimerProc timer_proc) override |
![]() | |
void | midiDriverCommonSend (uint32 b) |
void | midiDriverCommonSysEx (const byte *msg, uint16 length) |
virtual void | setPitchBendRange (byte channel, uint range) |
void | sendMT32Reset () |
void | sendGMReset () |
virtual void | setEngineSoundFont (Common::SeekableReadStream *soundFontData) |
virtual bool | acceptsSoundFontData () |
![]() | |
void | send (byte status, byte firstOp, byte secondOp) |
void | send (int8 source, byte status, byte firstOp, byte secondOp) |
virtual void | metaEvent (byte type, byte *data, uint16 length) |
Static Public Member Functions | |
static void | timerCallback (void *data) |
![]() | |
static Common::String | musicType2GUIO (uint32 musicType) |
static MidiDriver * | createMidi (DeviceHandle handle) |
static DeviceHandle | detectDevice (int flags) |
static DeviceHandle | getDeviceHandle (const Common::String &identifier) |
static bool | checkDevice (DeviceHandle handle, int flags, bool quiet) |
static MusicType | getMusicType (DeviceHandle handle) |
static Common::String | getDeviceString (DeviceHandle handle, DeviceStringType type) |
static const char * | getErrorName (int error_code) |
Static Public Attributes | |
static const byte | MT32_DEFAULT_INSTRUMENTS [8] |
static const byte | MT32_DEFAULT_PANNING [8] |
static const uint8 | MT32_DEFAULT_CHANNEL_VOLUME = 102 |
static const uint8 | GM_DEFAULT_CHANNEL_VOLUME = 100 |
static const uint8 | GS_DRUMKIT_FALLBACK_MAP [128] |
static const uint8 | MT32_DISPLAY_NUM_CHARS = 20 |
static const uint32 | MT32_DISPLAY_MEMORY_ADDRESS = 0x20 << 14 |
![]() | |
static const uint8 | MAXIMUM_SOURCES = 10 |
static const uint16 | DEFAULT_SOURCE_NEUTRAL_VOLUME = 255 |
![]() | |
static const byte | _mt32ToGm [128] |
static const byte | _gmToMt32 [128] |
![]() | |
static const uint8 | MIDI_CHANNEL_COUNT = 16 |
static const uint8 | MIDI_RHYTHM_CHANNEL = 9 |
static const byte | MIDI_COMMAND_NOTE_OFF = 0x80 |
static const byte | MIDI_COMMAND_NOTE_ON = 0x90 |
static const byte | MIDI_COMMAND_POLYPHONIC_AFTERTOUCH = 0xA0 |
static const byte | MIDI_COMMAND_CONTROL_CHANGE = 0xB0 |
static const byte | MIDI_COMMAND_PROGRAM_CHANGE = 0xC0 |
static const byte | MIDI_COMMAND_CHANNEL_AFTERTOUCH = 0xD0 |
static const byte | MIDI_COMMAND_PITCH_BEND = 0xE0 |
static const byte | MIDI_COMMAND_SYSTEM = 0xF0 |
static const byte | MIDI_CONTROLLER_BANK_SELECT_MSB = 0x00 |
static const byte | MIDI_CONTROLLER_MODULATION = 0x01 |
static const byte | MIDI_CONTROLLER_DATA_ENTRY_MSB = 0x06 |
static const byte | MIDI_CONTROLLER_VOLUME = 0x07 |
static const byte | MIDI_CONTROLLER_BALANCE = 0x08 |
static const byte | MIDI_CONTROLLER_PANNING = 0x0A |
static const byte | MIDI_CONTROLLER_EXPRESSION = 0x0B |
static const byte | MIDI_CONTROLLER_BANK_SELECT_LSB = 0x20 |
static const byte | MIDI_CONTROLLER_DATA_ENTRY_LSB = 0x26 |
static const byte | MIDI_CONTROLLER_SUSTAIN = 0x40 |
static const byte | MIDI_CONTROLLER_PORTAMENTO = 0x41 |
static const byte | MIDI_CONTROLLER_SOSTENUTO = 0x42 |
static const byte | MIDI_CONTROLLER_SOFT = 0x43 |
static const byte | MIDI_CONTROLLER_REVERB = 0x5B |
static const byte | MIDI_CONTROLLER_CHORUS = 0x5D |
static const byte | MIDI_CONTROLLER_RPN_LSB = 0x64 |
static const byte | MIDI_CONTROLLER_RPN_MSB = 0x65 |
static const byte | MIDI_CONTROLLER_ALL_SOUND_OFF = 0x78 |
static const byte | MIDI_CONTROLLER_RESET_ALL_CONTROLLERS = 0x79 |
static const byte | MIDI_CONTROLLER_ALL_NOTES_OFF = 0x7B |
static const byte | MIDI_CONTROLLER_OMNI_ON = 0x7C |
static const byte | MIDI_CONTROLLER_OMNI_OFF = 0x7D |
static const byte | MIDI_CONTROLLER_MONO_ON = 0x7E |
static const byte | MIDI_CONTROLLER_POLY_ON = 0x7F |
static const uint16 | MIDI_RPN_PITCH_BEND_SENSITIVITY = 0x0000 |
static const uint16 | MIDI_RPN_MASTER_TUNING_FINE = 0x0001 |
static const uint16 | MIDI_RPN_MASTER_TUNING_COARSE = 0x0002 |
static const uint16 | MIDI_RPN_NULL = 0x7F7F |
static const uint8 | MIDI_META_END_OF_TRACK = 0x2F |
static const uint8 | MIDI_META_SEQUENCER = 0x7F |
static const uint16 | MIDI_PITCH_BEND_DEFAULT = 0x2000 |
static const uint8 | MIDI_PANNING_DEFAULT = 0x40 |
static const uint8 | MIDI_EXPRESSION_DEFAULT = 0x7F |
static const uint16 | MIDI_MASTER_TUNING_FINE_DEFAULT = 0x2000 |
static const uint8 | MIDI_MASTER_TUNING_COARSE_DEFAULT = 0x40 |
static const uint8 | MT32_PITCH_BEND_SENSITIVITY_DEFAULT = 0x0C |
static const uint8 | GM_PITCH_BEND_SENSITIVITY_DEFAULT = 0x02 |
static const uint8 | GS_RHYTHM_FIRST_NOTE = 0x1B |
static const uint8 | GS_RHYTHM_LAST_NOTE = 0x58 |
Protected Member Functions | |
virtual void | initControlData () |
virtual void | initMidiDevice () |
virtual void | initMT32 (bool initForGM) |
virtual void | initGM (bool initForMT32, bool enableGS) |
virtual void | processEvent (int8 source, uint32 b, uint8 outputChannel, MidiChannelControlData &controlData, bool channelLockedByOtherSource=false) |
virtual void | applyControllerDefaults (uint8 source, MidiChannelControlData &controlData, uint8 outputChannel, bool channelLockedByOtherSource) |
virtual void | noteOnOff (byte outputChannel, byte command, byte note, byte velocity, int8 source, MidiChannelControlData &controlData) |
virtual void | polyAftertouch (byte outputChannel, byte note, byte pressure, int8 source, MidiChannelControlData &controlData, bool channelLockedByOtherSource=false) |
virtual void | controlChange (byte outputChannel, byte controllerNumber, byte controllerValue, int8 source, MidiChannelControlData &controlData, bool channelLockedByOtherSource=false) |
virtual void | programChange (byte outputChannel, byte patchId, int8 source, MidiChannelControlData &controlData, bool channelLockedByOtherSource=false) |
virtual void | channelAftertouch (byte outputChannel, byte pressure, int8 source, MidiChannelControlData &controlData, bool channelLockedByOtherSource=false) |
virtual void | pitchBend (byte outputChannel, uint8 pitchBendLsb, uint8 pitchBendMsb, int8 source, MidiChannelControlData &controlData, bool channelLockedByOtherSource=false) |
virtual bool | addActiveNote (uint8 outputChannel, uint8 note, int8 source) |
virtual bool | removeActiveNote (uint8 outputChannel, uint8 note, int8 source) |
virtual void | removeActiveNotes (uint8 outputChannel, bool sustainedNotes) |
bool | isOutputChannelUsed (int8 outputChannel) |
virtual byte | mapMT32InstrumentToGM (byte mt32Instrument) |
virtual byte | mapGMInstrumentToMT32 (byte gmInstrument) |
byte | correctInstrumentBank (byte outputChannel, byte patchId) |
virtual int8 | mapSourceChannel (uint8 source, uint8 dataChannel) |
void | applySourceVolume (uint8 source) override |
void | stopAllNotes (uint8 source, uint8 channel) override |
void | onTimer () override |
![]() | |
void | updateFading () |
![]() | |
void | midiDumpInit () |
int | midiDumpVarLength (const uint32 &delta) |
void | midiDumpDelta () |
void | midiDumpDo (uint32 b) |
void | midiDumpSysEx (const byte *msg, uint16 length) |
void | midiDumpFinish () |
Protected Attributes | |
Common::Mutex | _allocationMutex |
Common::Mutex | _activeNotesMutex |
MidiDriver * | _driver |
MusicType | _midiType |
bool | _nativeMT32 |
bool | _enableGS |
bool | _midiDataReversePanning |
bool | _midiDeviceReversePanning |
bool | _scaleGSPercussionVolumeToMT32 |
bool | _isOpen |
uint16 | _outputChannelMask |
int | _baseFreq |
MidiChannelControlData * | _controlData [MIDI_CHANNEL_COUNT] |
int8 | _channelMap [MAXIMUM_SOURCES][MIDI_CHANNEL_COUNT] |
uint16 | _availableChannels [MAXIMUM_SOURCES] |
const byte * | _mt32ToGMInstrumentMap |
const byte * | _gmToMT32InstrumentMap |
uint8 | _maximumActiveNotes |
ActiveNote * | _activeNotes |
uint32 | _sysExDelay |
Common::List< SysExData > | _sysExQueue |
Common::Mutex | _sysExQueueMutex |
![]() | |
MidiSource | _sources [MAXIMUM_SOURCES] |
ControllerDefaults | _controllerDefaults |
const byte * | _instrumentRemapping |
bool | _userVolumeScaling |
uint16 | _userMusicVolume |
uint16 | _userSfxVolume |
bool | _userMute |
Common::Mutex | _fadingMutex |
uint16 | _fadeDelay |
uint32 | _timerRate |
void * | _timer_param |
Common::TimerManager::TimerProc | _timer_proc |
![]() | |
bool | _midiDumpEnable |
uint32 | _prevMillis |
Common::Array< byte > | _midiDumpCache |
Static Protected Attributes | |
static const uint8 | MAXIMUM_MT32_ACTIVE_NOTES = 48 |
static const uint8 | MAXIMUM_GM_ACTIVE_NOTES = 96 |
![]() | |
static const uint16 | FADING_DELAY = 25 * 1000 |
Additional Inherited Members | |
![]() | |
enum | SourceType { SOURCE_TYPE_UNDEFINED, SOURCE_TYPE_MUSIC, SOURCE_TYPE_SFX } |
enum | FadeAbortType { FADE_ABORT_TYPE_END_VOLUME, FADE_ABORT_TYPE_CURRENT_VOLUME, FADE_ABORT_TYPE_START_VOLUME } |
enum | ControllerDefaultType { CONTROLLER_DEFAULT_PROGRAM, CONTROLLER_DEFAULT_INSTRUMENT_BANK, CONTROLLER_DEFAULT_DRUMKIT, CONTROLLER_DEFAULT_CHANNEL_PRESSURE, CONTROLLER_DEFAULT_PITCH_BEND, CONTROLLER_DEFAULT_MODULATION, CONTROLLER_DEFAULT_VOLUME, CONTROLLER_DEFAULT_PANNING, CONTROLLER_DEFAULT_EXPRESSION, CONTROLLER_DEFAULT_SUSTAIN, CONTROLLER_DEFAULT_RPN, CONTROLLER_DEFAULT_PITCH_BEND_SENSITIVITY } |
![]() | |
enum | DeviceStringType { kDriverName, kDriverId, kDeviceName, kDeviceId } |
enum | { MERR_CANNOT_CONNECT = 1, MERR_DEVICE_NOT_AVAILABLE = 3, MERR_ALREADY_OPEN = 4 } |
enum | { PROP_OLD_ADLIB = 2, PROP_CHANNEL_MASK = 3, PROP_SCUMM_OPL3 = 4, PROP_USER_VOLUME_SCALING = 5, PROP_MIDI_DATA_REVERSE_PANNING = 6, PROP_OPL_ACCURACY_MODE = 7, PROP_OPL_CHANNEL_ALLOCATION_MODE = 8, PROP_MILES_VERSION = 9, PROP_OPL_RHYTHM_MODE_IGNORE_NOTE_OFF = 10 } |
typedef uint32 | DeviceHandle |
MIDI driver for MT-32 and GM compatible emulators and devices.
This class contains some commonly needed functionality for these devices and the MIDI data that targets them. It wraps the MidiDriver instance that does the actual communication with the MT-32 or GM device.
This driver has the following features:
|
overridevirtual |
|
overridevirtual |
Close the midi driver.
Implements MidiDriver.
|
inlineoverridevirtual |
Check whether the midi driver has already been opened.
Implements MidiDriver.
|
overridevirtual |
A driver implementation might need time to prepare playback of a track. Use this function to check if the driver is ready to receive MIDI events.
source | Check if the driver is ready to receive events from this specific source. Specify -1 to check readiness regardless of source. |
Reimplemented from MidiDriver_BASE.
|
overridevirtual |
Get or set a property.
Reimplemented from MidiDriver_Multisource.
|
overridevirtual |
Output a packed midi command to the midi stream. The 'lowest' byte (i.e. b & 0xFF) is the status code, then come (if used) the first and second opcode.
Reimplemented from MidiDriver_Multisource.
|
overridevirtual |
Send a MIDI command from a specific source. If the MIDI driver does not support multiple sources, the source parameter is ignored.
Implements MidiDriver_Multisource.
Reimplemented in Ultima::Nuvie::MidiDriver_M_MT32, and AGOS::MidiDriver_Accolade_MT32.
|
overridevirtual |
Transmit a SysEx to the MIDI device.
The given msg MUST NOT contain the usual SysEx frame, i.e. do NOT include the leading 0xF0 and the trailing 0xF7.
Furthermore, the maximal supported length of a SysEx is 268 bytes. Passing longer buffers can lead to undefined behavior (most likely, a crash).
Reimplemented from MidiDriver_BASE.
|
overridevirtual |
Transmit a SysEx to the MIDI device and return the necessary delay until the next SysEx event in milliseconds.
This can be used to implement an alternate delay method than the OSystem::delayMillis function used by most sysEx implementations. Note that not every driver needs a delay, or supports this method. In this case, 0 is returned and the driver itself will do a delay if necessary.
For information on the SysEx data requirements, see the sysEx method.
Reimplemented from MidiDriver_BASE.
void MidiDriver_MT32GM::sysExQueue | ( | const byte * | msg, |
uint16 | length, | ||
int8 | source = -1 |
||
) |
Puts a SysEx message on the SysEx queue. The message will be sent when the device is ready to receive it, without blocking the thread. Use the isReady function to determine if the SysEx has been sent. Other MIDI messages (not using the queue) should not be sent until the queue is empty.
uint16 MidiDriver_MT32GM::sysExMT32 | ( | const byte * | msg, |
uint16 | length, | ||
const uint32 | targetAddress, | ||
bool | queue = false , |
||
bool | delay = true , |
||
int8 | source = -1 |
||
) |
Write data to an MT-32 memory location using a SysEx message. This function will add the necessary header and checksum bytes.
msg | Pointer to the data to write to a memory location |
length | The data length |
targetAddress | The start memory address in 8 bit format. Note that MT-32 memory addresses are sometimes specified in 7 bit format; these must be converted (f.e. System Area: 10 00 00 -> 04 00 00). |
queue | Specify this parameter to use the SysEx queue to send the message (see sysExQueue for more information). |
delay | Set this to false to disable the delay to ensure that the MT-32 has enough time to process the message. This parameter has no effect if queue is true. |
|
overridevirtual |
Send a meta event from a specific source. If the MIDI driver does not support multiple sources, the source parameter is ignored.
Reimplemented from MidiDriver_BASE.
Reimplemented in Ultima::Nuvie::MidiDriver_M_MT32.
|
overridevirtual |
Stops all currently active notes. Specify stopSustainedNotes if the MIDI data makes use of the sustain controller to make sure sustained notes are also stopped.
Usually, the MIDI parser tracks active notes and terminates them when playback is stopped. This method should be used as a backup to silence the MIDI output in case the MIDI parser makes a mistake when tracking acive notes. It can also be used when quitting or pausing a game.
By default, this method sends an All Notes Off message and, if stopSustainedNotes is true, a Sustain off message on all MIDI channels. Driver implementations can override this if they want to implement this functionality in a different way.
Reimplemented from MidiDriver_BASE.
Reimplemented in Ultima::Nuvie::MidiDriver_M_MT32.
void MidiDriver_MT32GM::clearSysExQueue | ( | ) |
Removes all SysEx messages in the SysEx queue.
|
overridevirtual |
The time in microseconds between invocations of the timer callback.
Implements MidiDriver.
|
virtual |
Allocates a number of MIDI channels for use by the specified source. By default this implements a simple algorithm which allocates the unallocated channel(s) with the lowest numbers. The channel numbers in the MIDI data sent by this source will be mapped to the allocated MIDI output channels. The function can be overridden to implement more complex channel allocation algorithms. Channels are freed when the source is deinitialized. Note that sources are not required to allocate channels, so if sources use conflicting MIDI channels, make sure to use this function consistently.
source | The source for which to allocate channels |
numChannels | The number of channels to allocate |
|
overridevirtual |
Deinitializes a source. This will abort active fades, free any output channels allocated to the source and stop active notes.
Reimplemented from MidiDriver_Multisource.
Reimplemented in AGOS::MidiDriver_Accolade_MT32.
|
protectedvirtual |
This will initialize the _controlData array with the default values for MT-32 or GM (depending on the _nativeMT32 value).
Reimplemented in Audio::MidiDriver_Miles_Midi.
|
protectedvirtual |
Initializes the MIDI device. Will call initMT32 or initGM.
Reimplemented in Audio::MidiDriver_Miles_Midi.
|
protectedvirtual |
Initializes the MT-32 MIDI device. The device will be reset and, if the parameter is specified, set up for General MIDI data.
initForGM | True if the MT-32 should be initialized for GM mapping |
|
protectedvirtual |
Initializes the General MIDI device. The device will be reset. If the initForMT32 parameter is specified, the device will be set up for MT-32 MIDI data. If the device supports Roland GS, the enableGS parameter can be specified for enhanced GS MT-32 compatibility.
initForMT32 | True if the device should be initialized for MT-32 mapping |
enableGS | True if the device should be initialized for GS MT-32 mapping |
|
protectedvirtual |
Processes a MIDI event. The type of event is determined and the corresponding function is called to handle the event. This function is called after mapping the MIDI data channel to an output channel, so the specified output channel is used and not the channel in the event bytes.
source | The source of the event |
b | The event MIDI bytes |
outputChannel | The output channel for the event |
controlData | The control data set to use when processing the event |
channelLockedByOtherSource | True if the output channel is locked by another source. This will prevent the event from actually being sent to the MIDI device, but controlData will be updated. Default is false. |
|
protectedvirtual |
Applies the controller default settings to the specified output channel for the specified source. This will set all default values specified on _controllerDefaults on the channel except sustain, which is set by deinitSource.
source | The source triggering the default settings |
controlData | The control data set to use when setting the defaults |
outputChannel | The output channel on which the defaults should be set |
channelLockedByOtherSource | True if the output channel is locked by another source. This will prevent the defaults from actually being sent to the MIDI device, but controlData will be updated. Default is false. |
|
protectedvirtual |
Processes a note on or off MIDI event. This will apply source volume if necessary, update the active note registration and send the event to the MIDI device.
outputChannel | The MIDI output channel for the event |
command | The MIDI command byte |
controlData | The control data set that will be used for applying source volume |
|
protectedvirtual |
Processes a polyphonic aftertouch MIDI event. This implementation will just send the event to the MIDI device.
outputChannel | The MIDI output channel for the event |
note | The note on which aftertouch should be applied |
pressure | The amount of pressure which should be applied |
source | The source of the event |
controlData | The control data set for the MIDI channel |
channelLockedByOtherSource | True if the output channel is locked by another source. Default is false. |
|
protectedvirtual |
Process a control change MIDI event. This will update the specified control data set and apply other processing if necessary, and then send the event to the MIDI device.
outputChannel | The MIDI output channel for the event |
controlData | The control data set that the new controller value should be stored on |
channelLockedByOtherSource | True if the output channel is locked by another source. Default is false. |
|
protectedvirtual |
Process a program change MIDI event. This will update the specified control data set, apply MT-32 <> GM instrument mapping and other processing, and send the event to the MIDI device.
outputChannel | The MIDI output channel for the event |
controlData | The control data set that the new program value should be stored on |
channelLockedByOtherSource | True if the output channel is locked by another source. Default is false. |
|
protectedvirtual |
Processes a channel aftertouch MIDI event. This whil update the specified control data set and send the event to the MIDI device.
outputChannel | The MIDI output channel for the event |
pressure | The amount of pressure which should be applied |
source | The source of the event |
controlData | The control data set for the MIDI channel |
channelLockedByOtherSource | True if the output channel is locked by another source. Default is false. |
|
protectedvirtual |
Processes a pitch bend MIDI event. This whil update the specified control data set and send the event to the MIDI device.
outputChannel | The MIDI output channel for the event |
pitchBendLsb | The pitch bend LSB |
pitchBendMsb | The pitch bend MSB |
source | The source of the event |
controlData | The control data set for the MIDI channel |
channelLockedByOtherSource | True if the output channel is locked by another source. Default is false. |
|
protectedvirtual |
Adds a note to the active note registration.
|
protectedvirtual |
Removes a note from the active note registration.
|
protectedvirtual |
Removes all sustained or all non-sustained notes on the specified MIDI channel from the active note registration.
|
protected |
Returns true if the MIDI device uses the specified MIDI channel.
|
protectedvirtual |
Maps the specified MT-32 instrument to an equivalent GM instrument. This implementation looks up the instrument in the _mt32ToGMInstrumentMap array. Override this function to implement more complex mapping schemes.
|
protectedvirtual |
Maps the specified GM instrument to an equivalent MT-32 instrument. This implementation looks up the instrument in the _gmToMT32InstrumentMap array. Override this function to implement more complex mapping schemes.
|
protected |
Checks if the currently selected GS bank / instrument variation on the specified channel is valid for the specified patch. If this is not the case, the correct bank will be returned which can be set by sending a bank select message. If no correction is needed, 0xFF will be returned. This emulates the fallback functionality of the Roland SC-55 v1.2x, on which some games rely to correct wrong bank selects.
|
protectedvirtual |
Returns the MIDI output channel mapped to the specified data channel. If the data channel has not been mapped yet, a new mapping to one of the output channels available to the source will be created.
source | The source using the data channel |
dataChannel | The data channel to map |
Reimplemented in AGOS::MidiDriver_Accolade_MT32.
|
overrideprotectedvirtual |
Applies the current source volume to the active notes and/or MIDI channels of the specified source. 0xFF can be specified to apply the source volume for all sources.
source | The source for which the source volume should be applied, or all sources if 0xFF is specified. |
Implements MidiDriver_Multisource.
|
overrideprotectedvirtual |
Stops all active notes (including sustained notes) for the specified source and MIDI channel. For both source and channel the value 0xFF can be specified, in which case active notes will be stopped for all sources and/or MIDI channels.
source | The source for which all notes should be stopped, or all sources if 0xFF is specified. |
channel | The MIDI channel on which all notes should be stopped, or all channels if 0xFF is specified. |
Implements MidiDriver_Multisource.
|
overrideprotectedvirtual |
Runs the MIDI driver's timer related functionality. Will update volume fades and sends messages from the SysEx queue if necessary.
Reimplemented from MidiDriver_Multisource.
Reimplemented in Ultima::Nuvie::MidiDriver_M_MT32.