X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmixer_strip.h;h=eb6da17f87823ad705cad8753c65a962f666f742;hb=946a99f554a158d569b2cea5310a1197664dcda5;hp=acb69534b3d590b667e1076590bd8a416f059aa2;hpb=b6f4cdaea27fbf49f924b2684d4c638089314067;p=ardour.git diff --git a/gtk2_ardour/mixer_strip.h b/gtk2_ardour/mixer_strip.h index acb69534b3..eb6da17f87 100644 --- a/gtk2_ardour/mixer_strip.h +++ b/gtk2_ardour/mixer_strip.h @@ -34,9 +34,10 @@ #include #include -#include -#include -#include +#include "gtkmm2ext/auto_spin.h" +#include "gtkmm2ext/click_box.h" +#include "gtkmm2ext/bindable_button.h" +#include "gtkmm2ext/stateful_button.h" #include "pbd/stateful.h" @@ -46,16 +47,15 @@ #include "pbd/fastlog.h" +#include "axis_view.h" +#include "control_slave_ui.h" +#include "ardour_knob.h" #include "route_ui.h" #include "gain_meter.h" #include "panner_ui.h" #include "enums.h" #include "processor_box.h" -#include "ardour_dialog.h" - -namespace Gtkmm2ext { - class SliderController; -} +#include "visibility_group.h" namespace ARDOUR { class Route; @@ -72,17 +72,24 @@ namespace Gtk { } class Mixer_UI; -class IOSelectorWindow; class MotionController; class RouteGroupMenu; +class ArdourWindow; -class MixerStrip : public RouteUI, public Gtk::EventBox +class MixerStrip : public AxisView, public RouteUI, public Gtk::EventBox { public: MixerStrip (Mixer_UI&, ARDOUR::Session*, boost::shared_ptr, bool in_mixer = true); MixerStrip (Mixer_UI&, ARDOUR::Session*, bool in_mixer = true); ~MixerStrip (); + std::string name() const; + Gdk::Color color () const; + bool marked_for_display () const; + bool set_marked_for_display (bool); + + boost::shared_ptr stripable() const { return RouteUI::stripable(); } + void set_width_enum (Width, void* owner); Width get_width_enum () const { return _width; } void* width_owner () const { return _width_owner; } @@ -94,29 +101,56 @@ 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); + void revert_to_default_display (); + + /** @return the delivery that is being edited using our fader; it will be the + * last send passed to ::show_send, or our route's main out delivery. + */ + boost::shared_ptr current_delivery () const { + return _current_delivery; + } - sigc::signal WidthChanged; + bool mixer_owned () const { + return _mixer_owned; + } + + void hide_things (); + + sigc::signal WidthChanged; + + /** 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 deselect_all_processors (); + bool delete_processors (); //note: returns false if nothing was deleted + void toggle_processors (); + void ab_plugins (); + + void set_selected (bool yn); + + static MixerStrip* entered_mixer_strip() { return _entered_mixer_strip; } + protected: friend class Mixer_UI; void set_packed (bool yn); bool packed () { return _packed; } - 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; @@ -128,66 +162,74 @@ 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; + ArdourButton number_label; Gtk::HBox width_hide_box; - Gtk::VBox whvbox; - Gtk::EventBox top_event_box; Gtk::EventBox* spacer; - Gtk::Alignment gain_meter_alignment; void hide_clicked(); - void width_clicked (); + bool width_button_pressed (GdkEventButton *); Gtk::Frame global_frame; Gtk::VBox global_vpacker; ProcessorBox processor_box; - GainMeter gpm; - PannerUI panners; - Gtk::ToggleButton _mono_button; + GainMeter gpm; + PannerUI panners; - Gtk::Table button_table; - Gtk::Table middle_button_table; + Glib::RefPtr button_size_group; + + Gtk::Table rec_mon_table; + Gtk::Table solo_iso_table; + Gtk::Table mute_solo_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 (); + void monitor_changed (); + + ArdourButton input_button; + ArdourButton output_button; - void meter_changed (void *); + ArdourButton* monitor_section_button; - Gtk::Button diskstream_button; - Gtk::Label diskstream_label; + void input_button_resized (Gtk::Allocation&); + void output_button_resized (Gtk::Allocation&); + void comment_button_resized (Gtk::Allocation&); - Gtk::Button input_button; - Gtk::Label input_label; - Gtk::Button output_button; - Gtk::Label output_label; + ArdourButton* midi_input_enable_button; + Gtk::HBox input_button_box; std::string longest_label; + void midi_input_status_changed (); + bool input_active_button_press (GdkEventButton*); + bool input_active_button_release (GdkEventButton*); + + void help_count_plugins (boost::weak_ptr); + uint32_t _plugin_insert_cnt; + gint mark_update_safe (); guint32 mode_switch_in_progress; - Gtk::Button name_button; + ArdourButton name_button; - ArdourDialog* comment_window; - Gtk::TextView* comment_area; - Gtk::Button comment_button; + ArdourButton _comment_button; - void comment_editor_done_editing(); - void setup_comment_editor (); - void comment_button_clicked (); - void mono_button_clicked (); + ArdourKnob trim_control; - Gtk::Button group_button; - Gtk::Label group_label; + void setup_comment_button (); + + ArdourButton group_button; RouteGroupMenu *group_menu; gint input_press (GdkEventButton *); + gint input_release (GdkEventButton *); + gint output_press (GdkEventButton *); + gint output_release (GdkEventButton *); Gtk::Menu input_menu; std::list > input_menu_bundles; @@ -197,27 +239,21 @@ 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 edit_input_configuration (); - void edit_output_configuration (); + void bundle_input_chosen (boost::shared_ptr); + void bundle_output_chosen (boost::shared_ptr); void diskstream_changed (); + void io_changed_proxy (); Gtk::Menu *send_action_menu; Gtk::MenuItem* rename_menu_item; void build_send_action_menu (); - void new_send (); - void show_send_controls (); - - void input_changed (ARDOUR::IOChange, void *); - void output_changed (ARDOUR::IOChange, void *); - PBD::ScopedConnection panstate_connection; PBD::ScopedConnection panstyle_connection; void connect_to_pan (); + void update_panner_choices (); + void update_trim_control (); void update_diskstream_display (); void update_input_display (); @@ -227,29 +263,21 @@ class MixerStrip : public RouteUI, public Gtk::EventBox Gtk::Menu* route_ops_menu; void build_route_ops_menu (); - gint name_button_button_press (GdkEventButton*); + gboolean name_button_button_press (GdkEventButton*); + gboolean name_button_button_release (GdkEventButton*); + gboolean number_button_button_press (GdkEventButton*); void list_route_operations (); - gint comment_key_release_handler (GdkEventKey*); - void comment_changed (void *src); - void comment_edited (); - bool ignore_comment_edit; - - void set_route_group (ARDOUR::RouteGroup *); bool select_route_group (GdkEventButton *); void route_group_changed (); - IOSelectorWindow *input_selector; - IOSelectorWindow *output_selector; - Gtk::Style *passthru_style; - void route_gui_changed (std::string, void*); - void show_route_color (); + void route_color_changed (); void show_passthru_color (); - void route_active_changed (); - + void route_property_changed (const PBD::PropertyChange&); + void name_button_resized (Gtk::Allocation&); void name_changed (); void update_speed_display (); void map_frozen (); @@ -258,21 +286,55 @@ class MixerStrip : public RouteUI, public Gtk::EventBox bool ignore_speed_adjustment; + static MixerStrip* _entered_mixer_strip; + void engine_running(); void engine_stopped(); - void switch_io (boost::shared_ptr); - boost::shared_ptr _current_delivery; - void revert_to_default_display (); + virtual void bus_send_display_changed (boost::shared_ptr); + + void set_current_delivery (boost::shared_ptr); void drop_send (); PBD::ScopedConnection send_gone_connection; void reset_strip_style (); - static int scrollbar_height; - void update_io_button (boost::shared_ptr route, Width width, bool input_button); + void port_connected_or_disconnected (boost::weak_ptr, boost::weak_ptr); + + bool mixer_strip_enter_event ( GdkEventCrossing * ); + bool mixer_strip_leave_event ( GdkEventCrossing * ); + + /** 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-element-visibility, which happen when the user makes changes in + * the RC option editor. + */ + VisibilityGroup _visibility; + boost::optional override_solo_visibility () const; + + PBD::ScopedConnectionList _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; + + std::string meter_point_string (ARDOUR::MeterPoint); + + void update_track_number_visibility (); + + ControlSlaveUI control_slave_ui; }; #endif /* __ardour_mixer_strip__ */