remove AU GUI debugging test in which arrow keys could be used to change GUI size
[ardour.git] / gtk2_ardour / mixer_strip.h
index dd6dddf6eaafce1a22c262cb670c34543c69d857..e5df59565c647b288637b79740d78881939385a6 100644 (file)
@@ -52,7 +52,7 @@
 #include "panner_ui.h"
 #include "enums.h"
 #include "processor_box.h"
-#include "ardour_dialog.h"
+#include "visibility_group.h"
 
 namespace ARDOUR {
        class Route;
@@ -72,6 +72,7 @@ class Mixer_UI;
 class IOSelectorWindow;
 class MotionController;
 class RouteGroupMenu;
+class ArdourWindow;
 
 class MixerStrip : public RouteUI, public Gtk::EventBox
 {
@@ -91,7 +92,6 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void fast_update ();
        void set_embedded (bool);
 
-       ARDOUR::RouteGroup* route_group() const;
        void set_route (boost::shared_ptr<ARDOUR::Route>);
        void set_button_names ();
        void show_send (boost::shared_ptr<ARDOUR::Send>);
@@ -115,11 +115,21 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        /** The delivery that we are handling the level for with our fader has changed */
        PBD::Signal1<void, boost::weak_ptr<ARDOUR::Delivery> > DeliveryChanged;
 
-       static sigc::signal<void,boost::shared_ptr<ARDOUR::Route> > SwitchIO;
        static PBD::Signal1<void,MixerStrip*> CatchDeletion;
 
        std::string state_id() const;
 
+       void parameter_changed (std::string);
+       void route_active_changed ();
+
+       void copy_processors ();
+       void cut_processors ();
+       void paste_processors ();
+       void select_all_processors ();
+       void delete_processors ();
+       void toggle_processors ();
+       void ab_plugins ();
+
   protected:
        friend class Mixer_UI;
        void set_packed (bool yn);
@@ -128,11 +138,6 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void set_selected(bool yn);
        void set_stuff_from_route ();
 
-       bool on_leave_notify_event (GdkEventCrossing* ev);
-       bool on_enter_notify_event (GdkEventCrossing* ev);
-       bool on_key_press_event (GdkEventKey* ev);
-       bool on_key_release_event (GdkEventKey* ev);
-
   private:
        Mixer_UI& _mixer;
 
@@ -144,15 +149,15 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        Width _width;
        void*  _width_owner;
 
-       Gtk::Button         hide_button;
-       Gtk::Button         width_button;
+       ArdourButton         hide_button;
+       ArdourButton         width_button;
        Gtk::HBox           width_hide_box;
        Gtk::VBox           whvbox;
        Gtk::EventBox       top_event_box;
        Gtk::EventBox*      spacer;
 
        void hide_clicked();
-       void width_clicked ();
+       bool width_button_pressed (GdkEventButton *);
 
        Gtk::Frame          global_frame;
        Gtk::VBox           global_vpacker;
@@ -161,28 +166,23 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        GainMeter    gpm;
        PannerUI     panners;
 
+       Glib::RefPtr<Gtk::SizeGroup> button_size_group;
+
        Gtk::Table button_table;
        Gtk::Table rec_solo_table;
        Gtk::Table top_button_table;
        Gtk::Table middle_button_table;
        Gtk::Table bottom_button_table;
 
-       Gtk::Button                  gain_unit_button;
-       Gtk::Label                   gain_unit_label;
-       Gtk::Button                  meter_point_button;
-       Gtk::Label                   meter_point_label;
+       ArdourButton                 meter_point_button;
 
        void meter_changed ();
 
-       Gtk::Button diskstream_button;
-       Gtk::Label  diskstream_label;
+       ArdourButton input_button;
+       ArdourButton output_button;
 
-       Gtk::Button input_button;
-       Gtkmm2ext::StatefulToggleButton* midi_input_enable_button;
+       ArdourButton* 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;
 
@@ -193,17 +193,19 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        gint    mark_update_safe ();
        guint32 mode_switch_in_progress;
 
-       Gtk::Button   name_button;
+       ArdourButton   name_button;
 
-       ArdourDialog*  comment_window;
+       ArdourWindow*  comment_window;
        Gtk::TextView* comment_area;
+       ArdourButton   _comment_button;
 
        void comment_editor_done_editing ();
        void setup_comment_editor ();
-       void toggle_comment ();
+       void open_comment_editor ();
+       void toggle_comment_editor ();
+       void setup_comment_button ();
 
-       Gtk::Button   group_button;
-       Gtk::Label    group_label;
+       ArdourButton   group_button;
        RouteGroupMenu *group_menu;
 
        gint input_press (GdkEventButton *);
@@ -226,7 +228,6 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void diskstream_changed ();
 
        Gtk::Menu *send_action_menu;
-       Gtk::CheckMenuItem* _comment_menu_item;
        Gtk::MenuItem* rename_menu_item;
        void build_send_action_menu ();
 
@@ -264,6 +265,8 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void route_color_changed ();
        void show_passthru_color ();
 
+       void property_changed (const PBD::PropertyChange&);
+       void name_button_resized (Gtk::Allocation&);
        void name_changed ();
        void update_speed_display ();
        void map_frozen ();
@@ -275,7 +278,7 @@ class MixerStrip : public RouteUI, public Gtk::EventBox
        void engine_running();
        void engine_stopped();
 
-       void switch_io (boost::shared_ptr<ARDOUR::Route>);
+       virtual void bus_send_display_changed (boost::shared_ptr<ARDOUR::Route>);
 
        void set_current_delivery (boost::shared_ptr<ARDOUR::Delivery>);
        boost::shared_ptr<ARDOUR::Delivery> _current_delivery;
@@ -290,6 +293,27 @@ 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 (boost::weak_ptr<ARDOUR::Port>, boost::weak_ptr<ARDOUR::Port>);
 
+       /** A VisibilityGroup to manage the visibility of some of our controls.
+        *  We fill it with the controls that are being managed, using the same names
+        *  as those used with _mixer_strip_visibility in RCOptionEditor.  Then
+        *  this VisibilityGroup is configured by changes to the RC variable
+        *  mixer-strip-visibility, which happen when the user makes changes in
+        *  the RC option editor.
+        */
+       VisibilityGroup _visibility;
+       boost::optional<bool> override_solo_visibility () const;
+
+       PBD::ScopedConnection _config_connection;
+
+       void add_input_port (ARDOUR::DataType);
+       void add_output_port (ARDOUR::DataType);
+
+       bool level_meter_button_press (GdkEventButton *);
+       void popup_level_meter_menu (GdkEventButton *);
+       void add_level_meter_item (Gtk::Menu_Helpers::MenuList &, Gtk::RadioMenuItem::Group &, std::string const &, ARDOUR::MeterPoint);
+       void set_meter_point (ARDOUR::MeterPoint);
+       PBD::ScopedConnection _level_meter_connection;
+
        static std::string meter_point_string (ARDOUR::MeterPoint);
 };