X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Froute_ui.h;h=f3021f675dd1c08fdab50f494eda32d25f0b9b93;hb=cd9fdb935f08966cc8c7170a39870e8adcae69d8;hp=c49583ab4522751b32085e19602bacd92f86fcf0;hpb=5c819462b8f146b25a7dbe2c948a8407e7c5dbbb;p=ardour.git diff --git a/gtk2_ardour/route_ui.h b/gtk2_ardour/route_ui.h index c49583ab45..f3021f675d 100644 --- a/gtk2_ardour/route_ui.h +++ b/gtk2_ardour/route_ui.h @@ -15,7 +15,6 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id$ */ #ifndef __ardour_route_ui__ @@ -26,15 +25,13 @@ #include #include #include +#include #include "axis_view.h" -namespace Gtkmm2ext { - class BindableToggleButton; -} - namespace ARDOUR { class AudioTrack; + class MidiTrack; } namespace Gtk { @@ -43,21 +40,31 @@ namespace Gtk { class Widget; } +class BindableToggleButton; + class RouteUI : public virtual AxisView { public: - RouteUI(ARDOUR::Route&, ARDOUR::Session&, const char*, const char*, const char*); + RouteUI(boost::shared_ptr, ARDOUR::Session&, const char*, const char*, const char*); virtual ~RouteUI(); + bool is_track() const; bool is_audio_track() const; - ARDOUR::DiskStream* get_diskstream() const; + bool is_midi_track() const; - ARDOUR::Route& route() const { return _route; } - ARDOUR::AudioTrack* audio_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; - - ARDOUR::Route& _route; + + // protected: XXX sigh this should be here + + boost::shared_ptr _route; void set_color (const Gdk::Color & c); bool choose_color (); @@ -65,33 +72,39 @@ class RouteUI : public virtual AxisView bool ignore_toggle; bool wait_for_release; - Gtkmm2ext::BindableToggleButton * mute_button; - Gtkmm2ext::BindableToggleButton * solo_button; - Gtkmm2ext::BindableToggleButton * rec_enable_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"; } Gtk::Menu* mute_menu; Gtk::Menu* solo_menu; + Gtk::Menu* remote_control_menu; XMLNode *xml_node; void ensure_xml_node (); XMLNode* get_child_xml_node (const string & childname); - gint mute_press(GdkEventButton*); - gint mute_release(GdkEventButton*); - gint solo_press(GdkEventButton*); - gint solo_release(GdkEventButton*); - gint rec_enable_press(GdkEventButton*); + 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*); + void solo_changed_so_update_mute (); void mute_changed(void*); - void route_rec_enable_changed(void*); + virtual void redirects_changed (void *) {} + 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 solo_safe_toggle (void*, Gtk::CheckMenuItem*); void toggle_solo_safe (Gtk::CheckMenuItem*); @@ -105,15 +118,15 @@ class RouteUI : public virtual AxisView void build_mute_menu(void); void init_mute_menu(ARDOUR::mute_type, Gtk::CheckMenuItem*); - void set_mix_group_solo(ARDOUR::Route&, bool); - void set_mix_group_mute(ARDOUR::Route&, bool); - void set_mix_group_rec_enable(ARDOUR::Route&, bool); + 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); int set_color_from_route (); sigc::connection blink_connection; - void rec_enable_button_blink (bool onoff, ARDOUR::DiskStream *, Gtk::Widget *w); + void rec_enable_button_blink (bool onoff, ARDOUR::AudioDiskstream *, Gtk::Widget *w); void remove_this_route (); static gint idle_remove_this_route (RouteUI *); @@ -123,22 +136,33 @@ class RouteUI : public virtual AxisView virtual void name_changed (void *src); void route_removed (); - static gint okay_gplusplus_cannot_do_complex_templates (RouteUI *rui); - 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; + void toggle_denormal_protection(); + virtual void denormal_protection_changed (); + void disconnect_input (); void disconnect_output (); - void update_rec_display (); + 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 reversibly_apply_route_boolean (string name, void (ARDOUR::Route::*func)(bool, void*), bool, void *); - void reversibly_apply_audio_track_boolean (string name, void (ARDOUR::AudioTrack::*func)(bool, void*), bool, void *); + void reversibly_apply_track_boolean (string name, void (ARDOUR::Track::*func)(bool, void*), bool, void *); }; #endif /* __ardour_route_ui__ */