X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fpatch_change.cc;h=4006cbdf469b7030ed3bf11d026edf18a4a8dc4a;hb=d92686afb4105b84b014372b6feb0ccc454a5171;hp=601011d01773da41c0dacecb5506a41f750b2eea;hpb=ced4378d0914bcfb926267772c45d1d23f3bed38;p=ardour.git diff --git a/gtk2_ardour/patch_change.cc b/gtk2_ardour/patch_change.cc index 601011d017..4006cbdf46 100644 --- a/gtk2_ardour/patch_change.cc +++ b/gtk2_ardour/patch_change.cc @@ -30,11 +30,11 @@ #include "canvas/debug.h" -#include "ardour_ui.h" #include "editor.h" #include "editor_drag.h" #include "midi_region_view.h" #include "patch_change.h" +#include "ui_config.h" using namespace MIDI::Name; using namespace std; @@ -58,15 +58,15 @@ PatchChange::PatchChange(MidiRegionView& region, _flag = new ArdourCanvas::Flag ( parent, height, - ARDOUR_UI::config()->color ("midi patch change outline"), - ARDOUR_UI::config()->color_mod ("midi patch change fill", "midi patch change fill"), + UIConfiguration::instance().color ("midi patch change outline"), + UIConfiguration::instance().color_mod ("midi patch change fill", "midi patch change fill"), ArdourCanvas::Duple (x, y), true); - + CANVAS_DEBUG_NAME (_flag, text); _flag->Event.connect (sigc::mem_fun (*this, &PatchChange::event_handler)); - _flag->set_font_description (ARDOUR_UI::config()->get_SmallFont()); + _flag->set_font_description (UIConfiguration::instance().get_SmallFont()); _flag->set_text(text); } @@ -98,12 +98,12 @@ PatchChange::initialize_popup_menus() ++bank) { Glib::RefPtr underscores = Glib::Regex::create("_"); std::string replacement(" "); - + 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) { @@ -131,13 +131,13 @@ PatchChange::initialize_popup_menus() 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 = (*patch)->name(); boost::replace_all (name, "_", " "); - + patch_menus.push_back ( Gtk::Menu_Helpers::MenuElem ( name, @@ -158,7 +158,7 @@ PatchChange::event_handler (GdkEvent* ev) { /* XXX: icky dcast */ Editor* e = dynamic_cast (&_region.get_time_axis_view().editor()); - + if (!e->internal_editing()) { return false; } @@ -176,14 +176,14 @@ PatchChange::event_handler (GdkEvent* ev) _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) { + if (Gtkmm2ext::Keyboard::is_context_menu_event (&ev->button)) { if (!_popup_initialized) { initialize_popup_menus(); _popup_initialized = true; @@ -212,6 +212,16 @@ PatchChange::event_handler (GdkEvent* ev) } break; + case GDK_KEY_RELEASE: + switch (ev->key.keyval) { + case GDK_BackSpace: + case GDK_Delete: + _region.delete_patch_change (this); + default: + break; + } + break; + case GDK_SCROLL: if (ev->scroll.direction == GDK_SCROLL_UP) { _region.step_patch(