#include <mididrv_ms.h>
Classes | |
struct | ControllerDefaults |
struct | MidiSource |
Public Types | |
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 |
Public Member Functions | |
void | send (uint32 b) override |
void | send (int8 source, uint32 b) override=0 |
uint32 | property (int prop, uint32 param) override |
virtual void | deinitSource (uint8 source) |
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 () |
virtual void | stopAllNotes (uint8 source, uint8 channel)=0 |
void | setTimerCallback (void *timer_param, Common::TimerManager::TimerProc timer_proc) override |
![]() | |
void | midiDriverCommonSend (uint32 b) |
void | midiDriverCommonSysEx (const byte *msg, uint16 length) |
virtual int | open ()=0 |
virtual bool | isOpen () const =0 |
virtual void | close ()=0 |
virtual void | setPitchBendRange (byte channel, uint range) |
void | sendMT32Reset () |
void | sendGMReset () |
virtual uint32 | getBaseTempo ()=0 |
virtual MidiChannel * | allocateChannel ()=0 |
virtual MidiChannel * | getPercussionChannel ()=0 |
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 | sysEx (const byte *msg, uint16 length) |
virtual uint16 | sysExNoDelay (const byte *msg, uint16 length) |
virtual void | metaEvent (byte type, byte *data, uint16 length) |
virtual void | metaEvent (int8 source, byte type, byte *data, uint16 length) |
virtual void | stopAllNotes (bool stopSustainedNotes=false) |
virtual bool | isReady (int8 source=-1) |
Static Public Attributes | |
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 | applySourceVolume (uint8 source)=0 |
void | updateFading () |
virtual void | onTimer () |
![]() | |
void | midiDumpInit () |
int | midiDumpVarLength (const uint32 &delta) |
void | midiDumpDelta () |
void | midiDumpDo (uint32 b) |
void | midiDumpSysEx (const byte *msg, uint16 length) |
void | midiDumpFinish () |
Protected Attributes | |
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 uint16 | FADING_DELAY = 25 * 1000 |
Additional Inherited Members | |
![]() | |
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) |
Abstract base class for MIDI drivers supporting multiple simultaneous sources of MIDI data.
These drivers support the following features:
A driver extending this class must implement the following functions:
Specifies what happens to the volume when a fade is aborted.
The controllers and parameters for which a default value can be set using setControllerDefault.
|
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.
Implements MidiDriver_BASE.
Reimplemented in MidiDriver_MT32GM.
|
overridepure virtual |
Send a MIDI command from a specific source. If the MIDI driver does not support multiple sources, the source parameter is ignored.
Reimplemented from MidiDriver_BASE.
Implemented in MidiDriver_ADLIB_Multisource, MidiDriver_NULL_Multisource, MidiDriver_MT32GM, Audio::MidiDriver_Miles_Midi, MidiDriver_Casio, Ultima::Nuvie::MidiDriver_M_MT32, Ultima::Nuvie::MidiDriver_M_AdLib, AGOS::MidiDriver_Accolade_AdLib, and AGOS::MidiDriver_Accolade_MT32.
|
overridevirtual |
Get or set a property.
Reimplemented from MidiDriver.
Reimplemented in MidiDriver_MT32GM, and Audio::MidiDriver_Miles_Midi.
|
virtual |
Deinitializes a source. This will abort active fades and stop any active notes.
source | The source to deinitialize. |
Reimplemented in MidiDriver_ADLIB_Multisource, MidiDriver_MT32GM, Audio::MidiDriver_Miles_Midi, Ultima::Nuvie::MidiDriver_M_AdLib, AGOS::MidiDriver_Simon1_AdLib, Darkseed::MidiDriver_DarkSeedFloppy_AdLib, AGOS::MidiDriver_Accolade_AdLib, and AGOS::MidiDriver_Accolade_MT32.
void MidiDriver_Multisource::setSourceType | ( | SourceType | type | ) |
Sets the type for all sources (music or SFX).
type | The new type for all sources. |
void MidiDriver_Multisource::setSourceType | ( | uint8 | source, |
SourceType | type | ||
) |
Sets the type for a specific sources (music or SFX).
source | The source for which the type should be set. |
type | The new type for the specified source. |
void MidiDriver_Multisource::setSourceVolume | ( | uint16 | volume | ) |
Sets the source volume for all sources.
volume | The new source volume for all sources. |
void MidiDriver_Multisource::setSourceVolume | ( | uint8 | source, |
uint16 | volume | ||
) |
Sets the volume for this source. The volume values in the MIDI data sent by this source will be scaled by the source volume.
source | The source for which the source volume should be set. |
volume | The new source volume for the specified source. |
void MidiDriver_Multisource::resetSourceVolume | ( | ) |
Resets the source volume for all sources to each source's neutral volume.
void MidiDriver_Multisource::resetSourceVolume | ( | uint8 | source | ) |
Resets the volume for this source to its neutral volume.
void MidiDriver_Multisource::setSourceNeutralVolume | ( | uint16 | volume | ) |
Sets the neutral volume for all sources. See the source-specific setSourceNeutralVolume function for details.
volume | The new neutral volume for all sources. |
void MidiDriver_Multisource::setSourceNeutralVolume | ( | uint8 | source, |
uint16 | volume | ||
) |
Sets the neutral volume for this source. If the source volume is at this level, the volume values in the MIDI data sent by this source will not be changed. At source volumes below or above this value, the MIDI volume values will be decreased or increased accordingly.
source | The source for which the neutral volume should be set. |
volume | The new neutral volume for the specified source. |
void MidiDriver_Multisource::startFade | ( | uint16 | duration, |
uint16 | targetVolume | ||
) |
Starts a fade for all sources. See the source-specific startFade function for more information.
duration | The fade duration in milliseconds |
targetVolume | The volume at the end of the fade |
void MidiDriver_Multisource::startFade | ( | uint8 | source, |
uint16 | duration, | ||
uint16 | targetVolume | ||
) |
Starts a fade for a source. This will linearly increase or decrease the volume of the MIDI channels used by the source to the specified target value over the specified length of time.
source | The source to fade |
duration | The fade duration in milliseconds |
targetVolume | The volume at the end of the fade |
void MidiDriver_Multisource::abortFade | ( | FadeAbortType | abortType = FADE_ABORT_TYPE_END_VOLUME | ) |
Aborts any active fades for all sources. See the source-specific abortFade function for more information.
abortType | How to set the volume when aborting the fade (default: set to the target fade volume). |
void MidiDriver_Multisource::abortFade | ( | uint8 | source, |
FadeAbortType | abortType = FADE_ABORT_TYPE_END_VOLUME |
||
) |
Aborts an active fade for a source. Depending on the abort type, the volume will remain at the current value or be set to the start or end volume. If there is no active fade for the specified source, this function does nothing.
source | The source that should have its fade aborted |
abortType | How to set the volume when aborting the fade (default: set to the target fade volume). |
bool MidiDriver_Multisource::isFading | ( | ) |
Check if any source has an active fade.
bool MidiDriver_Multisource::isFading | ( | uint8 | source | ) |
Check if the specified source has an active fade.
void MidiDriver_Multisource::setControllerDefault | ( | ControllerDefaultType | type | ) |
Specify a controller which should be reset to its General MIDI default value when a new track is started. See the overload for more details.
type | The controller which should be reset. |
void MidiDriver_Multisource::setControllerDefault | ( | ControllerDefaultType | type, |
int16 | value | ||
) |
Specify a default value for a controller which should be set when a new track is started. Use this if a game uses a MIDI controller, but does not consistently set it to a value at the start of every track, causing incorrect playback. Do not use this if a game depends on controller values carrying over to the next track for correct playback.
This functionality will not work if the fallback MIDI source -1 is used. It is also necessary to call deinitSource whenever playback of a track is stopped, as this sets up the contoller reset.
Use the setControllerDefault(ControllerDefaultType) overload if the General MIDI default value for the controller should be used.
type | The controller which should be reset. |
value | The default value which should be set. |
void MidiDriver_Multisource::setControllerDefaults | ( | ControllerDefaultType | type, |
int16 * | values | ||
) |
Specify a default value for a controller which should be set when a new track is started. This expects an array of values, each of which will be used as the default for the corresponding MIDI channel.
This is currently only supported for program.
See setControllerDefault for more details.
type | The controller which should be reset. |
values | The default values which should be set. Must be a 16 value array. |
void MidiDriver_Multisource::clearControllerDefault | ( | ControllerDefaultType | type | ) |
Clears a previously set default value for the specified controller.
type | The controller for which the default value should be cleared. |
void MidiDriver_Multisource::setInstrumentRemapping | ( | const byte * | instrumentRemapping | ) |
Sets an instrument map for arbitrarily remapping instruments in the MIDI data. The map should consist of 128 bytes, with the index representing the instrument number in the MIDI data, and the value being the instrument which should be substituted. This instrument mapping is applied before MT-32 to GM or GM to MT-32 instrument mapping. Call this method with nullptr as parameter to clear a previously set instrument remapping.
instrumentRemapping | The instrument map that should be used for remapping, or nullptr to disable remapping. |
void MidiDriver_Multisource::syncSoundSettings | ( | ) |
Applies the user volume settings to the MIDI driver. MIDI channel volumes will be scaled using the user volume. This function must be called by the engine when the user has changed the volume settings.
|
pure virtual |
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. |
Implemented in MidiDriver_ADLIB_Multisource, MidiDriver_MT32GM, MidiDriver_NULL_Multisource, and MidiDriver_Casio.
|
inlineoverridevirtual |
Sets a callback which will be called whenever the driver's timer callback is called by the underlying emulator or hardware driver. The callback will only be called when the driver is open. Use
timer_param | A parameter that will be passed to the callback function. Optional. |
timer_proc | The function that should be called. |
Implements MidiDriver.
|
protectedpure virtual |
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. |
Implemented in MidiDriver_ADLIB_Multisource, MidiDriver_MT32GM, MidiDriver_NULL_Multisource, MidiDriver_Casio, and Audio::MidiDriver_Miles_Midi.
|
protected |
Processes active fades and sets new volume values if necessary.
|
protectedvirtual |
Runs the MIDI driver's timer related functionality. Will update volume fades and calls the timer callback if necessary.
Reimplemented in MidiDriver_MT32GM, Ultima::Nuvie::MidiDriver_M_MT32, and Ultima::Nuvie::MidiDriver_M_AdLib.
|
static |
The maximum number of sources supported. This can be increased if necessary, but this will consume more memory and processing time.
|
static |
The default neutral volume level for a source. If the source volume is set to this level, the volume levels in the MIDI data are used directly; if source volume is lower or higher, output volume is decreased or increased, respectively. Use