X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmixer_strip.h;h=6aac87850d1ccd94ad3b8fe9ac18bc747e06319b;hb=e12432cc632125821d6ed192d129ef385fb25002;hp=fdcf85e1f3f994b9939eeea47c150382f5a6718a;hpb=dbb0b9ca4f82ea8e3829cfeb009b9746c3d6f0dc;p=ardour.git diff --git a/gtk2_ardour/mixer_strip.h b/gtk2_ardour/mixer_strip.h index fdcf85e1f3..6aac87850d 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" @@ -52,10 +53,7 @@ #include "enums.h" #include "processor_box.h" #include "ardour_dialog.h" - -namespace Gtkmm2ext { - class SliderController; -} +#include "visibility_group.h" namespace ARDOUR { class Route; @@ -79,8 +77,8 @@ class RouteGroupMenu; class MixerStrip : 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 (Mixer_UI&, ARDOUR::Session*, boost::shared_ptr, bool in_mixer = true); + MixerStrip (Mixer_UI&, ARDOUR::Session*, bool in_mixer = true); ~MixerStrip (); void set_width_enum (Width, void* owner); @@ -94,13 +92,43 @@ 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; + } + + bool mixer_owned () const { + return _mixer_owned; + } + + void hide_things (); + + sigc::signal WidthChanged; - 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 delete_processors (); + void toggle_processors (); + void ab_plugins (); protected: friend class Mixer_UI; @@ -110,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; @@ -132,7 +155,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 (); @@ -141,11 +163,14 @@ class MixerStrip : public RouteUI, public Gtk::EventBox Gtk::VBox global_vpacker; ProcessorBox processor_box; - GainMeter gpm; - PannerUI panners; - Gtk::ToggleButton _mono_button; + GainMeter gpm; + PannerUI panners; + + Glib::RefPtr 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; @@ -154,17 +179,23 @@ class MixerStrip : public RouteUI, public Gtk::EventBox Gtk::Button meter_point_button; Gtk::Label meter_point_label; - void meter_changed (void *); + void meter_changed (); Gtk::Button diskstream_button; 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; - sigc::connection newplug_connection; + 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; @@ -173,12 +204,12 @@ class MixerStrip : public RouteUI, public Gtk::EventBox ArdourDialog* comment_window; Gtk::TextView* comment_area; - Gtk::Button comment_button; + Gtk::Button _comment_button; - void comment_editor_done_editing(); + void comment_editor_done_editing (); void setup_comment_editor (); - void comment_button_clicked (); - void mono_button_clicked (); + void toggle_comment (); + void setup_comment_button (); Gtk::Button group_button; Gtk::Label group_label; @@ -210,11 +241,8 @@ class MixerStrip : public RouteUI, public Gtk::EventBox void new_send (); void show_send_controls (); - void input_changed (ARDOUR::IOChange, void *); - void output_changed (ARDOUR::IOChange, void *); - - sigc::connection panstate_connection; - sigc::connection panstyle_connection; + PBD::ScopedConnection panstate_connection; + PBD::ScopedConnection panstyle_connection; void connect_to_pan (); void update_diskstream_display (); @@ -225,7 +253,7 @@ 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*); void list_route_operations (); gint comment_key_release_handler (GdkEventKey*); @@ -233,21 +261,17 @@ 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 (void *); + 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 name_changed (); void update_speed_display (); void map_frozen (); @@ -259,13 +283,37 @@ 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; - void revert_to_default_display (); + + 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); + + /** 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); + + static std::string meter_point_string (ARDOUR::MeterPoint); }; #endif /* __ardour_mixer_strip__ */