LTC Slave, add support for variable framerates
[ardour.git] / libs / surfaces / mackie / strip.h
index 7de9d27f018da40befcd47b3e3c20e48ffc5aec4..d5fdc6c17c5917b82f0f8fb3cf4be23d9588eb22 100644 (file)
@@ -4,6 +4,8 @@
 #include <string>
 #include <iostream>
 
+#include "evoral/Parameter.hpp"
+
 #include "pbd/property_basics.h"
 #include "pbd/signals.h"
 
@@ -58,7 +60,7 @@ public:
        void add (Control & control);
        int index() const { return _index; } // zero based
        
-       void set_route (boost::shared_ptr<ARDOUR::Route>);
+       void set_route (boost::shared_ptr<ARDOUR::Route>, bool with_messages = true);
 
        // call all signal handlers manually
        void notify_all();
@@ -71,35 +73,20 @@ public:
 
        MidiByteArray display (uint32_t line_number, const std::string&);
        MidiByteArray blank_display (uint32_t line_number);
-       MidiByteArray zero ();
+
+       void zero ();
 
        void flip_mode_changed (bool notify=false);
 
        void lock_controls ();
        void unlock_controls ();
-       
-       MidiByteArray gui_selection_changed (ARDOUR::RouteNotificationListPtr);
+       bool locked() const { return _controls_locked; }
+
+       void gui_selection_changed (const ARDOUR::StrongRouteNotificationList&);
+  
+       void notify_metering_state_changed();
 
 private:
-       enum PotMode {
-               Gain,
-               PanAzimuth,
-               PanWidth,
-               PanElevation,
-               PanFrontBack,
-               PanLFE,
-               Input,
-               Output,
-               Send1,
-               Send2,
-               Send3,
-               Send4,
-               Send5,
-               Send6,
-               Send7,
-               Send8,
-       };
-               
        Button*  _solo;
        Button*  _recenable;
        Button*  _mute;
@@ -107,26 +94,28 @@ private:
        Button*  _vselect;
        Button*  _fader_touch;
        Pot*     _vpot;
-       PotMode  _vpot_mode;
-       PotMode  _preflip_vpot_mode;
        Fader*   _fader;
        Meter*   _meter;
        int      _index;
        Surface* _surface;
        bool     _controls_locked;
+       bool     _transport_is_rolling;
+       bool     _metering_active;
        uint64_t _reset_display_at;
        boost::shared_ptr<ARDOUR::Route> _route;
        PBD::ScopedConnectionList route_connections;
 
        float _last_gain_position_written;
-       float _last_pan_position_written;
+       float _last_pan_azi_position_written;
+       float _last_pan_width_position_written;
 
        void notify_solo_changed ();
        void notify_mute_changed ();
        void notify_record_enable_changed ();
        void notify_gain_changed (bool force_update = true);
        void notify_property_changed (const PBD::PropertyChange&);
-       void notify_panner_changed (bool force_update = true);
+       void notify_panner_azi_changed (bool force_update = true);
+       void notify_panner_width_changed (bool force_update = true);
        void notify_active_changed ();
        void notify_route_deleted ();
        
@@ -152,9 +141,13 @@ private:
        void vselect_event (Button&, ButtonState);
        void fader_touch_event (Button&, ButtonState);
 
-       std::vector<PotMode> current_pot_modes;
+       std::vector<Evoral::Parameter> possible_pot_parameters;
        void next_pot_mode ();
-       void set_vpot_mode (PotMode);
+       void set_vpot_parameter (Evoral::Parameter);
+
+       void reset_saved_values ();
+
+       std::map<Evoral::Parameter,Control*> control_by_parameter;
 };
 
 }