X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Froute_ui.h;h=cc11b1809470f69aaf2eaf773117116e4fcafbd5;hb=696837ec7a86046ce43dc61fedd4b6de560fc06d;hp=c784b9766801f2ae56ba06b0e14a7a6ff045400c;hpb=bc89fe0147c04b67141936d109c00dfd4d69cc4b;p=ardour.git diff --git a/gtk2_ardour/route_ui.h b/gtk2_ardour/route_ui.h index c784b97668..cc11b18094 100644 --- a/gtk2_ardour/route_ui.h +++ b/gtk2_ardour/route_ui.h @@ -22,10 +22,16 @@ #include -#include -#include -#include -#include +#include "pbd/xml++.h" +#include "pbd/signals.h" + +#include "ardour/ardour.h" +#include "ardour/mute_master.h" +#include "ardour/session_event.h" +#include "ardour/session.h" +#include "ardour/route.h" +#include "ardour/route_group.h" +#include "ardour/track.h" #include "axis_view.h" @@ -41,36 +47,35 @@ namespace Gtk { } class BindableToggleButton; +class LED; class RouteUI : public virtual AxisView { public: - RouteUI(ARDOUR::Session&, const char*, const char*, const char*); - RouteUI(boost::shared_ptr, ARDOUR::Session&, const char*, const char*, const char*); + RouteUI(ARDOUR::Session*); + RouteUI(boost::shared_ptr, ARDOUR::Session*); virtual ~RouteUI(); virtual void set_route (boost::shared_ptr); - void set_button_names (const char*, const char*, const char*); + virtual void set_button_names () = 0; bool is_track() const; bool is_audio_track() const; bool is_midi_track() const; boost::shared_ptr route() const { return _route; } - + boost::shared_ptr track() const; boost::shared_ptr audio_track() const; boost::shared_ptr midi_track() const; - - boost::shared_ptr get_diskstream() const; - string name() const; + std::string name() const; // protected: XXX sigh this should be here boost::shared_ptr _route; - + void set_color (const Gdk::Color & c); bool choose_color (); @@ -79,55 +84,87 @@ class RouteUI : public virtual AxisView bool multiple_mute_change; bool multiple_solo_change; + BindableToggleButton* invert_button; BindableToggleButton* mute_button; BindableToggleButton* solo_button; - BindableToggleButton* rec_enable_button; - - virtual string solo_button_name () const { return "SoloButton"; } - virtual string safe_solo_button_name () const { return "SafeSoloButton"; } - + BindableToggleButton* rec_enable_button; /* audio tracks */ + BindableToggleButton* show_sends_button; /* busses */ + + LED* solo_safe_led; + LED* solo_isolated_led; + + Gtk::Label solo_button_label; + Gtk::Label mute_button_label; + Gtk::Label invert_button_label; + Gtk::Label rec_enable_button_label; + + void send_blink (bool); + sigc::connection send_blink_connection; + + virtual std::string solo_button_name () const { return "SoloButton"; } + virtual std::string safe_solo_button_name () const { return "SafeSoloButton"; } + Gtk::Menu* mute_menu; Gtk::Menu* solo_menu; - Gtk::Menu* remote_control_menu; + Gtk::Menu* sends_menu; XMLNode *xml_node; void ensure_xml_node (); virtual XMLNode* get_automation_child_xml_node (Evoral::Parameter param); - + + void invert_toggled(); bool mute_press(GdkEventButton*); bool mute_release(GdkEventButton*); bool solo_press(GdkEventButton*); bool solo_release(GdkEventButton*); bool rec_enable_press(GdkEventButton*); bool rec_enable_release(GdkEventButton*); - - void solo_changed(void*); + bool show_sends_press(GdkEventButton*); + bool show_sends_release(GdkEventButton*); + + 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 (); + void set_sends_gain_to_unity (); + void create_sends (ARDOUR::Placement); + void create_selected_sends (ARDOUR::Placement); + + void solo_changed(bool, void*); void solo_changed_so_update_mute (); void mute_changed(void*); - virtual void processors_changed () {} + void listen_changed(void*); + virtual void processors_changed (ARDOUR::RouteProcessorChange) {} void route_rec_enable_changed(); void session_rec_enable_changed(); - void build_solo_menu (void); - void build_remote_control_menu (void); - void refresh_remote_control_menu (); + void build_solo_menu (); + + 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*); void solo_safe_toggle (void*, Gtk::CheckMenuItem*); void toggle_solo_safe (Gtk::CheckMenuItem*); - void toggle_mute_menu(ARDOUR::mute_type, Gtk::CheckMenuItem*); - void pre_fader_toggle(void*, Gtk::CheckMenuItem*); - void post_fader_toggle(void*, Gtk::CheckMenuItem*); - void control_outs_toggle(void*, Gtk::CheckMenuItem*); - void main_outs_toggle(void*, Gtk::CheckMenuItem*); + Gtk::CheckMenuItem* pre_fader_mute_check; + Gtk::CheckMenuItem* post_fader_mute_check; + Gtk::CheckMenuItem* listen_mute_check; + Gtk::CheckMenuItem* main_mute_check; + Gtk::CheckMenuItem* solo_safe_check; + Gtk::CheckMenuItem* solo_isolated_check; + void toggle_mute_menu(ARDOUR::MuteMaster::MutePoint, Gtk::CheckMenuItem*); + void muting_change (); void build_mute_menu(void); - void init_mute_menu(ARDOUR::mute_type, Gtk::CheckMenuItem*); - - void set_mix_group_solo(boost::shared_ptr, bool); - void set_mix_group_mute(boost::shared_ptr, bool); - void set_mix_group_rec_enable(boost::shared_ptr, bool); + void init_mute_menu(ARDOUR::MuteMaster::MutePoint, Gtk::CheckMenuItem*); int set_color_from_route (); @@ -135,16 +172,14 @@ class RouteUI : public virtual AxisView static gint idle_remove_this_route (RouteUI *); void route_rename(); - - virtual void name_changed (); + + virtual void property_changed (const PBD::PropertyChange&); void route_removed (); Gtk::CheckMenuItem *route_active_menu_item; void toggle_route_active (); virtual void route_active_changed (); - Gtk::CheckMenuItem *polarity_menu_item; - void toggle_polarity (); virtual void polarity_changed (); Gtk::CheckMenuItem *denormal_menu_item; @@ -157,26 +192,50 @@ class RouteUI : public virtual AxisView virtual void update_rec_display (); void update_mute_display (); - bool was_solo_safe; void update_solo_display (); virtual void map_frozen (); - void set_remote_control_id (uint32_t id, Gtk::CheckMenuItem* item); + void adjust_latency (); + void save_as_template (); + void open_remote_control_id_dialog (); - void reversibly_apply_route_boolean (string name, void (ARDOUR::Route::*func)(bool, void*), bool, void *); - void reversibly_apply_track_boolean (string name, void (ARDOUR::Track::*func)(bool, void*), bool, void *); + static int solo_visual_state (boost::shared_ptr); + static int solo_visual_state_with_isolate (boost::shared_ptr); + static int solo_isolate_visual_state (boost::shared_ptr); + static int solo_safe_visual_state (boost::shared_ptr); + static int mute_visual_state (ARDOUR::Session*, boost::shared_ptr); - void adjust_latency (); - protected: - std::vector connections; - std::string s_name; - std::string m_name; - std::string r_name; - + PBD::ScopedConnectionList route_connections; + bool self_destruct; + void init (); void reset (); + + void self_delete (); + + private: + void check_rec_enable_sensitivity (); + void parameter_changed (std::string const &); + void relabel_solo_button (); + + 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* _solo_release; + SoloMuteRelease* _mute_release; + }; #endif /* __ardour_route_ui__ */