X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fcanvas_patch_change.cc;h=7ab0eefd8c59a107122719c2b126651b7ef0e416;hb=8b5f990267622100b3a1a7ff6fa346282aca4dda;hp=930226565dabdbf61d0e00d4ba41f43bbba7e22e;hpb=ed626628b54e67dd9621c08d82a42afaed00c7ac;p=ardour.git diff --git a/gtk2_ardour/canvas_patch_change.cc b/gtk2_ardour/canvas_patch_change.cc index 930226565d..7ab0eefd8c 100644 --- a/gtk2_ardour/canvas_patch_change.cc +++ b/gtk2_ardour/canvas_patch_change.cc @@ -19,10 +19,14 @@ #include -#include +#include + +#include "pbd/stacktrace.h" #include "gtkmm2ext/keyboard.h" -#include "ardour/midi_patch_manager.h" +#include "ardour/instrument_info.h" +#include "midi++/midnam_patch.h" + #include "ardour_ui.h" #include "midi_region_view.h" #include "canvas_patch_change.h" @@ -31,34 +35,38 @@ using namespace Gnome::Canvas; using namespace MIDI::Name; +using namespace Gtkmm2ext; using namespace std; /** @param x x position in pixels. */ CanvasPatchChange::CanvasPatchChange( - MidiRegionView& region, - Group& parent, - const string& text, - double height, - double x, - double y, - string& model_name, - string& custom_device_mode, - ARDOUR::MidiModel::PatchChangePtr patch) + MidiRegionView& region, + Group& parent, + const string& text, + double height, + double x, + double y, + ARDOUR::InstrumentInfo& info, + ARDOUR::MidiModel::PatchChangePtr patch, + bool active_channel) : CanvasFlag( - region, - parent, - height, - ARDOUR_UI::config()->canvasvar_MidiPatchChangeOutline.get(), - ARDOUR_UI::config()->canvasvar_MidiPatchChangeFill.get(), - x, - y) - , _model_name(model_name) - , _custom_device_mode(custom_device_mode) + region, + parent, + height, + (active_channel + ? ARDOUR_UI::config()->canvasvar_MidiPatchChangeOutline.get() + : ARDOUR_UI::config()->canvasvar_MidiPatchChangeInactiveChannelOutline.get()), + (active_channel + ? ARDOUR_UI::config()->canvasvar_MidiPatchChangeFill.get() + : ARDOUR_UI::config()->canvasvar_MidiPatchChangeInactiveChannelFill.get()), + x, + y) + , _info (info) , _patch (patch) , _popup_initialized(false) { - set_text(text); + set_text (text); } CanvasPatchChange::~CanvasPatchChange() @@ -68,9 +76,7 @@ CanvasPatchChange::~CanvasPatchChange() void CanvasPatchChange::initialize_popup_menus() { - boost::shared_ptr channel_name_set = - MidiPatchManager::instance() - .find_channel_name_set(_model_name, _custom_device_mode, _patch->channel()); + boost::shared_ptr channel_name_set = _info.get_patches (_patch->channel()); if (!channel_name_set) { return; @@ -78,74 +84,99 @@ CanvasPatchChange::initialize_popup_menus() const ChannelNameSet::PatchBanks& patch_banks = channel_name_set->patch_banks(); - // fill popup menu: - Gtk::Menu::MenuList& patch_bank_menus = _popup.items(); - - for (ChannelNameSet::PatchBanks::const_iterator bank = patch_banks.begin(); - bank != patch_banks.end(); - ++bank) { - Glib::RefPtr underscores = Glib::Regex::create("_"); - std::string replacement(" "); - - Gtk::Menu& patch_bank_menu = *manage(new Gtk::Menu()); - - const PatchBank::PatchNameList& patches = (*bank)->patch_name_list(); - Gtk::Menu::MenuList& patch_menus = patch_bank_menu.items(); + if (patch_banks.size() > 1) { + // fill popup menu: + Gtk::Menu::MenuList& patch_bank_menus = _popup.items(); + + for (ChannelNameSet::PatchBanks::const_iterator bank = patch_banks.begin(); + bank != patch_banks.end(); + ++bank) { + Gtk::Menu& patch_bank_menu = *manage(new Gtk::Menu()); + + const PatchNameList& patches = (*bank)->patch_name_list(); + Gtk::Menu::MenuList& patch_menus = patch_bank_menu.items(); + + for (PatchNameList::const_iterator patch = patches.begin(); + patch != patches.end(); + ++patch) { + std::string name = (*patch)->name(); + boost::replace_all (name, "_", " "); + + patch_menus.push_back( + Gtk::Menu_Helpers::MenuElem( + name, + sigc::bind(sigc::mem_fun(*this, &CanvasPatchChange::on_patch_menu_selected), + (*patch)->patch_primary_key())) ); + } + + std::string name = (*bank)->name(); + boost::replace_all (name, "_", " "); + + patch_bank_menus.push_back( + Gtk::Menu_Helpers::MenuElem( + name, + patch_bank_menu) ); + } + } else { + /* only one patch bank, so make it the initial menu */ - for (PatchBank::PatchNameList::const_iterator patch = patches.begin(); + const PatchNameList& patches = patch_banks.front()->patch_name_list(); + Gtk::Menu::MenuList& patch_menus = _popup.items(); + + for (PatchNameList::const_iterator patch = patches.begin(); patch != patches.end(); ++patch) { - std::string name = underscores->replace((*patch)->name().c_str(), -1, 0, replacement); - - patch_menus.push_back( - Gtk::Menu_Helpers::MenuElem( + std::string name = (*patch)->name(); + boost::replace_all (name, "_", " "); + + patch_menus.push_back ( + Gtk::Menu_Helpers::MenuElem ( name, - sigc::bind( - sigc::mem_fun(*this, &CanvasPatchChange::on_patch_menu_selected), - (*patch)->patch_primary_key())) ); + sigc::bind (sigc::mem_fun(*this, &CanvasPatchChange::on_patch_menu_selected), + (*patch)->patch_primary_key()))); } - - - std::string name = underscores->replace((*bank)->name().c_str(), -1, 0, replacement); - - patch_bank_menus.push_back( - Gtk::Menu_Helpers::MenuElem( - name, - patch_bank_menu) ); } } - + void CanvasPatchChange::on_patch_menu_selected(const PatchPrimaryKey& key) { - cerr << " got patch program number " << key.program_number << endl; _region.change_patch_change (*this, key); } +static bool +in_edit_mode(Editor* editor) +{ + return (editor->internal_editing() && + (editor->current_mouse_mode() == Editing::MouseObject || + editor->current_mouse_mode() == Editing::MouseDraw)); +} + bool CanvasPatchChange::on_event (GdkEvent* ev) { + /* XXX: icky dcast */ + Editor* e = dynamic_cast (&_region.get_time_axis_view().editor()); + + if (!in_edit_mode(e)) { + return false; + } + switch (ev->type) { case GDK_BUTTON_PRESS: - { - /* XXX: icky dcast */ - Editor* e = dynamic_cast (&_region.get_time_axis_view().editor()); - if (e->current_mouse_mode() == Editing::MouseObject && e->internal_editing()) { - - if (Gtkmm2ext::Keyboard::is_delete_event (&ev->button)) { - - _region.delete_patch_change (this); - return true; - - } else if (Gtkmm2ext::Keyboard::is_edit_event (&ev->button)) { - - _region.edit_patch_change (this); - return true; - - } else if (ev->button.button == 1) { - e->drags()->set (new PatchChangeDrag (e, this, &_region), ev); - return true; - } + if (Gtkmm2ext::Keyboard::is_delete_event (&ev->button)) { + + _region.delete_patch_change (this); + return true; + + } else if (Gtkmm2ext::Keyboard::is_edit_event (&ev->button)) { + + _region.edit_patch_change (this); + return true; + + } else if (ev->button.button == 1) { + e->drags()->set (new PatchChangeDrag (e, this, &_region), ev); + return true; } if (ev->button.button == 3) { @@ -153,23 +184,36 @@ CanvasPatchChange::on_event (GdkEvent* ev) initialize_popup_menus(); _popup_initialized = true; } - _popup.popup(ev->button.button, ev->button.time); + if (!_popup.items().empty()) { + _popup.popup(ev->button.button, ev->button.time); + } return true; } break; - } case GDK_KEY_PRESS: switch (ev->key.keyval) { case GDK_Up: case GDK_KP_Up: case GDK_uparrow: - _region.previous_patch (*this); + if (Keyboard::modifier_state_contains (ev->key.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->key.state, Keyboard::PrimaryModifier)) { + _region.next_bank (*this); + } else { + _region.next_patch (*this); + } + break; + case GDK_Delete: + case GDK_BackSpace: + _region.delete_patch_change (this); break; default: break; @@ -178,20 +222,28 @@ CanvasPatchChange::on_event (GdkEvent* ev) case GDK_SCROLL: if (ev->scroll.direction == GDK_SCROLL_UP) { - _region.previous_patch (*this); - return true; + if (Keyboard::modifier_state_contains (ev->scroll.state, Keyboard::PrimaryModifier)) { + _region.previous_bank (*this); + } else { + _region.previous_patch (*this); + } } else if (ev->scroll.direction == GDK_SCROLL_DOWN) { - _region.next_patch (*this); - return true; + if (Keyboard::modifier_state_contains (ev->scroll.state, Keyboard::PrimaryModifier)) { + _region.next_bank (*this); + } else { + _region.next_patch (*this); + } } - break; + return true; case GDK_ENTER_NOTIFY: _region.patch_entered (this); + return true; break; case GDK_LEAVE_NOTIFY: _region.patch_left (this); + return true; break; default: