fix up some basic conceptual errors with canvas-simpleline, mostly relating to coordi...
[ardour.git] / gtk2_ardour / mixer_ui.h
index bb9625540698378e4fb55fd1bb8a72ef6607bf95..2c5081dbcc408b726ba13277ab9e2ef8b261dbd3 100644 (file)
 #include <gtkmm/paned.h>
 #include <gtkmm/menu.h>
 #include <gtkmm/treeview.h>
+#include <gtkmm/liststore.h>
 
 #include "pbd/stateful.h"
+#include "pbd/signals.h"
 
 #include "ardour/ardour.h"
+#include "ardour/session_handle.h"
 
 #include "route_processor_selection.h"
 #include "enums.h"
 namespace ARDOUR {
        class Route;
        class RouteGroup;
-       class Session;
-       class AudioDiskstream;
 };
 
 class MixerStrip;
 class PluginSelector;
 class MixerGroupTabs;
+class MonitorSection;
 
-class Mixer_UI : public Gtk::Window
+class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public ARDOUR::SessionHandlePtr
 {
   public:
        Mixer_UI ();
        ~Mixer_UI();
 
-       void connect_to_session (ARDOUR::Session *);
+       void set_session (ARDOUR::Session *);
 
        PluginSelector* plugin_selector();
 
@@ -79,10 +81,9 @@ class Mixer_UI : public Gtk::Window
        void set_auto_rebinding(bool);
 
        RouteRedirectSelection& selection() { return _selection; }
+        MonitorSection* monitor_section() const { return _monitor_section; }
 
   private:
-       ARDOUR::Session         *session;
-
        bool                                    _visible;
 
        Gtk::HBox                               global_hpacker;
@@ -114,12 +115,15 @@ class Mixer_UI : public Gtk::Window
 
        bool on_key_press_event (GdkEventKey*);
        bool on_key_release_event (GdkEventKey*);
+       bool on_scroll_event (GdkEventScroll*);
 
        void pane_allocation_handler (Gtk::Allocation&, Gtk::Paned*);
 
        std::list<MixerStrip *> strips;
 
        bool strip_scroller_button_release (GdkEventButton*);
+       void scroll_left ();
+       void scroll_right ();
 
        void add_strip (ARDOUR::RouteList&);
        void remove_strip (MixerStrip *);
@@ -143,7 +147,7 @@ class Mixer_UI : public Gtk::Window
        gint start_updating ();
        gint stop_updating ();
 
-       void disconnect_from_session ();
+       void session_going_away ();
 
        sigc::connection fast_screen_update_connection;
        void fast_update_strips ();
@@ -172,7 +176,6 @@ class Mixer_UI : public Gtk::Window
        void show_all_audiotracks();
        void hide_all_audiotracks ();
 
-       Gtk::Menu* route_group_context_menu;
        bool in_group_row_change;
 
        void group_selected (gint row, gint col, GdkEvent *ev);
@@ -180,23 +183,22 @@ class Mixer_UI : public Gtk::Window
        void group_display_active_clicked();
        void new_route_group ();
        void remove_selected_route_group ();
-       void build_route_group_context_menu ();
        void activate_all_route_groups ();
        void disable_all_route_groups ();
        void add_route_group (ARDOUR::RouteGroup *);
        void route_groups_changed ();
-       void route_group_name_edit (const Glib::ustring&, const Glib::ustring&);
+       void route_group_name_edit (const std::string&, const std::string&);
        void route_group_row_change (const Gtk::TreeModel::Path& path,const Gtk::TreeModel::iterator& iter);
 
        Gtk::Menu *track_menu;
        void track_column_click (gint);
        void build_track_menu ();
 
+        MonitorSection* _monitor_section;
        PluginSelector    *_plugin_selector;
 
-       void strip_name_changed (MixerStrip *);
-
-       void group_flags_changed (void *src, ARDOUR::RouteGroup *);
+       void strip_property_changed (const PBD::PropertyChange&, MixerStrip *);
+       void route_group_property_changed (ARDOUR::RouteGroup *, const PBD::PropertyChange &);
 
        /* various treeviews */
 
@@ -208,7 +210,7 @@ class Mixer_UI : public Gtk::Window
                    add (strip);
            }
            Gtk::TreeModelColumn<bool>           visible;
-           Gtk::TreeModelColumn<Glib::ustring>  text;
+           Gtk::TreeModelColumn<std::string>  text;
            Gtk::TreeModelColumn<boost::shared_ptr<ARDOUR::Route> > route;
            Gtk::TreeModelColumn<MixerStrip*>    strip;
        };
@@ -220,7 +222,7 @@ class Mixer_UI : public Gtk::Window
                    add (group);
            }
            Gtk::TreeModelColumn<bool>                                  visible;
-           Gtk::TreeModelColumn<Glib::ustring>                 text;
+           Gtk::TreeModelColumn<std::string>                   text;
            Gtk::TreeModelColumn<ARDOUR::RouteGroup*>   group;
        };