MCP: make v-pot press work; work ongoing on general keybindings
[ardour.git] / libs / surfaces / mackie / mcp_buttons.cc
index 37035353bc31faf68327d93326c4f5f66aee4ce8..4032785a3be480bf8b2aec7ca3ad209f61f8e291 100644 (file)
@@ -67,12 +67,14 @@ LedState
 MackieControlProtocol::control_press (Button &)
 {
        _modifier_state |= MODIFIER_CONTROL;
+       DEBUG_TRACE (DEBUG::MackieControl, string_compose ("CONTROL Press: modifier state now set to %1\n", _modifier_state));
        return on;
 }
 LedState
 MackieControlProtocol::control_release (Button &)
 {
        _modifier_state &= ~MODIFIER_CONTROL;
+       DEBUG_TRACE (DEBUG::MackieControl, string_compose ("CONTROL Release: modifier state now set to %1\n", _modifier_state));
        return on;
 }
 LedState
@@ -166,6 +168,19 @@ MackieControlProtocol::cursor_left_press (Button& )
                } else {
                        ZoomOut (); /* EMIT SIGNAL */
                }
+       } else {
+               float page_fraction;
+               if (_modifier_state == MODIFIER_CONTROL) {
+                       page_fraction = 1.0;
+               } else if (_modifier_state == MODIFIER_OPTION) {
+                       page_fraction = 0.1;
+               } else if (_modifier_state == MODIFIER_SHIFT) {
+                       page_fraction = 2.0;
+               } else {
+                       page_fraction = 0.25;
+               }
+
+               ScrollTimeline (-page_fraction);
        }
 
        return off;
@@ -187,8 +202,21 @@ MackieControlProtocol::cursor_right_press (Button& )
                } else {
                        ZoomIn (); /* EMIT SIGNAL */
                }
-       }
+       } else {
+               float page_fraction;
+               if (_modifier_state == MODIFIER_CONTROL) {
+                       page_fraction = 1.0;
+               } else if (_modifier_state == MODIFIER_OPTION) {
+                       page_fraction = 0.1;
+               } else if (_modifier_state == MODIFIER_SHIFT) {
+                       page_fraction = 2.0;
+               } else {
+                       page_fraction = 0.25;
+               }
 
+               ScrollTimeline (page_fraction);
+       }
+                       
        return off;
 }
 
@@ -202,10 +230,11 @@ LedState
 MackieControlProtocol::cursor_up_press (Button&)
 {
        if (_zoom_mode) {
-               if (_modifier_state & MODIFIER_OPTION) {
-                       VerticalZoomOutSelected (); /* EMIT SIGNAL */
+               
+               if (_modifier_state & MODIFIER_CONTROL) {
+                       VerticalZoomInSelected (); /* EMIT SIGNAL */
                } else {
-                       VerticalZoomOutAll (); /* EMIT SIGNAL */
+                       VerticalZoomInAll (); /* EMIT SIGNAL */
                }
        }
        return off;
@@ -221,11 +250,10 @@ LedState
 MackieControlProtocol::cursor_down_press (Button&)
 {
        if (_zoom_mode) {
-               
                if (_modifier_state & MODIFIER_OPTION) {
-                       VerticalZoomInSelected (); /* EMIT SIGNAL */
+                       VerticalZoomOutSelected (); /* EMIT SIGNAL */
                } else {
-                       VerticalZoomInAll (); /* EMIT SIGNAL */
+                       VerticalZoomOutAll (); /* EMIT SIGNAL */
                }
        }
        return off;
@@ -386,17 +414,11 @@ MackieControlProtocol::timecode_beats_release (Button &)
 LedState 
 MackieControlProtocol::marker_press (Button &)
 {
-       // cut'n'paste from LocationUI::add_new_location()
        string markername;
-       framepos_t where = session->audible_frame();
-       session->locations()->next_available_name(markername,"mcu");
-       Location *location = new Location (*session, where, where, markername, Location::IsMark);
-       session->begin_reversible_command (_("add marker"));
-       XMLNode &before = session->locations()->get_state();
-       session->locations()->add (location, true);
-       XMLNode &after = session->locations()->get_state();
-       session->add_command (new MementoCommand<Locations>(*(session->locations()), &before, &after));
-       session->commit_reversible_command ();
+
+       session->locations()->next_available_name (markername,"mcu");
+       add_marker (markername);
+
        return on;
 }
 
@@ -478,7 +500,11 @@ MackieControlProtocol::stop_release (Button &)
 LedState 
 MackieControlProtocol::play_press (Button &)
 {
-       transport_play ();
+       /* if we're already rolling at normal speed, and we're pressed
+          again, jump back to where we started last time
+       */
+
+       transport_play (session->transport_rolling() == 1.0);
        return none;
 }
 
@@ -530,8 +556,13 @@ MackieControlProtocol::ffwd_release (Button &)
 LedState 
 MackieControlProtocol::loop_press (Button &)
 {
-       session->request_play_loop (!session->get_play_loop());
-       return none;
+       if (_modifier_state & MODIFIER_CONTROL) {
+               set_view_mode (Loop);
+               return on;
+       } else {
+               session->request_play_loop (!session->get_play_loop());
+               return none;
+       }
 }
 
 LedState 
@@ -632,6 +663,17 @@ MackieControlProtocol::enter_release (Button &)
 { 
        return off;
 }
+
+void
+MackieControlProtocol::f_press (uint32_t fn)
+{
+#if 0
+       string action = f_action (0);
+       if (!action.empty()) {
+               access_action (action);
+       }
+#endif
+}
 LedState
 MackieControlProtocol::F1_press (Button &) 
 { 
@@ -736,12 +778,13 @@ MackieControlProtocol::io_release (Button &)
 LedState
 MackieControlProtocol::sends_press (Button &) 
 { 
-       return off; 
+       set_view_mode (Sends);
+       return on;
 }
 LedState
 MackieControlProtocol::sends_release (Button &) 
 { 
-       return off
+       return none
 }
 LedState
 MackieControlProtocol::pan_press (Button &) 
@@ -766,33 +809,35 @@ MackieControlProtocol::plugin_release (Button &)
 LedState
 MackieControlProtocol::eq_press (Button &) 
 { 
-       return off; 
+       set_view_mode (EQ);
+       return on;
 }
 LedState
 MackieControlProtocol::eq_release (Button &) 
 { 
-       return off; 
+       return none;
 }
 LedState
 MackieControlProtocol::dyn_press (Button &) 
 { 
-       return off; 
+       set_view_mode (Dynamics);
+       return on;
 }
 LedState
 MackieControlProtocol::dyn_release (Button &) 
 { 
-       return off; 
+       return none;
 }
 LedState
 MackieControlProtocol::flip_press (Button &) 
 { 
-       _flip_mode = !_flip_mode;
+       set_flip_mode (!_flip_mode);
        return (_flip_mode ? on : off);
 }
 LedState
 MackieControlProtocol::flip_release (Button &) 
 { 
-       return (_flip_mode ? on : off);
+       return none;
 }
 LedState
 MackieControlProtocol::edit_press (Button &) 
@@ -947,6 +992,7 @@ MackieControlProtocol::mixer_release (Button &)
 LedState
 MackieControlProtocol::user_a_press (Button &) 
 { 
+       transport_play (session->transport_speed() == 1.0);
        return off; 
 }
 LedState
@@ -957,6 +1003,7 @@ MackieControlProtocol::user_a_release (Button &)
 LedState
 MackieControlProtocol::user_b_press (Button &) 
 { 
+       transport_stop();
        return off; 
 }
 LedState
@@ -964,3 +1011,224 @@ MackieControlProtocol::user_b_release (Button &)
 { 
        return off; 
 }
+
+Mackie::LedState 
+MackieControlProtocol::snapshot_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::snapshot_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::read_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::read_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::write_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::write_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::fdrgroup_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::fdrgroup_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::clearsolo_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::clearsolo_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::track_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::track_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::send_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::send_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::miditracks_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::miditracks_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::inputs_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::inputs_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::audiotracks_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::audiotracks_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::audioinstruments_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::audioinstruments_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::aux_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::aux_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::busses_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::busses_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::outputs_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::outputs_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::user_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::user_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::trim_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::trim_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::latch_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::latch_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::grp_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::grp_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::nudge_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::nudge_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::replace_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::replace_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::click_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::click_release (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::view_press (Mackie::Button&) 
+{
+       return none;
+}
+Mackie::LedState 
+MackieControlProtocol::view_release (Mackie::Button&) 
+{
+       return none;
+}