From 6f35a1b2b84ab6cfc5d77fd46d5e31887a1590e1 Mon Sep 17 00:00:00 2001 From: Florian Jung Date: Fri, 30 Dec 2011 17:55:58 +0000 Subject: instruments can load their patch'es drummaps automatic setting of drummap according to patch this is turned off when the user manually changes the drummap TODO: let him turn it on again moved MidiTrack::read/writeOurDrummap out to helper.cpp extended xg.idf and gs.idf to ship the drummaps still work in progress, but should be usable and stable, though incomplete --- muse2/share/instruments/gs.idf | 367 ++++++++++++++++++++++++++++++ muse2/share/instruments/xg.idf | 501 +++++++++++++++++++++++++++++++++++++++++ 2 files changed, 868 insertions(+) (limited to 'muse2/share/instruments') diff --git a/muse2/share/instruments/gs.idf b/muse2/share/instruments/gs.idf index 3368b7c9..1e8a54c0 100644 --- a/muse2/share/instruments/gs.idf +++ b/muse2/share/instruments/gs.idf @@ -214,5 +214,372 @@ + + + + + High Q + Slap + Scratch Push + Scratch Pull + Sticks + Square Click + Metronome Click + Metronome Bell + Kick Drum 2 + Kick Drum 1 + Snare Drum 1 + Snare Drum 2 + Low Tom 2 + Low Tom 1 + Mid Tom 2 + Mid Tom 1 + High Tom 2 + High Tom 1 + Shaker + Jingle Bell + Belltree + Castanets + Mute Surdo + Open Surdo + + + + + + + High Q + Slap + Scratch Push + Scratch Pull + Sticks + Square Click + Metronome Click + Metronome Bell + Kick Drum 2 + Kick Drum 1 + Snare Drum 1 + Snare Drum 2 + Room Low Tom 2 + Room Low Tom 1 + Room Mid Tom 2 + Room Mid Tom 1 + Room High Tom 2 + Room High Tom 1 + Shaker + Jingle Bell + Belltree + Castanets + Mute Surdo + Open Surdo + + + + + + + High Q + Slap + Scratch Push + Scratch Pull + Sticks + Square Click + Metronome Click + Metronome Bell + Kick Drum 2 + Mondo Kick + Gated Snare + Snare Drum 2 + Room Low Tom 2 + Room Low Tom 1 + Room Mid Tom 2 + Room Mid Tom 1 + Room High Tom 2 + Room High Tom 1 + Shaker + Jingle Bell + Belltree + Castanets + Mute Surdo + Open Surdo + + + + + + + High Q + Slap + Scratch Push + Scratch Pull + Sticks + Square Click + Metronome Click + Metronome Bell + Kick Drum 2 + Elec. Bass Drum + Elec. Snare + Gated Snare + Elec. Low Tom 2 + Elec. Low Tom 1 + Elec. Mid Tom 2 + Elec. Mid Tom 1 + Elec. High Tom 2 + Elec. High Tom 1 + Reverse Cymbal + Shaker + Jingle Bell + Belltree + Castanets + Mute Surdo + Open Surdo + + + + + + + High Q + Slap + Scratch Push + Scratch Pull + Sticks + Square Click + Metronome Click + Metronome Bell + Kick Drum 2 + 808 Bass Drum + 808 Rim Shot + 808 Snare Drum + Snare Drum 2 + 808 Low Tom 2 + 808 Closed Hi-Hat + 808 Low Tom 1 + 808 Pedal Hi-Hat + 808 Tom 2 + 808 Open Hi-Hat + 808 Mid Tom 1 + 808 High Tom 2 + 808 Cymbal + 808 High Tom 1 + Reverse Cymbal + 808 Cowbell + 808 High Conga + 808 Mid Conga + 808 Low Conga + 808 Maracas + Shaker + Jingle Bell + Belltree + Castanets + Mute Surdo + Open Surdo + + + + + + + High Q + Slap + Scratch Push + Scratch Pull + Sticks + Square Click + Metronome Click + Metronome Bell + Jazz Bass Drum 2 + Jazz Bass Drum 1 + Snare Drum 1 + Snare Drum 2 + Low Tom 2 + Low Tom 1 + Mid Tom 2 + Mid Tom 1 + High Tom 2 + High Tom 1 + Shaker + Jingle Bell + Belltree + Castanets + Mute Surdo + Open Surdo + + + + + + + High Q + Slap + Scratch Push + Scratch Pull + Sticks + Square Click + Metronome Click + Metronome Bell + Jazz Bass Drum 2 + Jazz Bass Drum 1 + Brush Tap + Brush Slap + Brush Swirl + Low Tom 2 + Low Tom 1 + Mid Tom 2 + Mid Tom 1 + High Tom 2 + High Tom 1 + Shaker + Jingle Bell + Belltree + Castanets + Mute Surdo + Open Surdo + + + + + + + Closed Hi-Hat + Pedal Hi-Hat + Open Hi-Hat + Ride Cymbal + Sticks + Square Click + Metronome Click + Metronome Bell + Concert Bass Drum 2 + Concert Bass Drum 1 + Concert Snare Drum + Castanets + Concert Snare Drum + Timpani F + Timpani F# + Timpani G + Timpani G# + Timpani A + Timpani A# + Timpani B + Timpani C + Timpani C# + Timpani D + Timpani D# + Timpani E + Timpani F + Concert Cymbal 2 + Concert Cymbal 1 + Shaker + Jingle Bell + Belltree + Castanets + Mute Surdo + Open Surdo + + + + + + + + + + + High Q + Slap + Scratch Push + Scratch Pull + Sticks + Square Click + Metronome Click + Metronome Bell + Guitar Fret Noise + Guitar Cut Noise Up + Guitar Cut Noise Down + Double Bass String Slap + Flute Key Click + Laughing + Screaming + Punch + Heartbeat + Footsteps 1 + Footsteps 2 + Applause + Door Creaking + Door Closing + Scratch + Wind Chimes + Car Engine + Car Brakes + Car Passing + Car Crash + Siren + Train + Jet Plane + Helicopter + Starship + Gun Shot + Machine Gun + Laser Gun + Explosion + Dog Bark + Horse Gallop + Birds Tweet + Rain + Thunder + Wind + Seashore + Stream + Bubble + + + + + + + + + + + + + Quijada + + Laughing + Screaming + Punch + Heartbeat + Footsteps 1 + Footsteps 2 + Applause + Door Creaking + Door Closing + Scratch + Wind Chimes + Car Engine + Car Brakes + Car Passing + Car Crash + Siren + Train + Jet Plane + Helicopter + Starship + Gun Shot + Machine Gun + Laser Gun + Explosion + Dog Bark + Horse Gallop + Birds Tweet + Rain + Thunder + Wind + Seashore + Stream + Bubble + + + diff --git a/muse2/share/instruments/xg.idf b/muse2/share/instruments/xg.idf index 4f5f586e..c281df66 100644 --- a/muse2/share/instruments/xg.idf +++ b/muse2/share/instruments/xg.idf @@ -602,5 +602,506 @@ + + + + + + Mute Surdo + Open Surdo + High Q + Whip Slap + Scratch Push + Scratch Pull + Finger Snap + Click Noise + Metronome Click + Metronome Bell + Seq Click L + Seq Click H + Brush Tap + Brush Swirl L + Brush Slap + Brush Swirl H + Snare Roll + Castanet + Snare L + Sticks + Bass Drum L + Open Rim Shot + Bass Drum M + Bass Drum H + Snare M + Snare H + Shaker + Jingle Bell + Belltree + + + + + + + Mute Surdo + Open Surdo + High Q + Whip Slap + Scratch Push + Scratch Pull + Finger Snap + Click Noise + Metronome Click + Metronome Bell + Seq Click L + Seq Click H + Brush Tap + Brush Swirl L + Brush Slap + Brush Swirl H + Snare Roll 2 + Castanet + Snare L 2 + Sticks + Bass Drum L + Open Rim Shot 2 + Bass Drum M 2 + Bass Drum H 2 + Snare M 2 + Snare H 2 + Shaker + Jingle Bell + Belltree + + + + + + + Mute Surdo + Open Surdo + High Q + Whip Slap + Scratch Push + Scratch Pull + Finger Snap + Click Noise + Metronome Click + Metronome Bell + Seq Click L + Seq Click H + Brush Tap + Brush Swirl L + Brush Slap + Brush Swirl H + Snare Roll + Castanet + Snare L + Sticks + Bass Drum L + Open Rim Shot + Bass Drum M + Room Bass Drum + Room Snare L + Room Snare H + Room Tom 1 + Room Tom 2 + Room Tom 3 + Room Tom 4 + Room Tom 5 + Room Tom 6 + Shaker + Jingle Bell + Belltree + + + + + + + Mute Surdo + Open Surdo + High Q + Whip Slap + Scratch Push + Scratch Pull + Finger Snap + Click Noise + Metronome Click + Metronome Bell + Seq Click L + Seq Click H + Brush Tap + Brush Swirl L + Brush Slap + Brush Swirl H + Snare Roll + Castanet + Rock Snare M + Sticks + Rock Bass Drum M + Open Rim Shot + Bass Drum H 3 + Rock Bass Drum + Rock Snare L + Rock Snare Rim + Rock Tom 1 + Rock Tom 2 + Rock Tom 3 + Rock Tom 4 + Rock Tom 5 + Rock Tom 6 + Shaker + Jingle Bell + Belltree + + + + + + + Mute Surdo + Open Surdo + High Q + Whip Slap + Scratch Push + Scratch Pull + Finger Snap + Click Noise + Metronome Click + Metronome Bell + Seq Click L + Seq Click H + Brush Tap + Brush Swirl L + Brush Slap + Reverse Cymbal + Snare Roll + High Q + Snare M + Sticks + Bass Drum H 4 + Open Rim Shot + Rock Bass Drum + Gated Bass Drum + Rock Snare L + Rock Snare H + Elec. Tom 1 + Elec. Tom 2 + Elec. Tom 3 + Elec. Tom 4 + Elec. Tom 5 + Elec. Tom 6 + Scratch Push + Scratch Pull + Shaker + Jingle Bell + Belltree + + + + + + + Mute Surdo + Open Surdo + High Q + Whip Slap + Scratch Push + Scratch Pull + Finger Snap + Click Noise + Metronome Click + Metronome Bell + Seq Click L + Seq Click H + Brush Tap + Brush Swirl L + Brush Slap + Reverse Cymbal + Snare Roll + High Q + Rock Snare H + Sticks + Bass Drum M + Open Rim Shot + Analog Bass Drum L + Analog Bass Drum H + Analog Side Stick + Analog Snare L + Analog Snare H + Analog Tom 1 + Analog Hi-Hat Closed 1 + Analog Tom 2 + Analog Hi-Hat Closed 2 + Analog Tom 3 + Analog Hi-Hat Open + Analog Tom 4 + Analog Tom 5 + Analog Cymbal + Analog Tom 6 + Analog Cowbell + Analog Conga H + Analog Conga M + Analog Conga L + Analog Maracas + Analog Claves + Scratch Push + Scratch Pull + Shaker + Jingle Bell + Belltree + + + + + + + Mute Surdo + Open Surdo + High Q + Whip Slap + Scratch Push + Scratch Pull + Finger Snap + Click Noise + Metronome Click + Metronome Bell + Seq Click L + Seq Click H + Brush Tap + Brush Swirl L + Brush Slap + Brush Swirl H + Snare Roll + Castanet + Snare L + Sticks + Bass Drum L + Open Rim Shot + Bass Drum M + Jazz Bass Drum + Snare M + Snare H + Jazz Tom 1 + Jazz Tom 2 + Jazz Tom 3 + Jazz Tom 4 + Jazz Tom 5 + Jazz Tom 6 + Shaker + Jingle Bell + Belltree + + + + + + + Mute Surdo + Open Surdo + High Q + Whip Slap + Scratch Push + Scratch Pull + Finger Snap + Click Noise + Metronome Click + Metronome Bell + Seq Click L + Seq Click H + Brush Tap + Brush Swirl L + Brush Slap + Brush Swirl H + Snare Roll + Castanet + Brush Slap L + Sticks + Bass Drum L + Open Rim Shot + Bass Drum M + Soft Bass Drum + Brush Slap + Brush Tap + Brush Tom 1 + Brush Tom 2 + Brush Tom 3 + Brush Tom 4 + Brush Tom 5 + Brush Tom 6 + Shaker + Jingle Bell + Belltree + + + + + + + Mute Surdo + Open Surdo + High Q + Whip Slap + Scratch Push + Scratch Pull + Finger Snap + Click Noise + Metronome Click + Metronome Bell + Seq Click L + Seq Click H + Brush Tap + Brush Swirl L + Brush Slap + Brush Swirl H + Snare Roll + Castanet + Snare L + Sticks + Bass Drum L 2 + Open Rim Shot + Gran Cassa + Gran Cassa Mute + Marching Snare H + Marching Snare M + Jazz Tom 1 + Jazz Tom 2 + Jazz Tom 3 + Jazz Tom 4 + Jazz Tom 5 + Hand Cym. Open L + Jazz Tom 6 + Hand Cym. Closed L + Hand Cym. Open H + Hand Cym. Closed H + Shaker + Jingle Bell + Belltree + + + + + + + + Guitar Cutting Noise + Guitar Cutting Noise 2 + Dist. Cut Noise + String Slap + Bass Slide + Pick Scrape + + + + + + + + + + + FL.Key Click + + + + + + + + + + + + + + + + Rain + Thunder + Wind + Stream + Bubble + Feed + + + + + + + + + + + Dog + Horse Gallop + Bird 2 + Kitty + Growl + Haunted + Ghost + Maou + + + + + + + + Dial Tone + Door Creaking + Door Slam + Scratch + Scratch 2 + Windchime + Telephone Ring 2 + + + + + + + + + + Engine Start + Tire Screech + Car Passing + Crash + Siren + Train + Jetplane + Starship + Burst Noise + Coaster + SbMarine + + + + + + Laughing + Screaming + Punch + Heartbeat + Footsteps + Applaus2 + + + + + + + + + + + Machine Gun + Laser Gun + Explosion + Firework + + + + -- cgit v1.2.3 From 30ce0c7640d9d7d8e409d485fe044426b33ea522 Mon Sep 17 00:00:00 2001 From: Florian Jung Date: Fri, 30 Dec 2011 18:29:26 +0000 Subject: removed silly song-type-depencency in MidiInstrument::getPatchName and MidiInstrument::populatePatchPopup() --- muse2/muse/instruments/minstrument.cpp | 53 ++++++++++------------------------ muse2/share/instruments/gm.idf | 3 ++ 2 files changed, 19 insertions(+), 37 deletions(-) (limited to 'muse2/share/instruments') diff --git a/muse2/muse/instruments/minstrument.cpp b/muse2/muse/instruments/minstrument.cpp index 3876fb28..3906c399 100644 --- a/muse2/muse/instruments/minstrument.cpp +++ b/muse2/muse/instruments/minstrument.cpp @@ -49,8 +49,6 @@ namespace MusECore { MidiInstrumentList midiInstruments; MidiInstrument* genericMidiInstrument; -static const char* gmdrumname = "GM-drums"; - //--------------------------------------------------------- // string2sysex //--------------------------------------------------------- @@ -1054,8 +1052,6 @@ QString MidiInstrument::getPatchName(int channel, int prog, MType mode, bool dru tmask = 4; break; case MT_GM: - if(drumchan) - return gmdrumname; tmask = 1; break; default: @@ -1067,10 +1063,8 @@ QString MidiInstrument::getPatchName(int channel, int prog, MType mode, bool dru const PatchList& pl = (*i)->patches; for (ciPatch ipl = pl.begin(); ipl != pl.end(); ++ipl) { const Patch* mp = *ipl; - if ((mp->typ & tmask) - && (pr == mp->prog) - && ((drum && mode != MT_GM) || - (mp->drum == drumchan)) + if ( (pr == mp->prog) + && (mp->drum == drum) && (hbank == mp->hbank || !hb || mp->hbank == -1) && (lbank == mp->lbank || !lb || mp->lbank == -1)) @@ -1084,49 +1078,35 @@ QString MidiInstrument::getPatchName(int channel, int prog, MType mode, bool dru // populatePatchPopup //--------------------------------------------------------- -void MidiInstrument::populatePatchPopup(MusEGui::PopupMenu* menu, int chan, MType songType, bool drum) +void MidiInstrument::populatePatchPopup(MusEGui::PopupMenu* menu, int, MType, bool drum) { menu->clear(); - int mask = 0; - bool drumchan = chan == 9; - switch (songType) { - case MT_XG: mask = 4; break; - case MT_GS: mask = 2; break; - case MT_GM: - if(drumchan) - { - int id = (0xff << 16) + (0xff << 8) + 0x00; // First patch - QAction* act = menu->addAction(gmdrumname); - //act->setCheckable(true); - act->setData(id); - return; - } - mask = 1; - break; - case MT_UNKNOWN: mask = 7; break; - } + if (pg.size() > 1) { for (ciPatchGroup i = pg.begin(); i != pg.end(); ++i) { PatchGroup* pgp = *i; - //QMenu* pm = menu->addMenu(pgp->name); MusEGui::PopupMenu* pm = new MusEGui::PopupMenu(pgp->name, menu, menu->stayOpen()); // Use the parent stayOpen here. - menu->addMenu(pm); - pm->setFont(MusEGlobal::config.fonts[0]); const PatchList& pl = pgp->patches; + bool added=false; for (ciPatch ipl = pl.begin(); ipl != pl.end(); ++ipl) { const Patch* mp = *ipl; - if ((mp->typ & mask) && - ((drum && songType != MT_GM) || - (mp->drum == drumchan)) ) + if (mp->drum == drum) { int id = ((mp->hbank & 0xff) << 16) + ((mp->lbank & 0xff) << 8) + (mp->prog & 0xff); QAction* act = pm->addAction(mp->name); - //act->setCheckable(true); act->setData(id); + added=true; } - } + if (added) + { + menu->addMenu(pm); + pm->setFont(MusEGlobal::config.fonts[0]); + } + else + delete pm; + } } else if (pg.size() == 1 ){ @@ -1134,11 +1114,10 @@ void MidiInstrument::populatePatchPopup(MusEGui::PopupMenu* menu, int chan, MTyp const PatchList& pl = pg.front()->patches; for (ciPatch ipl = pl.begin(); ipl != pl.end(); ++ipl) { const Patch* mp = *ipl; - if (mp->typ & mask) { + if (mp->drum == drum) { int id = ((mp->hbank & 0xff) << 16) + ((mp->lbank & 0xff) << 8) + (mp->prog & 0xff); QAction* act = menu->addAction(mp->name); - //act->setCheckable(true); act->setData(id); } } diff --git a/muse2/share/instruments/gm.idf b/muse2/share/instruments/gm.idf index 04bf23ff..69e02503 100644 --- a/muse2/share/instruments/gm.idf +++ b/muse2/share/instruments/gm.idf @@ -161,6 +161,9 @@ + + + -- cgit v1.2.3 From 14ed268100ece710a009c287fa4d61d7254f7aa1 Mon Sep 17 00:00:00 2001 From: Florian Jung Date: Fri, 30 Dec 2011 18:51:46 +0000 Subject: fixed gs.idf --- muse2/muse/midiedit/scoreedit.cpp | 4 +++- muse2/muse/xml.cpp | 2 +- muse2/share/instruments/gs.idf | 2 +- 3 files changed, 5 insertions(+), 3 deletions(-) (limited to 'muse2/share/instruments') diff --git a/muse2/muse/midiedit/scoreedit.cpp b/muse2/muse/midiedit/scoreedit.cpp index 055134e2..45ccd4d6 100644 --- a/muse2/muse/midiedit/scoreedit.cpp +++ b/muse2/muse/midiedit/scoreedit.cpp @@ -4679,7 +4679,9 @@ void ScoreCanvas::add_new_parts(const std::map< MusECore::Part*, std::set<%s><%s>\n", + printf("unexpected EOF reading xml file at level %d, line %d, <%s><%s><%s>\n", level, _line, _tag.toLatin1().constData(), _s1.toLatin1().constData(), _s2.toLatin1().constData()); return level == 0 ? End : Error; } diff --git a/muse2/share/instruments/gs.idf b/muse2/share/instruments/gs.idf index 1e8a54c0..9314e282 100644 --- a/muse2/share/instruments/gs.idf +++ b/muse2/share/instruments/gs.idf @@ -580,6 +580,6 @@ Bubble - + -- cgit v1.2.3