X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Froute_ui.h;h=bac608eed43dcf217f522e0dac2c75247a9997a3;hb=6b1b72a247bf04c81292fc41af4f69c9b7f90379;hp=aedea7380b2d1296efe607bb3e5ed2b9c8c72a04;hpb=3e12d4b4a625e7c02b797e806c1de501a33ade2d;p=ardour.git diff --git a/gtk2_ardour/route_ui.h b/gtk2_ardour/route_ui.h index aedea7380b..bac608eed4 100644 --- a/gtk2_ardour/route_ui.h +++ b/gtk2_ardour/route_ui.h @@ -26,6 +26,7 @@ #include "pbd/signals.h" #include +#include #include "gtkmm2ext/widget_state.h" @@ -40,6 +41,7 @@ #include "axis_view.h" #include "selectable.h" +#include "stripable_colorpicker.h" #include "window_manager.h" namespace ARDOUR { @@ -53,33 +55,42 @@ namespace Gtk { class Widget; } -class ArdourButton; +namespace ArdourWidgets { + class ArdourButton; + class Prompter; +} + class ArdourWindow; class IOSelectorWindow; +class ControlSlaveUI; +class PatchChangeGridDialog; +class SaveTemplateDialog; class RoutePinWindowProxy : public WM::ProxyBase { - public: +public: RoutePinWindowProxy (std::string const &, boost::shared_ptr); ~RoutePinWindowProxy(); Gtk::Window* get (bool create = false); ARDOUR::SessionHandlePtr* session_handle(); - private: +private: boost::weak_ptr _route; void route_going_away (); PBD::ScopedConnection going_away_connection; }; -class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::trackable, public virtual PBD::ScopedConnectionList +class RouteUI : public virtual Selectable, public virtual ARDOUR::SessionHandlePtr, public virtual PBD::ScopedConnectionList, public virtual sigc::trackable { - public: +public: RouteUI (ARDOUR::Session*); virtual ~RouteUI(); + boost::shared_ptr stripable() const; + virtual void set_route (boost::shared_ptr); virtual void set_button_names () = 0; @@ -99,13 +110,11 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr boost::shared_ptr _route; - void request_redraw (); - virtual void set_color (uint32_t c); Gdk::Color route_color () const; void choose_color (); - void set_selected (bool); + void select_midi_patch (); bool ignore_toggle; bool wait_for_release; @@ -113,19 +122,18 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr bool multiple_solo_change; Gtk::HBox _invert_button_box; - ArdourButton* mute_button; - ArdourButton* solo_button; - ArdourButton* rec_enable_button; /* audio tracks */ - ArdourButton* show_sends_button; /* busses */ - ArdourButton* monitor_input_button; - ArdourButton* monitor_disk_button; + ArdourWidgets::ArdourButton* mute_button; + ArdourWidgets::ArdourButton* solo_button; + ArdourWidgets::ArdourButton* rec_enable_button; /* audio tracks */ + ArdourWidgets::ArdourButton* show_sends_button; /* busses */ + ArdourWidgets::ArdourButton* monitor_input_button; + ArdourWidgets::ArdourButton* monitor_disk_button; Glib::RefPtr solo_safe_pixbuf; - ArdourButton* solo_safe_led; - ArdourButton* solo_isolated_led; + ArdourWidgets::ArdourButton* solo_safe_led; + ArdourWidgets::ArdourButton* solo_isolated_led; - ArdourButton* vca_button; Gtk::Label monitor_input_button_label; Gtk::Label monitor_disk_button_label; @@ -160,11 +168,6 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr void edit_input_configuration (); void edit_output_configuration (); - void step_gain_up (); - void step_gain_down (); - void page_gain_up (); - void page_gain_down (); - void build_sends_menu (); void set_sends_gain_from_track (); void set_sends_gain_to_zero (); @@ -184,8 +187,8 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr void solo_isolated_toggle (void*, Gtk::CheckMenuItem*); void toggle_solo_isolated (Gtk::CheckMenuItem*); - bool solo_isolate_button_release (GdkEventButton*); - bool solo_safe_button_release (GdkEventButton*); + bool solo_isolate_button_release (GdkEventButton*); + bool solo_safe_button_release (GdkEventButton*); void solo_safe_toggle (void*, Gtk::CheckMenuItem*); void toggle_solo_safe (Gtk::CheckMenuItem*); @@ -208,6 +211,7 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr void manage_pins (); void maybe_add_route_print_mgr (); + void fan_out (bool to_busses = true, bool group = true); virtual void route_property_changed (const PBD::PropertyChange&) = 0; void route_removed (); @@ -216,8 +220,8 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr void set_route_active (bool, bool); void duplicate_selected_routes (); - Gtk::Menu* record_menu; - void build_record_menu (); + Gtk::Menu* record_menu; + void build_record_menu (); Gtk::CheckMenuItem *step_edit_item; void toggle_step_edit (); @@ -240,12 +244,10 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr void update_solo_display (); - void update_vca_display (); - virtual void map_frozen (); void adjust_latency (); - bool process_save_template_prompter (ArdourPrompter& prompter, const std::string& dir); + void save_as_template_dialog_response (int response, SaveTemplateDialog* d); void save_as_template (); static Gtkmm2ext::ActiveState solo_active_state (boost::shared_ptr); @@ -269,7 +271,9 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr void comment_edited (); bool ignore_comment_edit; - protected: + void set_disk_io_point (ARDOUR::DiskIOPoint); + +protected: ArdourWindow* comment_window; Gtk::TextView* comment_area; @@ -283,10 +287,10 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr void reset (); void self_delete (); - virtual void start_step_editing () {} - virtual void stop_step_editing() {} + virtual void start_step_editing () {} + virtual void stop_step_editing() {} - void set_invert_sensitive (bool); + void set_invert_sensitive (bool); bool verify_new_route_name (const std::string& name); void route_gui_changed (PBD::PropertyChange const&); @@ -300,30 +304,36 @@ class RouteUI : public virtual ARDOUR::SessionHandlePtr, public virtual sigc::tr bool mark_hidden (bool yn); - private: - void parameter_changed (std::string const &); + PatchChangeGridDialog* patch_change_dialog () const; + +private: + void parameter_changed (std::string const&); void relabel_solo_button (); void track_mode_changed (); + void delete_patch_change_dialog (); std::string route_state_id () const; protected: struct SoloMuteRelease { - SoloMuteRelease (bool was_active) - : active (was_active) - , exclusive (false) {} - - boost::shared_ptr routes; - boost::shared_ptr routes_on; - boost::shared_ptr routes_off; - boost::shared_ptr route; - bool active; - bool exclusive; + SoloMuteRelease (bool was_active) + : active (was_active) + , exclusive (false) + {} + + boost::shared_ptr routes; + boost::shared_ptr routes_on; + boost::shared_ptr routes_off; + boost::shared_ptr route; + bool active; + bool exclusive; }; SoloMuteRelease* _solo_release; SoloMuteRelease* _mute_release; + ControlSlaveUI* csu; + private: void setup_invert_buttons (); void set_invert_button_state (); @@ -332,9 +342,11 @@ private: bool invert_release (GdkEventButton *, uint32_t i); int _i_am_the_modifier; - std::vector _invert_buttons; + std::vector _invert_buttons; Gtk::Menu* _invert_menu; + StripableColorDialog _color_picker; + static void set_showing_sends_to (boost::shared_ptr); static boost::weak_ptr _showing_sends_to;