X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmixer_strip.h;h=c7a39393aa00646f99566158ab7f528fab5a9744;hb=d4190d37612ac1b9f12f83d3952ed6584c085923;hp=488981141500f18d71cc77b93642293587dbd60f;hpb=d46081c2756d2990f585a7db41adba9f1a15a1e3;p=ardour.git diff --git a/gtk2_ardour/mixer_strip.h b/gtk2_ardour/mixer_strip.h index 4889811415..c7a39393aa 100644 --- a/gtk2_ardour/mixer_strip.h +++ b/gtk2_ardour/mixer_strip.h @@ -47,6 +47,9 @@ #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" @@ -69,18 +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; } @@ -126,11 +135,14 @@ class MixerStrip : public RouteUI, public Gtk::EventBox void cut_processors (); void paste_processors (); void select_all_processors (); - void delete_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); + void set_selected (bool yn); + + static MixerStrip* entered_mixer_strip() { return _entered_mixer_strip; } protected: friend class Mixer_UI; @@ -154,8 +166,6 @@ class MixerStrip : public RouteUI, public Gtk::EventBox ArdourButton width_button; ArdourButton number_label; Gtk::HBox width_hide_box; - Gtk::VBox whvbox; - Gtk::EventBox top_event_box; Gtk::EventBox* spacer; void hide_clicked(); @@ -170,7 +180,6 @@ class MixerStrip : public RouteUI, public Gtk::EventBox Glib::RefPtr button_size_group; - Gtk::Table button_table; Gtk::Table rec_mon_table; Gtk::Table solo_iso_table; Gtk::Table mute_solo_table; @@ -179,10 +188,17 @@ class MixerStrip : public RouteUI, public Gtk::EventBox ArdourButton meter_point_button; void meter_changed (); + void monitor_changed (); ArdourButton input_button; ArdourButton output_button; + ArdourButton* monitor_section_button; + + void input_button_resized (Gtk::Allocation&); + void output_button_resized (Gtk::Allocation&); + void comment_button_resized (Gtk::Allocation&); + ArdourButton* midi_input_enable_button; Gtk::HBox input_button_box; @@ -192,26 +208,28 @@ class MixerStrip : public RouteUI, public Gtk::EventBox 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; ArdourButton name_button; - ArdourWindow* comment_window; - Gtk::TextView* comment_area; ArdourButton _comment_button; - void comment_editor_done_editing (); - void setup_comment_editor (); - void open_comment_editor (); - void toggle_comment_editor (); + ArdourKnob trim_control; + 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; @@ -224,9 +242,6 @@ class MixerStrip : public RouteUI, public Gtk::EventBox void bundle_input_chosen (boost::shared_ptr); void bundle_output_chosen (boost::shared_ptr); - void edit_input_configuration (); - void edit_output_configuration (); - void diskstream_changed (); void io_changed_proxy (); @@ -234,13 +249,11 @@ class MixerStrip : public RouteUI, public Gtk::EventBox Gtk::MenuItem* rename_menu_item; void build_send_action_menu (); - void new_send (); - void show_send_controls (); - 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 (); @@ -251,25 +264,18 @@ class MixerStrip : public RouteUI, public Gtk::EventBox Gtk::Menu* route_ops_menu; void build_route_ops_menu (); gboolean name_button_button_press (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; - bool select_route_group (GdkEventButton *); void route_group_changed (); - IOSelectorWindow *input_selector; - IOSelectorWindow *output_selector; - Gtk::Style *passthru_style; void route_color_changed (); void show_passthru_color (); - void property_changed (const PBD::PropertyChange&); + void route_property_changed (const PBD::PropertyChange&); void name_button_resized (Gtk::Allocation&); void name_changed (); void update_speed_display (); @@ -279,29 +285,31 @@ class MixerStrip : public RouteUI, public Gtk::EventBox bool ignore_speed_adjustment; + static MixerStrip* _entered_mixer_strip; + void engine_running(); void engine_stopped(); virtual void bus_send_display_changed (boost::shared_ptr); void set_current_delivery (boost::shared_ptr); - boost::shared_ptr _current_delivery; 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-strip-visibility, which happen when the user makes changes in + * mixer-element-visibility, which happen when the user makes changes in * the RC option editor. */ VisibilityGroup _visibility; @@ -322,6 +330,10 @@ class MixerStrip : public RouteUI, public Gtk::EventBox 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__ */