X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Froute_ui.h;h=0501c78937406c80721aadc299c37de2cedb716c;hb=b4d7120a58cb3fc2a49542acab868e0eb0790864;hp=ff133642a2d9cee24fbffb5555a5ecf6ff444b6e;hpb=6ffc443eaa19a9d421cc4bc957e9a12b3047ae9e;p=ardour.git diff --git a/gtk2_ardour/route_ui.h b/gtk2_ardour/route_ui.h index ff133642a2..0501c78937 100644 --- a/gtk2_ardour/route_ui.h +++ b/gtk2_ardour/route_ui.h @@ -25,6 +25,8 @@ #include "pbd/xml++.h" #include "pbd/signals.h" +#include "gtkmm2ext/widget_state.h" + #include "ardour/ardour.h" #include "ardour/mute_master.h" #include "ardour/session_event.h" @@ -34,6 +36,7 @@ #include "ardour/track.h" #include "axis_view.h" +#include "selectable.h" namespace ARDOUR { class AudioTrack; @@ -47,7 +50,7 @@ namespace Gtk { } class BindableToggleButton; -class LED; +class ArdourButton; class RouteUI : public virtual AxisView { @@ -57,6 +60,8 @@ class RouteUI : public virtual AxisView virtual ~RouteUI(); + Gdk::Color color () const; + virtual void set_route (boost::shared_ptr); virtual void set_button_names () = 0; @@ -66,6 +71,7 @@ class RouteUI : public virtual AxisView bool has_audio_outputs () const; boost::shared_ptr route() const { return _route; } + ARDOUR::RouteGroup* route_group() const; boost::shared_ptr track() const; boost::shared_ptr audio_track() const; @@ -77,8 +83,10 @@ class RouteUI : public virtual AxisView boost::shared_ptr _route; - void set_color (const Gdk::Color & c); - bool choose_color (); + void request_redraw (); + + virtual void set_color (const Gdk::Color & c); + void choose_color (); bool ignore_toggle; bool wait_for_release; @@ -86,33 +94,28 @@ class RouteUI : public virtual AxisView bool multiple_solo_change; Gtk::HBox _invert_button_box; - BindableToggleButton* mute_button; - BindableToggleButton* solo_button; - BindableToggleButton* rec_enable_button; /* audio tracks */ - BindableToggleButton* show_sends_button; /* busses */ + 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; - LED* solo_safe_led; - LED* solo_isolated_led; + Glib::RefPtr solo_safe_pixbuf; - Gtk::Label solo_button_label; - Gtk::Label mute_button_label; - Gtk::Label rec_enable_button_label; + ArdourButton* solo_safe_led; + ArdourButton* solo_isolated_led; + + Gtk::Label monitor_input_button_label; + Gtk::Label monitor_disk_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* sends_menu; - XMLNode *xml_node; - void ensure_xml_node (); - - virtual XMLNode* get_automation_child_xml_node (Evoral::Parameter); - bool mute_press(GdkEventButton*); bool mute_release(GdkEventButton*); bool solo_press(GdkEventButton*); @@ -122,6 +125,14 @@ class RouteUI : public virtual AxisView bool show_sends_press(GdkEventButton*); bool show_sends_release(GdkEventButton*); + bool monitor_release(GdkEventButton*, ARDOUR::MonitorChoice); + bool monitor_input_press(GdkEventButton*); + bool monitor_input_release(GdkEventButton*); + bool monitor_disk_press(GdkEventButton*); + bool monitor_disk_release(GdkEventButton*); + void monitoring_changed (); + void update_monitoring_display (); + void step_gain_up (); void step_gain_down (); void page_gain_up (); @@ -167,7 +178,7 @@ class RouteUI : public virtual AxisView int set_color_from_route (); - void remove_this_route (); + void remove_this_route (bool apply_to_selection = false); static gint idle_remove_this_route (RouteUI *); void route_rename(); @@ -175,9 +186,8 @@ class RouteUI : public virtual AxisView 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 (); + virtual void route_active_changed () {} + void set_route_active (bool, bool); Gtk::Menu* record_menu; void build_record_menu (); @@ -185,7 +195,7 @@ class RouteUI : public virtual AxisView Gtk::CheckMenuItem *step_edit_item; void toggle_step_edit (); virtual void step_edit_changed (bool); - + virtual void polarity_changed (); Gtk::CheckMenuItem *denormal_menu_item; @@ -206,11 +216,16 @@ class RouteUI : public virtual AxisView void save_as_template (); void open_remote_control_id_dialog (); - 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); + static Gtkmm2ext::ActiveState solo_active_state (boost::shared_ptr); + static Gtkmm2ext::ActiveState solo_isolate_active_state (boost::shared_ptr); + static Gtkmm2ext::ActiveState solo_safe_active_state (boost::shared_ptr); + static Gtkmm2ext::ActiveState mute_active_state (ARDOUR::Session*, boost::shared_ptr); + + /** Emitted when a bus has been set or unset from `display sends to this bus' mode + * by a click on the `Sends' button. The parameter is the route that the sends are + * to, or 0 if no route is now in this mode. + */ + static sigc::signal > BusSendDisplayChanged; protected: PBD::ScopedConnectionList route_connections; @@ -224,17 +239,25 @@ class RouteUI : public virtual AxisView virtual void stop_step_editing() {} void set_invert_sensitive (bool); + bool verify_new_route_name (const std::string& name); + + void route_gui_changed (std::string); + virtual void route_color_changed () {} + + virtual void bus_send_display_changed (boost::shared_ptr); private: void check_rec_enable_sensitivity (); void parameter_changed (std::string const &); void relabel_solo_button (); + std::string route_state_id () const; + struct SoloMuteRelease { - SoloMuteRelease (bool was_active) + SoloMuteRelease (bool was_active) : active (was_active) , exclusive (false) {} - + boost::shared_ptr routes; boost::shared_ptr routes_on; boost::shared_ptr routes_off; @@ -248,14 +271,17 @@ class RouteUI : public virtual AxisView void setup_invert_buttons (); void set_invert_button_state (); - void invert_toggled (uint32_t, BindableToggleButton *); void invert_menu_toggled (uint32_t); bool invert_press (GdkEventButton *); - + bool invert_release (GdkEventButton *, uint32_t i); + int _i_am_the_modifier; - std::list _invert_buttons; + std::vector _invert_buttons; Gtk::Menu* _invert_menu; + static void set_showing_sends_to (boost::shared_ptr); + static boost::weak_ptr _showing_sends_to; + static uint32_t _max_invert_buttons; };