introduce GUIObjectState; massive, pervasive changes in visibility and height managem...
[ardour.git] / gtk2_ardour / route_ui.h
index 5dce9ee4b44e4c8a1cb6653b78f58c1d4d276e84..9990fd14d0b26ca62050a7eccfb4fd959344c90d 100644 (file)
@@ -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<ARDOUR::Route> route() const { return _route; }
 
@@ -69,27 +71,31 @@ class RouteUI : public virtual AxisView
        boost::shared_ptr<ARDOUR::AudioTrack> audio_track() const;
        boost::shared_ptr<ARDOUR::MidiTrack>  midi_track() const;
 
-       boost::shared_ptr<ARDOUR::Diskstream> get_diskstream() const;
-
        std::string name() const;
 
        // protected: XXX sigh this should be here
 
        boost::shared_ptr<ARDOUR::Route> _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<ARDOUR::Route>);
        static int solo_visual_state_with_isolate (boost::shared_ptr<ARDOUR::Route>);
        static int solo_isolate_visual_state (boost::shared_ptr<ARDOUR::Route>);
+       static int solo_safe_visual_state (boost::shared_ptr<ARDOUR::Route>);
        static int mute_visual_state (ARDOUR::Session*, boost::shared_ptr<ARDOUR::Route>);
 
    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<ARDOUR::RouteList> routes;
            boost::shared_ptr<ARDOUR::RouteList> routes_on;
            boost::shared_ptr<ARDOUR::RouteList> 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<BindableToggleButton*> _invert_buttons;
+       Gtk::Menu* _invert_menu;
+
+       static uint32_t _max_invert_buttons;
 };
 
 #endif /* __ardour_route_ui__ */