X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmixer_strip.h;h=e4cecf358602780827e9ad5fe8b886fe6eb7d101;hb=007c4ffdc0bb8a6de967e499885284b2d3b3d0c2;hp=c1c1726902aa1bf5e34e6a07072fcdd6c4bd191e;hpb=da7d7f950233f109f82f7e7ea5c62f81ef3d7bbb;p=ardour.git diff --git a/gtk2_ardour/mixer_strip.h b/gtk2_ardour/mixer_strip.h index c1c1726902..e4cecf3586 100644 --- a/gtk2_ardour/mixer_strip.h +++ b/gtk2_ardour/mixer_strip.h @@ -23,21 +23,16 @@ #include -#include +#include #include #include +#include #include -#include #include -#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 #include "pbd/stateful.h" @@ -47,9 +42,11 @@ #include "pbd/fastlog.h" +#include "widgets/ardour_button.h" +#include "widgets/ardour_knob.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" @@ -78,7 +75,7 @@ class ArdourWindow; class MixerStrip : public AxisView, public RouteUI, public Gtk::EventBox { - public: +public: MixerStrip (Mixer_UI&, ARDOUR::Session*, boost::shared_ptr, bool in_mixer = true); MixerStrip (Mixer_UI&, ARDOUR::Session*, bool in_mixer = true); ~MixerStrip (); @@ -144,14 +141,14 @@ class MixerStrip : public AxisView, public RouteUI, public Gtk::EventBox static MixerStrip* entered_mixer_strip() { return _entered_mixer_strip; } - protected: +protected: friend class Mixer_UI; void set_packed (bool yn); bool packed () { return _packed; } void set_stuff_from_route (); - private: +private: Mixer_UI& _mixer; void init (); @@ -162,11 +159,11 @@ class MixerStrip : public AxisView, public RouteUI, public Gtk::EventBox Width _width; void* _width_owner; - ArdourButton hide_button; - ArdourButton width_button; - ArdourButton number_label; - Gtk::HBox width_hide_box; - Gtk::EventBox* spacer; + ArdourWidgets::ArdourButton hide_button; + ArdourWidgets::ArdourButton width_button; + ArdourWidgets::ArdourButton number_label; + Gtk::HBox width_hide_box; + Gtk::EventBox spacer; void hide_clicked(); bool width_button_pressed (GdkEventButton *); @@ -185,22 +182,23 @@ class MixerStrip : public AxisView, public RouteUI, public Gtk::EventBox Gtk::Table mute_solo_table; Gtk::Table bottom_button_table; - ArdourButton meter_point_button; + void vca_assign (boost::shared_ptr); + void vca_unassign (boost::shared_ptr); void meter_changed (); void monitor_changed (); - ArdourButton input_button; - ArdourButton output_button; + ArdourWidgets::ArdourButton input_button; + ArdourWidgets::ArdourButton output_button; - ArdourButton* monitor_section_button; + ArdourWidgets::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; + ArdourWidgets::ArdourButton* midi_input_enable_button; + Gtk::HBox input_button_box; std::string longest_label; @@ -214,16 +212,17 @@ class MixerStrip : public AxisView, public RouteUI, public Gtk::EventBox gint mark_update_safe (); guint32 mode_switch_in_progress; - ArdourButton name_button; + ArdourWidgets::ArdourButton name_button; + ArdourWidgets::ArdourButton _comment_button; + ArdourWidgets::ArdourKnob trim_control; - ArdourButton _comment_button; - - ArdourKnob trim_control; + void trim_start_touch (); + void trim_end_touch (); void setup_comment_button (); - ArdourButton group_button; - RouteGroupMenu *group_menu; + ArdourWidgets::ArdourButton group_button; + RouteGroupMenu* group_menu; gint input_press (GdkEventButton *); gint input_release (GdkEventButton *); @@ -237,7 +236,8 @@ class MixerStrip : public AxisView, public RouteUI, public Gtk::EventBox Gtk::Menu output_menu; std::list > output_menu_bundles; - void maybe_add_bundle_to_output_menu (boost::shared_ptr, ARDOUR::BundleList const &); + void maybe_add_bundle_to_output_menu (boost::shared_ptr, ARDOUR::BundleList const &, + ARDOUR::DataType type = ARDOUR::DataType::NIL); void bundle_input_chosen (boost::shared_ptr); void bundle_output_chosen (boost::shared_ptr); @@ -246,13 +246,13 @@ class MixerStrip : public AxisView, public RouteUI, public Gtk::EventBox void io_changed_proxy (); Gtk::Menu *send_action_menu; - Gtk::MenuItem* rename_menu_item; void build_send_action_menu (); 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 (); @@ -263,7 +263,6 @@ class MixerStrip : public AxisView, public RouteUI, public Gtk::EventBox Gtk::Menu* route_ops_menu; void build_route_ops_menu (); gboolean name_button_button_press (GdkEventButton*); - gboolean name_button_button_release (GdkEventButton*); gboolean number_button_button_press (GdkEventButton*); void list_route_operations (); @@ -299,7 +298,9 @@ class MixerStrip : public AxisView, public RouteUI, public Gtk::EventBox void reset_strip_style (); - void update_io_button (boost::shared_ptr route, Width width, bool input_button); + ARDOUR::DataType guess_main_type(bool for_input, bool favor_connected = true) const; + + void update_io_button (bool input_button); void port_connected_or_disconnected (boost::weak_ptr, boost::weak_ptr); bool mixer_strip_enter_event ( GdkEventCrossing * );