many changes associated with rationalizing selection flow
[ardour.git] / gtk2_ardour / mixer_ui.h
index 7bfe8b1bddad396f9f9aa11d0eb6c4c849f8910c..70a0e630b73d9ac53fbc7fe11314837af1120e38 100644 (file)
@@ -28,7 +28,6 @@
 #include <gtkmm/label.h>
 #include <gtkmm/button.h>
 #include <gtkmm/frame.h>
-#include <gtkmm/paned.h>
 #include <gtkmm/menu.h>
 #include <gtkmm/treeview.h>
 #include <gtkmm/liststore.h>
@@ -42,8 +41,8 @@
 #include "ardour/plugin.h"
 #include "ardour/plugin_manager.h"
 
-
 #include "gtkmm2ext/dndtreeview.h"
+#include <gtkmm2ext/pane.h>
 #include "gtkmm2ext/treeutils.h"
 
 #include "gtkmm2ext/tabbable.h"
@@ -56,10 +55,12 @@ namespace ARDOUR {
        class RouteGroup;
 };
 
+class AxisView;
 class MixerStrip;
 class PluginSelector;
 class MixerGroupTabs;
 class MonitorSection;
+class VCAMasterStrip;
 
 class PluginTreeStore : public Gtk::TreeStore
 {
@@ -91,9 +92,6 @@ class Mixer_UI : public Gtkmm2ext::Tabbable, public PBD::ScopedConnectionList, p
        void  set_strip_width (Width, bool save = false);
        Width get_strip_width () const { return _strip_width; }
 
-       void unselect_strip_in_display (MixerStrip*);
-       void select_strip_in_display (MixerStrip*);
-
        XMLNode& get_state ();
        int set_state (const XMLNode&, int /* version */);
 
@@ -110,13 +108,20 @@ class Mixer_UI : public Gtkmm2ext::Tabbable, public PBD::ScopedConnectionList, p
 
        void deselect_all_strip_processors();
        void delete_processors();
-
+       void select_strip (MixerStrip&, bool add=false);
        void select_none ();
 
        bool window_not_visible () const;
 
+       void do_vca_assign (boost::shared_ptr<ARDOUR::VCA>);
+       void do_vca_unassign (boost::shared_ptr<ARDOUR::VCA>);
+       void show_vca_slaves (boost::shared_ptr<ARDOUR::VCA>);
+       bool showing_vca_slaves_for (boost::shared_ptr<ARDOUR::VCA>) const;
+
+       sigc::signal1<void,boost::shared_ptr<ARDOUR::VCA> > show_vca_change;
+
   protected:
-       void set_route_targets_for_operation ();
+       void set_axis_targets_for_operation ();
 
   private:
        Mixer_UI ();
@@ -129,39 +134,51 @@ class Mixer_UI : public Gtkmm2ext::Tabbable, public PBD::ScopedConnectionList, p
        Gtk::HBox             scroller_hpacker;
        Gtk::VBox             mixer_scroller_vpacker;
        Gtk::VBox             list_vpacker;
-       Gtk::Label                              group_display_button_label;
-       Gtk::Button                             group_display_button;
-       Gtk::ScrolledWindow             track_display_scroller;
-       Gtk::ScrolledWindow             group_display_scroller;
-       Gtk::ScrolledWindow             favorite_plugins_scroller;
-       Gtk::VBox                               group_display_vbox;
-       Gtk::Frame                              track_display_frame;
-       Gtk::Frame                              group_display_frame;
-       Gtk::Frame                              favorite_plugins_frame;
-       Gtk::VPaned                             rhs_pane1;
-       Gtk::VPaned                             rhs_pane2;
-       Gtk::HBox                               strip_packer;
-       Gtk::HBox                               out_packer;
-       Gtk::HPaned                             list_hpane;
+       Gtk::Label            group_display_button_label;
+       Gtk::Button           group_display_button;
+       Gtk::ScrolledWindow   track_display_scroller;
+       Gtk::ScrolledWindow   group_display_scroller;
+       Gtk::ScrolledWindow   favorite_plugins_scroller;
+       Gtk::VBox             group_display_vbox;
+       Gtk::Frame            track_display_frame;
+       Gtk::Frame            group_display_frame;
+       Gtk::Frame            favorite_plugins_frame;
+       Gtkmm2ext::VPane      rhs_pane1;
+       Gtkmm2ext::VPane      rhs_pane2;
+       Gtkmm2ext::HPane      inner_pane;
+       Gtk::HBox             strip_packer;
+       Gtk::ScrolledWindow   vca_scroller;
+       Gtk::HBox             vca_hpacker;
+       Gtk::VBox             vca_vpacker;
+       Gtk::EventBox         vca_label_bar;
+       Gtk::Label            vca_label;
+       Gtk::EventBox         vca_scroller_base;
+       Gtk::HBox             out_packer;
+       Gtkmm2ext::HPane      list_hpane;
 
        MixerGroupTabs* _group_tabs;
 
        bool on_scroll_event (GdkEventScroll*);
 
-       void pane_allocation_handler (Gtk::Allocation&, Gtk::Paned*);
-
        std::list<MixerStrip *> strips;
 
        void scroller_drag_data_received (const Glib::RefPtr<Gdk::DragContext>&, int, int, const Gtk::SelectionData&, guint, guint);
        bool strip_scroller_button_release (GdkEventButton*);
+       bool masters_scroller_button_release (GdkEventButton*);
        void scroll_left ();
        void scroll_right ();
         void toggle_midi_input_active (bool flip_others);
 
-       void add_strips (ARDOUR::RouteList&);
+       void add_stripables (ARDOUR::StripableList&);
+
+       void add_routes (ARDOUR::RouteList&);
        void remove_strip (MixerStrip *);
 
-       MixerStrip* strip_by_route (boost::shared_ptr<ARDOUR::Route>);
+       void add_masters (ARDOUR::VCAList&);
+       void remove_master (VCAMasterStrip*);
+
+       MixerStrip* strip_by_route (boost::shared_ptr<ARDOUR::Route>) const;
+       AxisView* axis_by_stripable (boost::shared_ptr<ARDOUR::Stripable>) const;
 
        void hide_all_strips (bool with_select);
        void unselect_all_strips();
@@ -185,6 +202,7 @@ class Mixer_UI : public Gtkmm2ext::Tabbable, public PBD::ScopedConnectionList, p
        void track_name_changed (MixerStrip *);
 
        void redisplay_track_list ();
+       void spill_redisplay (boost::shared_ptr<ARDOUR::VCA>);
        bool no_track_list_redisplay;
        bool track_display_button_press (GdkEventButton*);
        void strip_width_changed ();
@@ -249,50 +267,50 @@ class Mixer_UI : public Gtkmm2ext::Tabbable, public PBD::ScopedConnectionList, p
         MonitorSection* _monitor_section;
        PluginSelector    *_plugin_selector;
 
-       void strip_property_changed (const PBD::PropertyChange&, MixerStrip *);
+       void stripable_property_changed (const PBD::PropertyChange& what_changed, boost::weak_ptr<ARDOUR::Stripable> ws);
        void route_group_property_changed (ARDOUR::RouteGroup *, const PBD::PropertyChange &);
 
        /* various treeviews */
 
-       struct TrackDisplayModelColumns : public Gtk::TreeModel::ColumnRecord {
-           TrackDisplayModelColumns () {
-                   add (text);
-                   add (visible);
-                   add (route);
-                   add (strip);
-           }
-           Gtk::TreeModelColumn<bool>           visible;
-           Gtk::TreeModelColumn<std::string>  text;
-           Gtk::TreeModelColumn<boost::shared_ptr<ARDOUR::Route> > route;
-           Gtk::TreeModelColumn<MixerStrip*>    strip;
+       struct StripableDisplayModelColumns : public Gtk::TreeModel::ColumnRecord {
+               StripableDisplayModelColumns () {
+                       add (text);
+                       add (visible);
+                       add (stripable);
+                       add (strip);
+               }
+               Gtk::TreeModelColumn<bool>         visible;
+               Gtk::TreeModelColumn<std::string>  text;
+               Gtk::TreeModelColumn<boost::shared_ptr<ARDOUR::Stripable> > stripable;
+               Gtk::TreeModelColumn<AxisView*>    strip;
        };
 
        struct GroupDisplayModelColumns : public Gtk::TreeModel::ColumnRecord {
-           GroupDisplayModelColumns() {
-                   add (visible);
-                   add (text);
-                   add (group);
-           }
-           Gtk::TreeModelColumn<bool>                                  visible;
-           Gtk::TreeModelColumn<std::string>                   text;
-           Gtk::TreeModelColumn<ARDOUR::RouteGroup*>   group;
+               GroupDisplayModelColumns() {
+                       add (visible);
+                       add (text);
+                       add (group);
+               }
+               Gtk::TreeModelColumn<bool>            visible;
+               Gtk::TreeModelColumn<std::string>         text;
+               Gtk::TreeModelColumn<ARDOUR::RouteGroup*> group;
        };
 
        struct PluginsDisplayModelColumns : public Gtk::TreeModel::ColumnRecord {
-           PluginsDisplayModelColumns() {
-                   add (name);
-                   add (plugin);
-           }
-           Gtk::TreeModelColumn<std::string> name;
-                       Gtk::TreeModelColumn<ARDOUR::PluginPresetPtr> plugin;
+               PluginsDisplayModelColumns() {
+                       add (name);
+                       add (plugin);
+               }
+               Gtk::TreeModelColumn<std::string> name;
+               Gtk::TreeModelColumn<ARDOUR::PluginPresetPtr> plugin;
        };
 
        ARDOUR::PluginInfoList favorite_order;
        std::map<std::string, bool> favorite_ui_state;
 
-       TrackDisplayModelColumns    track_columns;
-       GroupDisplayModelColumns    group_columns;
-       PluginsDisplayModelColumns  favorite_plugins_columns;
+       StripableDisplayModelColumns stripable_columns;
+       GroupDisplayModelColumns     group_columns;
+       PluginsDisplayModelColumns   favorite_plugins_columns;
 
        Gtk::TreeView track_display;
        Gtk::TreeView group_display;
@@ -309,10 +327,8 @@ class Mixer_UI : public Gtkmm2ext::Tabbable, public PBD::ScopedConnectionList, p
 
        Width _strip_width;
 
-        void sync_order_keys_from_treeview ();
-        void sync_treeview_from_order_keys ();
-        void reset_remote_control_ids ();
-        void reset_order_keys ();
+        void sync_presentation_info_from_treeview ();
+        void sync_treeview_from_presentation_info ();
 
         bool ignore_reorder;
 
@@ -356,6 +372,10 @@ class Mixer_UI : public Gtkmm2ext::Tabbable, public PBD::ScopedConnectionList, p
 
        // true if mixer list is visible
        bool _show_mixer_list;
+
+       mutable boost::weak_ptr<ARDOUR::VCA> spilled_vca;
+
+       void escape ();
 };
 
 #endif /* __ardour_mixer_ui_h__ */