X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Froute_params_ui.h;h=850c56af7c358447262edaf19eb4d8f44a8edae9;hb=7d8b93add17620135eadee5029325a3d22512b12;hp=75c0ef731dbd2dc1ad5de94e95ed1d21ed870379;hpb=bb9cc45cd22af67ac275a5e73accbe14fee664d8;p=ardour.git diff --git a/gtk2_ardour/route_params_ui.h b/gtk2_ardour/route_params_ui.h index 75c0ef731d..850c56af7c 100644 --- a/gtk2_ardour/route_params_ui.h +++ b/gtk2_ardour/route_params_ui.h @@ -27,19 +27,20 @@ #include #include #include -#include #include #include #include #include "pbd/stateful.h" +#include "pbd/signals.h" #include "ardour/ardour.h" -#include "io_selector.h" -#include "ardour_dialog.h" +#include + +#include "ardour_window.h" #include "processor_box.h" -#include "route_processor_selection.h" +#include "processor_selection.h" #include "latency_gui.h" namespace ARDOUR { @@ -53,49 +54,39 @@ namespace ARDOUR { } class PluginSelector; +class IOSelector; -class RouteParams_UI : public ArdourDialog +class RouteParams_UI : public ArdourWindow, public PBD::ScopedConnectionList { - public: +public: RouteParams_UI (); ~RouteParams_UI(); - void set_session (ARDOUR::Session *); - void session_gone (); - 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; + void set_session (ARDOUR::Session*); + void session_going_away (); + PluginSelector* plugin_selector() { return _plugin_selector; } +private: 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; + Gtk::Frame input_frame; + Gtk::Frame output_frame; + ArdourWidgets::HPane redir_hpane; - Gtk::Frame route_select_frame; + Gtk::Frame route_select_frame; Gtk::HBox route_hpacker; Gtk::VBox route_vpacker; ProcessorBox* insert_box; - Gtk::HPaned list_hpane; + ArdourWidgets::HPane list_hpane; - Gtk::HPaned right_hpane; + ArdourWidgets::HPane right_hpane; - Gtk::Frame route_choice_frame; - - Gtk::Frame route_param_frame; + Gtk::Frame route_param_frame; Gtk::VBox choice_vpacker; @@ -105,9 +96,9 @@ class RouteParams_UI : public ArdourDialog Gtk::Button latency_apply_button; LatencyGUI* latency_widget; Gtk::Label delay_label; - sigc::connection latency_conn; - sigc::connection delay_conn; - sigc::connection latency_apply_conn; + + PBD::ScopedConnectionList latency_connections; + sigc::connection latency_click_connection; void refresh_latency (); @@ -122,14 +113,14 @@ class RouteParams_UI : public ArdourDialog IOSelector * _output_iosel; PluginSelector *_plugin_selector; - RouteRedirectSelection _rr_selection; + ProcessorSelection _p_selection; boost::shared_ptr _route; - sigc::connection _route_conn; - sigc::connection _route_ds_conn; + PBD::ScopedConnection _route_processors_connection; + PBD::ScopedConnectionList route_connections; boost::shared_ptr _processor; - sigc::connection _plugin_conn; + PBD::ScopedConnection _processor_going_away_connection; enum ConfigView { @@ -145,12 +136,12 @@ class RouteParams_UI : public ArdourDialog /* treeview */ - struct RouteDisplayModelColumns : public Gtk::TreeModel::ColumnRecord { + struct RouteDisplayModelColumns : public Gtk::TreeModel::ColumnRecord { RouteDisplayModelColumns() { add(text); add(route); } - Gtk::TreeModelColumn text; + Gtk::TreeModelColumn text; Gtk::TreeModelColumn > route; }; @@ -161,20 +152,21 @@ class RouteParams_UI : public ArdourDialog void add_routes (ARDOUR::RouteList&); - void route_name_changed (boost::shared_ptr route); - void route_removed (boost::shared_ptr route); + void route_property_changed (const PBD::PropertyChange&, boost::weak_ptr route); + void route_removed (boost::weak_ptr route); + void map_frozen (); void route_selected(); //void route_unselected (gint row, gint col, GdkEvent *ev); - void setup_io_frames(); - void cleanup_io_frames(); + void setup_io_samples(); + void cleanup_io_samples(); void cleanup_view(bool stopupdate = true); void cleanup_latency_frame (); void setup_latency_frame (); - void processors_changed (); + void processors_changed (ARDOUR::RouteProcessorChange); void setup_processor_boxes(); void cleanup_processor_boxes(); @@ -182,7 +174,7 @@ class RouteParams_UI : public ArdourDialog void redirect_selected (boost::shared_ptr); void plugin_going_away (ARDOUR::Placement); - void redirect_going_away (boost::shared_ptr); + void processor_going_away (boost::weak_ptr); gint edit_input_configuration (GdkEventButton *ev); gint edit_output_configuration (GdkEventButton *ev);