X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmixer_strip.h;h=0d3878fc2016d20da726fa3d1fcbb7cb12b51534;hb=9c4f5ac000ad91b55e4cf91317b7a89f6239870e;hp=30557b115edc229d3171c729a9fffdc7702eb5a3;hpb=7a4f1b9cf685aa5b6288b87c02d0f25397f6cd3a;p=ardour.git diff --git a/gtk2_ardour/mixer_strip.h b/gtk2_ardour/mixer_strip.h index 30557b115e..0d3878fc20 100644 --- a/gtk2_ardour/mixer_strip.h +++ b/gtk2_ardour/mixer_strip.h @@ -79,27 +79,30 @@ 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); Width get_width_enum () const { return _width; } void* width_owner () const { return _width_owner; } - GainMeter& gain_meter() { return gpm; } - PannerUI& panner_ui() { return panners; } + GainMeter& gain_meter() { return gpm; } + PannerUI& panner_ui() { return panners; } + PluginSelector* plugin_selector(); 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); sigc::signal WidthChanged; static sigc::signal > SwitchIO; + static PBD::Signal1 CatchDeletion; protected: friend class Mixer_UI; @@ -109,6 +112,11 @@ 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; @@ -134,12 +142,14 @@ class MixerStrip : public RouteUI, public Gtk::EventBox Gtk::Frame global_frame; Gtk::VBox global_vpacker; - ProcessorBox pre_processor_box; - ProcessorBox post_processor_box; + ProcessorBox processor_box; GainMeter gpm; PannerUI panners; - + Gtk::ToggleButton _mono_button; + Gtk::Table button_table; + Gtk::Table solo_led_table; + Gtk::HBox solo_led_box; Gtk::Table middle_button_table; Gtk::Table bottom_button_table; @@ -148,7 +158,7 @@ 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; @@ -158,11 +168,11 @@ class MixerStrip : public RouteUI, public Gtk::EventBox Gtk::Button output_button; Gtk::Label output_label; - sigc::connection newplug_connection; - + std::string longest_label; + gint mark_update_safe (); guint32 mode_switch_in_progress; - + Gtk::Button name_button; ArdourDialog* comment_window; @@ -172,6 +182,7 @@ class MixerStrip : public RouteUI, public Gtk::EventBox void comment_editor_done_editing(); void setup_comment_editor (); void comment_button_clicked (); + void mono_button_clicked (); Gtk::Button group_button; Gtk::Label group_label; @@ -180,12 +191,14 @@ class MixerStrip : public RouteUI, public Gtk::EventBox gint input_press (GdkEventButton *); gint output_press (GdkEventButton *); - Gtk::Menu input_menu; + Gtk::Menu input_menu; + std::list > input_menu_bundles; void maybe_add_bundle_to_input_menu (boost::shared_ptr, ARDOUR::BundleList const &); Gtk::Menu output_menu; + 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); @@ -204,8 +217,8 @@ class MixerStrip : public RouteUI, public Gtk::EventBox 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 (); @@ -216,7 +229,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*); @@ -226,7 +239,7 @@ class MixerStrip : public RouteUI, public Gtk::EventBox 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; @@ -254,7 +267,14 @@ class MixerStrip : public RouteUI, public Gtk::EventBox 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); }; #endif /* __ardour_mixer_strip__ */