mackie: semi-working Sends subview mode
[ardour.git] / libs / surfaces / mackie / mcp_buttons.cc
index 5bf52ce4c4cf771c140a13ba771dade1db764328..c239004e5954c6b8fce4974827be8b207a259978 100644 (file)
@@ -22,6 +22,7 @@
 #include "pbd/memento_command.h"
 
 #include "ardour/debug.h"
+#include "ardour/profile.h"
 #include "ardour/session.h"
 #include "ardour/route.h"
 #include "ardour/location.h"
@@ -97,6 +98,10 @@ MackieControlProtocol::cmd_alt_release (Button &)
 LedState
 MackieControlProtocol::left_press (Button &)
 {
+       if (_subview_mode != None) {
+               return none;
+       }
+
        Sorted sorted = get_sorted_routes();
        uint32_t strip_cnt = n_strips ();
 
@@ -121,6 +126,10 @@ MackieControlProtocol::left_release (Button &)
 LedState
 MackieControlProtocol::right_press (Button &)
 {
+       if (_subview_mode != None) {
+               return none;
+       }
+
        Sorted sorted = get_sorted_routes();
        uint32_t strip_cnt = n_strips();
        uint32_t route_cnt = sorted.size();
@@ -265,6 +274,9 @@ MackieControlProtocol::cursor_down_release (Button&)
 LedState
 MackieControlProtocol::channel_left_press (Button &)
 {
+       if (_subview_mode != None) {
+               return none;
+       }
        Sorted sorted = get_sorted_routes();
        if (sorted.size() > n_strips()) {
                prev_track();
@@ -283,6 +295,9 @@ MackieControlProtocol::channel_left_release (Button &)
 LedState
 MackieControlProtocol::channel_right_press (Button &)
 {
+       if (_subview_mode != None) {
+               return none;
+       }
        Sorted sorted = get_sorted_routes();
        if (sorted.size() > n_strips()) {
                next_track();
@@ -408,7 +423,18 @@ MackieControlProtocol::marker_press (Button &)
 {
        string markername;
 
-       session->locations()->next_available_name (markername,"mcu");
+       /* Don't add another mark if one exists within 1/100th of a second of
+        * the current position and we're not rolling.
+        */
+
+
+       framepos_t where = session->audible_frame();
+
+       if (session->transport_stopped() && session->locations()->mark_at (where, session->frame_rate() / 100.0)) {
+               return off;
+       }
+
+       session->locations()->next_available_name (markername,"marker");
        add_marker (markername);
 
        return on;
@@ -504,13 +530,9 @@ MackieControlProtocol::ffwd_release (Button &)
 LedState
 MackieControlProtocol::loop_press (Button &)
 {
-       if (main_modifier_state() & MODIFIER_CONTROL) {
-               set_view_mode (Loop);
-               return on;
-       } else {
-               session->request_play_loop (!session->get_play_loop());
-               return none;
-       }
+       bool was_on = session->get_play_loop();
+       session->request_play_loop (!was_on);
+       return was_on ? off : on;
 }
 
 LedState
@@ -533,18 +555,6 @@ MackieControlProtocol::clicking_release (Button &)
        return Config->get_clicking();
 }
 
-LedState MackieControlProtocol::global_solo_press (Button &)
-{
-       bool state = !session->soloing();
-       session->set_solo (session->get_routes(), state);
-       return state;
-}
-
-LedState MackieControlProtocol::global_solo_release (Button &)
-{
-       return session->soloing();
-}
-
 LedState
 MackieControlProtocol::enter_press (Button &)
 {
@@ -559,24 +569,42 @@ MackieControlProtocol::enter_release (Button &)
 }
 
 LedState
-MackieControlProtocol::F1_press (Button &)
+MackieControlProtocol::bank_release (Button& b, uint32_t basic_bank_num)
 {
-       return off;
+       if (_subview_mode != None) {
+               return none;
+       }
+
+       uint32_t bank_num = basic_bank_num;
+
+       if (b.long_press_count() > 0) {
+               bank_num = 8 + basic_bank_num;
+       }
+
+       switch_banks (n_strips() * bank_num);
+
+       return on;
 }
+
 LedState
-MackieControlProtocol::F1_release (Button &)
+MackieControlProtocol::F1_press (Button &b)
 {
        return off;
 }
 LedState
+MackieControlProtocol::F1_release (Button &b)
+{
+       return bank_release (b, 0);
+}
+LedState
 MackieControlProtocol::F2_press (Button &)
 {
        return off;
 }
 LedState
-MackieControlProtocol::F2_release (Button &)
+MackieControlProtocol::F2_release (Button &b)
 {
-       return off;
+       return bank_release (b, 1);
 }
 LedState
 MackieControlProtocol::F3_press (Button &)
@@ -584,9 +612,9 @@ MackieControlProtocol::F3_press (Button &)
        return off;
 }
 LedState
-MackieControlProtocol::F3_release (Button &)
+MackieControlProtocol::F3_release (Button &b)
 {
-       return off;
+       return bank_release (b, 2);
 }
 LedState
 MackieControlProtocol::F4_press (Button &)
@@ -594,9 +622,9 @@ MackieControlProtocol::F4_press (Button &)
        return off;
 }
 LedState
-MackieControlProtocol::F4_release (Button &)
+MackieControlProtocol::F4_release (Button &b)
 {
-       return off;
+       return bank_release (b, 3);
 }
 LedState
 MackieControlProtocol::F5_press (Button &)
@@ -645,7 +673,8 @@ MackieControlProtocol::F8_release (Button &)
 LedState
 MackieControlProtocol::pan_press (Button &)
 {
-       return off;
+       set_pot_mode (Pan);
+       return none;
 }
 LedState
 MackieControlProtocol::pan_release (Button &)
@@ -660,14 +689,21 @@ MackieControlProtocol::plugin_press (Button &)
 LedState
 MackieControlProtocol::plugin_release (Button &)
 {
-       return none;
+       set_view_mode (Plugins);
+       return none; /* LED state set by set_view_mode */
 }
 LedState
 MackieControlProtocol::eq_press (Button &)
 {
-       //set_view_mode (EQ);
-       // not implemented yet, turn off (see comments for send button)
-       return off;
+       if (Profile->get_mixbus()) {
+               boost::shared_ptr<Route> r = first_selected_route ();
+               if (r && r->eq_band_cnt() > 0) {
+                       set_subview_mode (EQ, r);
+                       return none; /* led state handled by set_subview_mode() */
+               }
+       }
+       return none;
+
 }
 LedState
 MackieControlProtocol::eq_release (Button &)
@@ -677,10 +713,18 @@ MackieControlProtocol::eq_release (Button &)
 LedState
 MackieControlProtocol::dyn_press (Button &)
 {
-       //set_view_mode (Dynamics);
-       // same as send
-       return off;
+       if (Profile->get_mixbus()) {
+               boost::shared_ptr<Route> r = first_selected_route ();
+
+               if (r) {
+                       set_subview_mode (Dynamics, r);
+                       return none; /* led state handled by set_subview_mode() */
+               }
+       }
+
+       return none;
 }
+
 LedState
 MackieControlProtocol::dyn_release (Button &)
 {
@@ -803,21 +847,28 @@ MackieControlProtocol::write_release (Mackie::Button&)
 {
        return none;
 }
+
 Mackie::LedState
 MackieControlProtocol::clearsolo_press (Mackie::Button&)
 {
+       // clears all solos and listens (pfl/afl)
+       session->set_solo (session->get_routes(), false);
+       session->set_listen (session->get_routes(), false);
        return none;
 }
+
 Mackie::LedState
 MackieControlProtocol::clearsolo_release (Mackie::Button&)
 {
+       //return session->soloing();
        return none;
 }
+
 Mackie::LedState
 MackieControlProtocol::track_press (Mackie::Button&)
 {
-
-       return off;
+       set_pot_mode (Trim);
+       return none;
 }
 Mackie::LedState
 MackieControlProtocol::track_release (Mackie::Button&)
@@ -827,13 +878,21 @@ MackieControlProtocol::track_release (Mackie::Button&)
 Mackie::LedState
 MackieControlProtocol::send_press (Mackie::Button&)
 {
-// code moved here from "sends_press"
-       //set_view_mode (Sends);
-       // Led state for vpot assignment should be radio button-ish
-       // Pressing any one should turn the rest off.
-       // but this is not implemented yet so leave off
-       //return on;
-       return off;
+       boost::shared_ptr<Route> r = first_selected_route ();
+       if (r) {
+#ifndef MIXBUS
+               if (!r->nth_send (0)) {
+                       /* no sends ... no send subview mode */
+                       if (!surfaces.empty()) {
+                               surfaces.front()->display_message_for (_("No sends for this track/bus"), 1000);
+                       }
+                       return none;
+               }
+#endif
+               set_subview_mode (Sends, r);
+               return none; /* led state handled by set_subview_mode() */
+       }
+       return none;
 }
 Mackie::LedState
 MackieControlProtocol::send_release (Mackie::Button&)
@@ -848,6 +907,7 @@ MackieControlProtocol::miditracks_press (Mackie::Button&)
 Mackie::LedState
 MackieControlProtocol::miditracks_release (Mackie::Button&)
 {
+       set_view_mode (MidiTracks);
        return none;
 }
 Mackie::LedState
@@ -868,17 +928,20 @@ MackieControlProtocol::audiotracks_press (Mackie::Button&)
 Mackie::LedState
 MackieControlProtocol::audiotracks_release (Mackie::Button&)
 {
+       set_view_mode (AudioTracks);
        return none;
 }
 Mackie::LedState
-MackieControlProtocol::audioinstruments_press (Mackie::Button&)
+MackieControlProtocol::audioinstruments_press (Mackie::Button& b)
 {
-       return none;
+       return dyn_press (b);
 }
+
 Mackie::LedState
-MackieControlProtocol::audioinstruments_release (Mackie::Button&)
+MackieControlProtocol::audioinstruments_release (Mackie::Button& b)
 {
-       return none;
+       return dyn_release (b);
+
 }
 Mackie::LedState
 MackieControlProtocol::aux_press (Mackie::Button&)
@@ -888,6 +951,7 @@ MackieControlProtocol::aux_press (Mackie::Button&)
 Mackie::LedState
 MackieControlProtocol::aux_release (Mackie::Button&)
 {
+       set_view_mode (Auxes);
        return none;
 }
 Mackie::LedState
@@ -898,6 +962,7 @@ MackieControlProtocol::busses_press (Mackie::Button&)
 Mackie::LedState
 MackieControlProtocol::busses_release (Mackie::Button&)
 {
+       set_view_mode (Busses);
        return none;
 }
 Mackie::LedState
@@ -908,6 +973,7 @@ MackieControlProtocol::outputs_press (Mackie::Button&)
 Mackie::LedState
 MackieControlProtocol::outputs_release (Mackie::Button&)
 {
+       set_view_mode (Hidden);
        return none;
 }
 Mackie::LedState
@@ -918,6 +984,7 @@ MackieControlProtocol::user_press (Mackie::Button&)
 Mackie::LedState
 MackieControlProtocol::user_release (Mackie::Button&)
 {
+       set_view_mode (Selected);
        return none;
 }
 Mackie::LedState
@@ -983,6 +1050,7 @@ MackieControlProtocol::click_release (Mackie::Button&)
 Mackie::LedState
 MackieControlProtocol::view_press (Mackie::Button&)
 {
+       set_view_mode (Mixer);
        return none;
 }
 Mackie::LedState