X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmixer_strip.h;h=fe10070fbb6397d2be554415b41fd0c02b457ba5;hb=89b0beb2ddf002e8d95ad89148e2c7e395294b0c;hp=14a28531232f944190022eaf162909e687621f8d;hpb=3b018f69028bf1c2701a28dad38352fbbdb8f070;p=ardour.git diff --git a/gtk2_ardour/mixer_strip.h b/gtk2_ardour/mixer_strip.h index 14a2853123..fe10070fbb 100644 --- a/gtk2_ardour/mixer_strip.h +++ b/gtk2_ardour/mixer_strip.h @@ -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); void set_button_names (); void show_send (boost::shared_ptr); @@ -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 > DeliveryChanged; - static sigc::signal > SwitchIO; static PBD::Signal1 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,31 +166,23 @@ class MixerStrip : public RouteUI, public Gtk::EventBox GainMeter gpm; PannerUI panners; + Glib::RefPtr button_size_group; + Gtk::Table button_table; - Gtk::Table solo_led_table; - Gtk::HBox below_panner_box; + Gtk::Table rec_solo_table; + Gtk::Table top_button_table; 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; - 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; @@ -196,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 *); @@ -220,8 +219,8 @@ class MixerStrip : public RouteUI, public Gtk::EventBox std::list > output_menu_bundles; void maybe_add_bundle_to_output_menu (boost::shared_ptr, ARDOUR::BundleList const &); - void bundle_input_toggled (boost::shared_ptr); - void bundle_output_toggled (boost::shared_ptr); + void bundle_input_chosen (boost::shared_ptr); + void bundle_output_chosen (boost::shared_ptr); void edit_input_configuration (); void edit_output_configuration (); @@ -229,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 (); @@ -267,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 (); @@ -278,7 +278,7 @@ class MixerStrip : public RouteUI, public Gtk::EventBox void engine_running(); void engine_stopped(); - void switch_io (boost::shared_ptr); + virtual void bus_send_display_changed (boost::shared_ptr); void set_current_delivery (boost::shared_ptr); boost::shared_ptr _current_delivery; @@ -291,9 +291,33 @@ class MixerStrip : public RouteUI, public Gtk::EventBox static int scrollbar_height; void update_io_button (boost::shared_ptr route, Width width, bool input_button); - void port_connected_or_disconnected (ARDOUR::Port *, ARDOUR::Port *); + void port_connected_or_disconnected (boost::weak_ptr, boost::weak_ptr); + + /** 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 override_solo_visibility () const; + + PBD::ScopedConnection _config_connection; + + void add_input_port (ARDOUR::DataType); + void add_output_port (ARDOUR::DataType); + + bool _suspend_menu_callbacks; + bool level_meter_button_press (GdkEventButton *); + void popup_level_meter_menu (GdkEventButton *); + void add_level_meter_item_point (Gtk::Menu_Helpers::MenuList &, Gtk::RadioMenuItem::Group &, std::string const &, ARDOUR::MeterPoint); + void add_level_meter_item_type (Gtk::Menu_Helpers::MenuList &, Gtk::RadioMenuItem::Group &, std::string const &, ARDOUR::MeterType); + void set_meter_point (ARDOUR::MeterPoint); + void set_meter_type (ARDOUR::MeterType); + PBD::ScopedConnection _level_meter_connection; - static std::string meter_point_string (ARDOUR::MeterPoint); + std::string meter_point_string (ARDOUR::MeterPoint); }; #endif /* __ardour_mixer_strip__ */