X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;ds=sidebyside;f=gtk2_ardour%2Froute_ui.h;h=9990fd14d0b26ca62050a7eccfb4fd959344c90d;hb=10cb0a7646ae7da18e5e6f49b940a5e921a73b57;hp=5dce9ee4b44e4c8a1cb6653b78f58c1d4d276e84;hpb=ce7a5e1c9fa3edf2d9cc66875505e402a0aaa6f6;p=ardour.git diff --git a/gtk2_ardour/route_ui.h b/gtk2_ardour/route_ui.h index 5dce9ee4b4..9990fd14d0 100644 --- a/gtk2_ardour/route_ui.h +++ b/gtk2_ardour/route_ui.h @@ -47,6 +47,7 @@ namespace Gtk { } class BindableToggleButton; +class LED; class RouteUI : public virtual AxisView { @@ -62,6 +63,7 @@ class RouteUI : public virtual AxisView bool is_track() const; bool is_audio_track() const; bool is_midi_track() const; + bool has_audio_outputs () const; boost::shared_ptr route() const { return _route; } @@ -69,27 +71,31 @@ class RouteUI : public virtual AxisView boost::shared_ptr audio_track() const; boost::shared_ptr midi_track() const; - boost::shared_ptr get_diskstream() 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 (); + void request_redraw (); + + virtual void set_color (const Gdk::Color & c); + void choose_color (); bool ignore_toggle; bool wait_for_release; bool multiple_mute_change; 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 */ + LED* solo_safe_led; + LED* solo_isolated_led; + Gtk::Label solo_button_label; Gtk::Label mute_button_label; Gtk::Label rec_enable_button_label; @@ -104,12 +110,6 @@ class RouteUI : public virtual AxisView Gtk::Menu* solo_menu; Gtk::Menu* sends_menu; - - XMLNode *xml_node; - void ensure_xml_node (); - - virtual XMLNode* get_automation_child_xml_node (Evoral::Parameter param); - bool mute_press(GdkEventButton*); bool mute_release(GdkEventButton*); bool solo_press(GdkEventButton*); @@ -128,10 +128,10 @@ class RouteUI : public virtual AxisView 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 create_sends (ARDOUR::Placement, bool); + void create_selected_sends (ARDOUR::Placement, bool); - void solo_changed(void*); + void solo_changed(bool, void*); void solo_changed_so_update_mute (); void mute_changed(void*); void listen_changed(void*); @@ -144,6 +144,9 @@ class RouteUI : public virtual AxisView 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*); @@ -151,6 +154,8 @@ class RouteUI : public virtual AxisView 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 (); @@ -159,20 +164,24 @@ 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(); - 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 (); + virtual void route_active_changed () {} + void set_route_active (bool, bool); + + Gtk::Menu* record_menu; + void build_record_menu (); + + Gtk::CheckMenuItem *step_edit_item; + void toggle_step_edit (); + virtual void step_edit_changed (bool); - Gtk::CheckMenuItem *polarity_menu_item; - void toggle_polarity (); virtual void polarity_changed (); Gtk::CheckMenuItem *denormal_menu_item; @@ -196,6 +205,7 @@ class RouteUI : public virtual AxisView 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); protected: @@ -206,6 +216,10 @@ class RouteUI : public virtual AxisView void reset (); void self_delete (); + virtual void start_step_editing () {} + virtual void stop_step_editing() {} + + void set_invert_sensitive (bool); private: void check_rec_enable_sensitivity (); @@ -213,10 +227,10 @@ class RouteUI : public virtual AxisView void relabel_solo_button (); 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; @@ -228,6 +242,17 @@ class RouteUI : public virtual AxisView SoloMuteRelease* _solo_release; SoloMuteRelease* _mute_release; + 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 *); + + int _i_am_the_modifier; + std::list _invert_buttons; + Gtk::Menu* _invert_menu; + + static uint32_t _max_invert_buttons; }; #endif /* __ardour_route_ui__ */