introduce GUIObjectState; massive, pervasive changes in visibility and height managem...
[ardour.git] / gtk2_ardour / mixer_strip.h
index 45e0fce52d342093c1d55a556240abed0bdb00ae..4ef0c2f223d6c63f392876c552b08211afc8a6aa 100644 (file)
@@ -37,6 +37,7 @@
 #include "gtkmm2ext/auto_spin.h"
 #include "gtkmm2ext/click_box.h"
 #include "gtkmm2ext/bindable_button.h"
+#include "gtkmm2ext/stateful_button.h"
 
 #include "pbd/stateful.h"
 
@@ -107,6 +108,8 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
                return _mixer_owned;
        }
 
+       void hide_things ();
+
        sigc::signal<void> WidthChanged;
 
        /** The delivery that we are handling the level for with our fader has changed */
@@ -115,6 +118,8 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        static sigc::signal<void,boost::shared_ptr<ARDOUR::Route> > SwitchIO;
        static PBD::Signal1<void,MixerStrip*> CatchDeletion;
 
+       std::string state_id() const;
+
   protected:
        friend class Mixer_UI;
        void set_packed (bool yn);
@@ -145,7 +150,6 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        Gtk::VBox           whvbox;
        Gtk::EventBox       top_event_box;
        Gtk::EventBox*      spacer;
-       Gtk::Alignment      gain_meter_alignment;
 
        void hide_clicked();
        void width_clicked ();
@@ -154,15 +158,18 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        Gtk::VBox           global_vpacker;
 
        ProcessorBox processor_box;
-       GainMeter   gpm;
-       PannerUI    panners;
+       GainMeter    gpm;
+       PannerUI     panners;
 
        Gtk::Table button_table;
-        Gtk::Table solo_led_table;
-        Gtk::HBox  solo_led_box;
+       Gtk::Table solo_led_table;
+       Gtk::HBox  below_panner_box;
        Gtk::Table middle_button_table;
        Gtk::Table bottom_button_table;
 
+       Gtk::Label* _iso_label;
+       Gtk::Label* _safe_label;
+
        Gtk::Button                  gain_unit_button;
        Gtk::Label                   gain_unit_label;
        Gtk::Button                  meter_point_button;
@@ -174,12 +181,18 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        Gtk::Label  diskstream_label;
 
        Gtk::Button input_button;
+       Gtkmm2ext::StatefulToggleButton* midi_input_enable_button;
+       Gtk::HBox   input_button_box;
        Gtk::Label  input_label;
        Gtk::Button output_button;
        Gtk::Label  output_label;
 
        std::string longest_label;
 
+       void midi_input_status_changed ();
+       bool input_active_button_press (GdkEventButton*);
+       bool input_active_button_release (GdkEventButton*);
+
        gint    mark_update_safe ();
        guint32 mode_switch_in_progress;
 
@@ -191,7 +204,6 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void comment_editor_done_editing ();
        void setup_comment_editor ();
        void toggle_comment ();
-       void toggle_mono ();
 
        Gtk::Button   group_button;
        Gtk::Label    group_label;
@@ -217,7 +229,6 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void diskstream_changed ();
 
        Gtk::Menu *send_action_menu;
-       Gtk::CheckMenuItem* _mono_menu_item;
        Gtk::CheckMenuItem* _comment_menu_item;
        Gtk::MenuItem* rename_menu_item;
        void build_send_action_menu ();
@@ -245,7 +256,6 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void comment_edited ();
        bool ignore_comment_edit;
 
-       void set_route_group (ARDOUR::RouteGroup *);
        bool select_route_group (GdkEventButton *);
        void route_group_changed ();
 
@@ -258,8 +268,6 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void show_route_color ();
        void show_passthru_color ();
 
-       void route_active_changed ();
-
        void name_changed ();
        void update_speed_display ();
        void map_frozen ();
@@ -272,10 +280,10 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void engine_stopped();
 
        void switch_io (boost::shared_ptr<ARDOUR::Route>);
-       
+
        void set_current_delivery (boost::shared_ptr<ARDOUR::Delivery>);
        boost::shared_ptr<ARDOUR::Delivery> _current_delivery;
-       
+
        void drop_send ();
        PBD::ScopedConnection send_gone_connection;
 
@@ -285,6 +293,8 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
 
        void update_io_button (boost::shared_ptr<ARDOUR::Route> route, Width width, bool input_button);
        void port_connected_or_disconnected (ARDOUR::Port *, ARDOUR::Port *);
+
+       static std::string meter_point_string (ARDOUR::MeterPoint);
 };
 
 #endif /* __ardour_mixer_strip__ */