add canvas-based Meter object
[ardour.git] / gtk2_ardour / route_params_ui.h
index 2dcb1b921d2c03e75cebcad5b1ae9b97c3289407..83ddf27110f937275159bd926b57745233279c7b 100644 (file)
 #include <gtkmm/eventbox.h>
 #include <gtkmm/frame.h>
 #include <gtkmm/label.h>
-#include <gtkmm/paned.h>
 #include <gtkmm/scrolledwindow.h>
 #include <gtkmm/togglebutton.h>
 #include <gtkmm/treeview.h>
 
 #include "pbd/stateful.h"
-#include "pbd/scoped_connections.h"
+#include "pbd/signals.h"
 
 #include "ardour/ardour.h"
 
-#include "io_selector.h"
-#include "ardour_dialog.h"
+#include <gtkmm2ext/pane.h>
+
+#include "ardour_window.h"
 #include "processor_box.h"
 #include "route_processor_selection.h"
 #include "latency_gui.h"
@@ -54,8 +54,9 @@ namespace ARDOUR {
 }
 
 class PluginSelector;
+class IOSelector;
 
-class RouteParams_UI : public ArdourDialog, public PBD::ScopedConnectionList
+class RouteParams_UI : public ArdourWindow, public PBD::ScopedConnectionList
 {
   public:
        RouteParams_UI ();
@@ -63,25 +64,16 @@ class RouteParams_UI : public ArdourDialog, public PBD::ScopedConnectionList
 
        void set_session (ARDOUR::Session*);
        void session_going_away ();
-       PluginSelector*  plugin_selector() { return _plugin_selector; }
+       PluginSelector* plugin_selector() { return _plugin_selector; }
 
   private:
-       Gtk::HBox                global_hpacker;
-       Gtk::VBox                global_vpacker;
-       Gtk::ScrolledWindow      scroller;
-       Gtk::EventBox            scroller_base;
-       Gtk::HBox                scroller_hpacker;
-       Gtk::VBox                mixer_scroller_vpacker;
-
        Gtk::VBox                list_vpacker;
-       Gtk::Label               route_list_button_label;
-       Gtk::Button              route_list_button;
        Gtk::ScrolledWindow      route_select_scroller;
 
        Gtk::Notebook            notebook;
        Gtk::Frame               input_frame;
        Gtk::Frame               output_frame;
-       Gtk::HPaned              redir_hpane;
+       Gtkmm2ext::HPane         redir_hpane;
 
        Gtk::Frame               route_select_frame;
 
@@ -90,11 +82,9 @@ class RouteParams_UI : public ArdourDialog, public PBD::ScopedConnectionList
 
        ProcessorBox*            insert_box;
 
-       Gtk::HPaned              list_hpane;
-
-       Gtk::HPaned              right_hpane;
+       Gtkmm2ext::HPane         list_hpane;
 
-       Gtk::Frame               route_choice_frame;
+       Gtkmm2ext::HPane         right_hpane;
 
        Gtk::Frame               route_param_frame;
 
@@ -123,13 +113,14 @@ class RouteParams_UI : public ArdourDialog, public PBD::ScopedConnectionList
        IOSelector     * _output_iosel;
 
        PluginSelector    *_plugin_selector;
-       RouteRedirectSelection  _rr_selection;
+       RouteProcessorSelection  _rr_selection;
 
        boost::shared_ptr<ARDOUR::Route> _route;
-       boost::signals2::scoped_connection _route_processors_connection;
+       PBD::ScopedConnection _route_processors_connection;
+       PBD::ScopedConnectionList route_connections;
 
        boost::shared_ptr<ARDOUR::Processor> _processor;
-       boost::signals2::scoped_connection _processor_going_away_connection;
+       PBD::ScopedConnection _processor_going_away_connection;
 
 
        enum ConfigView {
@@ -150,7 +141,7 @@ class RouteParams_UI : public ArdourDialog, public PBD::ScopedConnectionList
                        add(text);
                        add(route);
                }
-               Gtk::TreeModelColumn<Glib::ustring> text;
+               Gtk::TreeModelColumn<std::string> text;
                Gtk::TreeModelColumn<boost::shared_ptr<ARDOUR::Route> > route;
        };
 
@@ -161,8 +152,9 @@ class RouteParams_UI : public ArdourDialog, public PBD::ScopedConnectionList
 
        void add_routes (ARDOUR::RouteList&);
 
-       void route_name_changed (boost::weak_ptr<ARDOUR::Route> route);
+       void route_property_changed (const PBD::PropertyChange&, boost::weak_ptr<ARDOUR::Route> route);
        void route_removed (boost::weak_ptr<ARDOUR::Route> route);
+       void map_frozen ();
 
 
        void route_selected();