introduce GUIObjectState; massive, pervasive changes in visibility and height managem...
[ardour.git] / gtk2_ardour / route_ui.h
index 643c39b9604ab18242f5d9d793d53a3a7fa28127..9990fd14d0b26ca62050a7eccfb4fd959344c90d 100644 (file)
@@ -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__
 
 #include <list>
 
-#include <pbd/xml++.h>
-#include <ardour/ardour.h>
-#include <ardour/route.h>
-#include <ardour/track.h>
+#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"
 
@@ -42,120 +47,212 @@ namespace Gtk {
 }
 
 class BindableToggleButton;
+class LED;
 
 class RouteUI : public virtual AxisView
 {
   public:
-       RouteUI(boost::shared_ptr<ARDOUR::Route>, ARDOUR::Session&, const char*, const char*, const char*);
+       RouteUI(ARDOUR::Session*);
+       RouteUI(boost::shared_ptr<ARDOUR::Route>, ARDOUR::Session*);
+
        virtual ~RouteUI();
 
+       virtual void set_route (boost::shared_ptr<ARDOUR::Route>);
+       virtual void set_button_names () = 0;
+
        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; }
-       
-       // FIXME: make these return shared_ptr
-       ARDOUR::Track*      track() const;
-       ARDOUR::AudioTrack* audio_track() const;
-       ARDOUR::MidiTrack*  midi_track() const;
-       
-       ARDOUR::Diskstream* get_diskstream() const;
 
-       string name() const;
+       boost::shared_ptr<ARDOUR::Track>      track() const;
+       boost::shared_ptr<ARDOUR::AudioTrack> audio_track() const;
+       boost::shared_ptr<ARDOUR::MidiTrack>  midi_track() 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;
-       
-       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;
+       BindableToggleButton* rec_enable_button; /* audio tracks */
+       BindableToggleButton* show_sends_button; /* busses */
+
+        LED* solo_safe_led;
+        LED* solo_isolated_led;
 
-       XMLNode *xml_node;
-       void ensure_xml_node ();
+       Gtk::Label solo_button_label;
+       Gtk::Label mute_button_label;
+       Gtk::Label rec_enable_button_label;
 
-       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*);
+       void send_blink (bool);
+       sigc::connection send_blink_connection;
 
-       void solo_changed(void*);
+       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;
+
+       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*);
+       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, bool);
+       void create_selected_sends (ARDOUR::Placement, bool);
+
+       void solo_changed(bool, void*);
+       void solo_changed_so_update_mute ();
        void mute_changed(void*);
-       virtual void redirects_changed (void *) {}
+       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<ARDOUR::Route>, bool);
-       void set_mix_group_mute(boost::shared_ptr<ARDOUR::Route>, bool);
-       void set_mix_group_rec_enable(boost::shared_ptr<ARDOUR::Route>, bool);
+       void init_mute_menu(ARDOUR::MuteMaster::MutePoint, Gtk::CheckMenuItem*);
 
        int  set_color_from_route ();
 
-       sigc::connection blink_connection;
-
-       void rec_enable_button_blink (bool onoff, ARDOUR::AudioDiskstream *, Gtk::Widget *w);
-       
-       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 (void *src);
+
+       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;
+       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 ();
+
        void update_solo_display ();
-       virtual void map_frozen ();
 
-       void set_remote_control_id (uint32_t id, Gtk::CheckMenuItem* item);
+       virtual void map_frozen ();
 
-       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 adjust_latency ();
+       void save_as_template ();
+       void open_remote_control_id_dialog ();
+
+       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:
+       PBD::ScopedConnectionList route_connections;
+       bool self_destruct;
+
+       void init ();
+       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 ();
+       void parameter_changed (std::string const &);
+       void relabel_solo_button ();
+
+       struct SoloMuteRelease {
+           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;
+           boost::shared_ptr<ARDOUR::Route> route;
+           bool active;
+           bool exclusive;
+       };
+
+       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__ */