X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Feditor_keyboard.cc;h=257ebc487aee69ec48164f8492d05f7e9ff7ad8d;hb=c3e7746e367b5b461f0577b548c9e29854bdde06;hp=e9082445c441b40e1bf69d4d2da2ba82b4cb0635;hpb=d6ef740e9002c7112bc47cb2d9d8d4b8609aa089;p=ardour.git diff --git a/gtk2_ardour/editor_keyboard.cc b/gtk2_ardour/editor_keyboard.cc index e9082445c4..257ebc487a 100644 --- a/gtk2_ardour/editor_keyboard.cc +++ b/gtk2_ardour/editor_keyboard.cc @@ -19,14 +19,19 @@ #include #include +#include + #include #include "editor.h" #include "region_view.h" #include "selection.h" +#include "keyboard.h" #include "i18n.h" +using namespace ARDOUR; + void Editor::kbd_driver (sigc::slot theslot, bool use_track_canvas, bool use_time_canvas, bool can_select) { @@ -34,7 +39,7 @@ Editor::kbd_driver (sigc::slot theslot, bool use_track_canvas, b double worldx, worldy; GdkEvent ev; Gdk::ModifierType mask; - Glib::RefPtr evw = track_canvas.get_window()->get_pointer (x, y, mask); + Glib::RefPtr evw = track_canvas->get_window()->get_pointer (x, y, mask); bool doit = false; if (use_track_canvas && track_canvas_event_box.get_window()->get_pointer(x, y, mask) != 0) { @@ -43,13 +48,21 @@ Editor::kbd_driver (sigc::slot theslot, bool use_track_canvas, b doit = true; } + /* any use of "keyboard mouse buttons" invalidates an existing grab + */ + + if (drag_info.item) { + drag_info.item->ungrab (GDK_CURRENT_TIME); + drag_info.item = 0; + } + if (doit) { if (entered_regionview && can_select) { selection->set (entered_regionview); } - track_canvas.window_to_world (x, y, worldx, worldy); + track_canvas->window_to_world (x, y, worldx, worldy); worldx += horizontal_adjustment.get_value(); worldy += vertical_adjustment.get_value(); @@ -63,44 +76,30 @@ Editor::kbd_driver (sigc::slot theslot, bool use_track_canvas, b } void -Editor::kbd_set_playhead_cursor () +Editor::kbd_mute_unmute_region () { - kbd_driver (mem_fun(*this, &Editor::set_playhead_cursor), true, true, false); -} + if (!selection->regions.empty ()) { -void -Editor::kbd_set_edit_cursor () -{ - kbd_driver (mem_fun(*this, &Editor::set_edit_cursor), true, true, false); -} + if (selection->regions.size() > 1) { + begin_reversible_command (_("mute regions")); + } else { + begin_reversible_command (_("mute region")); + } + for (RegionSelection::iterator i = selection->regions.begin(); i != selection->regions.end(); ++i) { -void -Editor::kbd_do_split (GdkEvent* ev) -{ - nframes_t where = event_frame (ev); + XMLNode &before = (*i)->region()->playlist()->get_state (); + (*i)->region()->set_muted (!(*i)->region()->muted ()); + XMLNode &after = (*i)->region()->playlist()->get_state (); + + session->add_command (new MementoCommand(*((*i)->region()->playlist()), &before, &after)); - if (entered_regionview) { - if (selection->regions.contains (entered_regionview)) { - split_regions_at (where, selection->regions); - } else { - RegionSelection s; - s.add (entered_regionview); - split_regions_at (where, s); } - } -} -void -Editor::kbd_split () -{ - kbd_driver (mem_fun(*this, &Editor::kbd_do_split), true, true, false); -} + commit_reversible_command (); -void -Editor::kbd_mute_unmute_region () -{ - if (entered_regionview) { + } else if (entered_regionview) { + begin_reversible_command (_("mute region")); XMLNode &before = entered_regionview->region()->playlist()->get_state(); @@ -109,50 +108,10 @@ Editor::kbd_mute_unmute_region () XMLNode &after = entered_regionview->region()->playlist()->get_state(); session->add_command (new MementoCommand(*(entered_regionview->region()->playlist()), &before, &after)); commit_reversible_command(); + } } -void -Editor::kbd_set_sync_position () -{ - kbd_driver (mem_fun(*this, &Editor::kbd_do_set_sync_position), true, true, false); -} - -void -Editor::kbd_do_set_sync_position (GdkEvent* ev) -{ - nframes_t where = event_frame (ev); - snap_to (where); - - if (entered_regionview) { - set_a_regions_sync_position (entered_regionview->region(), where); - } -} - -void -Editor::kbd_do_align (GdkEvent* ev, ARDOUR::RegionPoint what) -{ - align (what); -} - -void -Editor::kbd_align (ARDOUR::RegionPoint what) -{ - kbd_driver (bind (mem_fun(*this, &Editor::kbd_do_align), what)); -} - -void -Editor::kbd_do_align_relative (GdkEvent* ev, ARDOUR::RegionPoint what) -{ - align (what); -} - -void -Editor::kbd_align_relative (ARDOUR::RegionPoint what) -{ - kbd_driver (bind (mem_fun(*this, &Editor::kbd_do_align), what), true, true, false); -} - void Editor::kbd_do_brush (GdkEvent *ev) { @@ -165,14 +124,3 @@ Editor::kbd_brush () kbd_driver (mem_fun(*this, &Editor::kbd_do_brush), true, true, false); } -void -Editor::kbd_do_audition (GdkEvent *ignored) -{ - audition_selected_region (); -} - -void -Editor::kbd_audition () -{ - kbd_driver (mem_fun(*this, &Editor::kbd_do_audition), true, false, true); -}