From e7e58c9ddce0438505ba3aabffbf2a5af1896071 Mon Sep 17 00:00:00 2001 From: Wohlstand Date: Fri, 17 Nov 2017 03:39:05 +0300 Subject: Added handling of XG percussion bank numbers --- src/adlmidi_midiplay.cpp | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) (limited to 'src/adlmidi_midiplay.cpp') diff --git a/src/adlmidi_midiplay.cpp b/src/adlmidi_midiplay.cpp index f8e9d6a..9fe1cfd 100644 --- a/src/adlmidi_midiplay.cpp +++ b/src/adlmidi_midiplay.cpp @@ -918,14 +918,25 @@ bool MIDIplay::realTime_NoteOn(uint8_t channel, uint8_t note, uint8_t velocity) size_t midiins = Ch[channel].patch; bool isPercussion = (channel % 16 == 9); + uint16_t bank = 0; + if(Ch[channel].bank_msb || Ch[channel].bank_lsb) + { + bank = (uint16_t(Ch[channel].bank_msb) * 256) + uint16_t(Ch[channel].bank_lsb); + if(bank == 0x7E00) //XG SFX1/SFX2 channel (16128 signed decimal) + isPercussion = true; + if(bank == 0x7F00) //XG Percussion channel (16256 signed decimal) + isPercussion = true; + } + if(isPercussion) + { + bank = (uint16_t)midiins; // MIDI instrument defines the patch midiins = opl.dynamic_percussion_offset + note; // Percussion instrument + } - uint16_t bank = 0; //Set bank bank - if(Ch[channel].bank_msb || Ch[channel].bank_lsb) + if(bank > 0) { - bank = (uint16_t(Ch[channel].bank_msb) * 256) + uint16_t(Ch[channel].bank_lsb); if(isPercussion) { OPL3::BankMap::iterator b = opl.dynamic_percussion_banks.find(bank); -- cgit v1.2.3