#include "gtkmm2ext/keyboard.h"
#include "ardour/midi_patch_manager.h"
+
#include "ardour_ui.h"
#include "midi_region_view.h"
#include "canvas_patch_change.h"
using namespace Gnome::Canvas;
using namespace MIDI::Name;
+using namespace Gtkmm2ext;
using namespace std;
/** @param x x position in pixels.
void
CanvasPatchChange::on_patch_menu_selected(const PatchPrimaryKey& key)
{
- cerr << " got patch program number " << key.program_number << endl;
_region.change_patch_change (*this, key);
}
case GDK_Up:
case GDK_KP_Up:
case GDK_uparrow:
- _region.previous_patch (*this);
+ if (Keyboard::modifier_state_contains (ev->scroll.state, Keyboard::PrimaryModifier)) {
+ _region.previous_bank (*this);
+ } else {
+ _region.previous_patch (*this);
+ }
break;
case GDK_Down:
case GDK_KP_Down:
case GDK_downarrow:
- _region.next_patch (*this);
+ if (Keyboard::modifier_state_contains (ev->scroll.state, Keyboard::PrimaryModifier)) {
+ _region.next_bank (*this);
+ } else {
+ _region.next_patch (*this);
+ }
break;
default:
break;
case GDK_SCROLL:
if (ev->scroll.direction == GDK_SCROLL_UP) {
- _region.previous_patch (*this);
+ if (Keyboard::modifier_state_contains (ev->scroll.state, Keyboard::PrimaryModifier)) {
+ _region.previous_bank (*this);
+ } else {
+ _region.previous_patch (*this);
+ }
return true;
} else if (ev->scroll.direction == GDK_SCROLL_DOWN) {
- _region.next_patch (*this);
+ if (Keyboard::modifier_state_contains (ev->scroll.state, Keyboard::PrimaryModifier)) {
+ _region.next_bank (*this);
+ } else {
+ _region.next_patch (*this);
+ }
return true;
}
break;
}
}
+void
+MidiRegionView::previous_bank (CanvasPatchChange& patch)
+{
+ if (patch.patch()->program() < 127) {
+ MIDI::Name::PatchPrimaryKey key;
+ get_patch_key_at (patch.patch()->time(), patch.patch()->channel(), key);
+ if (key.lsb > 0) {
+ key.lsb--;
+ change_patch_change (patch, key);
+ } else {
+ if (key.msb > 0) {
+ key.lsb = 127;
+ key.msb--;
+ change_patch_change (patch, key);
+ }
+ }
+ }
+}
+
+void
+MidiRegionView::next_bank (CanvasPatchChange& patch)
+{
+ if (patch.patch()->program() > 0) {
+ MIDI::Name::PatchPrimaryKey key;
+ get_patch_key_at (patch.patch()->time(), patch.patch()->channel(), key);
+ if (key.lsb < 127) {
+ key.lsb++;
+ change_patch_change (patch, key);
+ } else {
+ if (key.msb < 127) {
+ key.lsb = 0;
+ key.msb++;
+ change_patch_change (patch, key);
+ }
+ }
+ }
+}
+
void
MidiRegionView::maybe_remove_deleted_note_from_selection (CanvasNoteEvent* cne)
{
MidiRegionView::patch_entered (ArdourCanvas::CanvasPatchChange* ev)
{
ostringstream s;
- s << ((int) ev->patch()->program() + 1) << ":" << (ev->patch()->bank() + 1);
+ /* XXX should get patch name if we can */
+ s << _("Bank:") << (ev->patch()->bank() + 1) << '\n' << _("Program:") << ((int) ev->patch()->program() + 1);
show_verbose_cursor (s.str(), 10, 20);
}