X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fmixer_strip.h;h=ef35bf237d9e49d4c2076d95bcd1151037e74372;hb=c78528dcea03a61685ad0586eaa6302847af6fe9;hp=c914d1240493c8763ab59c53968d8392bfc2ff26;hpb=8b46567e0677eb25c965ed46b80da8808fa33b2b;p=ardour.git diff --git a/gtk2_ardour/mixer_strip.h b/gtk2_ardour/mixer_strip.h index c914d12404..ef35bf237d 100644 --- a/gtk2_ardour/mixer_strip.h +++ b/gtk2_ardour/mixer_strip.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2000 Paul Davis + Copyright (C) 2000-2006 Paul Davis This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -14,8 +14,6 @@ You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - - $Id$ */ #ifndef __ardour_mixer_strip__ @@ -36,42 +34,32 @@ #include #include -#include -#include -#include +#include "gtkmm2ext/auto_spin.h" +#include "gtkmm2ext/click_box.h" +#include "gtkmm2ext/bindable_button.h" -#include +#include "pbd/stateful.h" -#include -#include -#include -#include -#include +#include "ardour/types.h" +#include "ardour/ardour.h" +#include "ardour/processor.h" -#include +#include "pbd/fastlog.h" #include "route_ui.h" -#include "io_selector.h" #include "gain_meter.h" #include "panner_ui.h" #include "enums.h" -#include "redirect_box.h" +#include "processor_box.h" #include "ardour_dialog.h" -class MotionController; - - -namespace Gtkmm2ext { - class SliderController; -} - namespace ARDOUR { class Route; class Send; - class Insert; + class Processor; class Session; class PortInsert; - class Connection; + class Bundle; class Plugin; } namespace Gtk { @@ -80,20 +68,54 @@ namespace Gtk { } class Mixer_UI; +class IOSelectorWindow; +class MotionController; +class RouteGroupMenu; class MixerStrip : public RouteUI, public Gtk::EventBox { public: - MixerStrip (Mixer_UI&, ARDOUR::Session&, ARDOUR::Route &, 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 (Width); - Width get_width() const { return _width; } + 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; } + PluginSelector* plugin_selector(); void fast_update (); void set_embedded (bool); - ARDOUR::RouteGroup* mix_group() const; + 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; + + /** 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; protected: friend class Mixer_UI; @@ -103,16 +125,29 @@ 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; + void init (); + bool _embedded; bool _packed; + bool _mixer_owned; Width _width; + void* _width_owner; Gtk::Button hide_button; Gtk::Button width_button; 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 (); @@ -120,21 +155,25 @@ class MixerStrip : public RouteUI, public Gtk::EventBox Gtk::Frame global_frame; Gtk::VBox global_vpacker; - RedirectBox pre_redirect_box; - RedirectBox post_redirect_box; + ProcessorBox processor_box; GainMeter gpm; - PannerUI panners; - + PannerUI panners; + Gtk::Table button_table; + Gtk::Table solo_led_table; + Gtk::HBox below_panner_box; Gtk::Table middle_button_table; Gtk::Table bottom_button_table; + Gtk::Label* _iso_label; + Gtk::Label* _safe_label; + Gtk::Button gain_unit_button; Gtk::Label gain_unit_label; 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; @@ -144,54 +183,53 @@ 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; Gtk::TextView* comment_area; - Gtk::Button comment_button; + void comment_editor_done_editing (); void setup_comment_editor (); - void comment_button_clicked (); + void toggle_comment (); Gtk::Button group_button; Gtk::Label group_label; - Gtk::Menu *group_menu; + RouteGroupMenu *group_menu; gint input_press (GdkEventButton *); gint output_press (GdkEventButton *); - Gtk::Menu input_menu; - void add_connection_to_input_menu (ARDOUR::Connection *); + 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; - void add_connection_to_output_menu (ARDOUR::Connection *); - - void stream_input_chosen (ARDOUR::AudioDiskstream*); - void select_stream_input (); - void connection_input_chosen (ARDOUR::Connection *); - void connection_output_chosen (ARDOUR::Connection *); + 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 diskstream_changed (void *src); + void diskstream_changed (); Gtk::Menu *send_action_menu; + Gtk::CheckMenuItem* _comment_menu_item; + 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 *); - - sigc::connection panstate_connection; - sigc::connection panstyle_connection; + PBD::ScopedConnection panstate_connection; + PBD::ScopedConnection panstyle_connection; void connect_to_pan (); void update_diskstream_display (); @@ -202,7 +240,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*); @@ -210,45 +248,45 @@ class MixerStrip : public RouteUI, public Gtk::EventBox void comment_edited (); bool ignore_comment_edit; - void set_mix_group (ARDOUR::RouteGroup *); - void add_mix_group_to_menu (ARDOUR::RouteGroup *, Gtk::RadioMenuItem::Group*); - bool select_mix_group (GdkEventButton *); - void mix_group_changed (void *); - + bool select_route_group (GdkEventButton *); + void route_group_changed (); IOSelectorWindow *input_selector; IOSelectorWindow *output_selector; Gtk::Style *passthru_style; - void route_gui_changed (string, void*); + void route_gui_changed (std::string, void*); void show_route_color (); void show_passthru_color (); - void route_active_changed (); - - /* speed control (for tracks only) */ - - Gtk::Adjustment speed_adjustment; - Gtkmm2ext::ClickBox speed_spinner; - Gtk::Label speed_label; - Gtk::Frame speed_frame; - - void speed_adjustment_changed (); - void speed_changed (); - void name_changed (void *src); + void name_changed (); void update_speed_display (); void map_frozen (); - void hide_redirect_editor (ARDOUR::Redirect* redirect); + void hide_processor_editor (boost::weak_ptr processor); + void hide_redirect_editors (); bool ignore_speed_adjustment; - string solo_button_name () const { return "MixerSoloButton"; } - string safe_solo_button_name () const { return "MixerSafeSoloButton"; } - void engine_running(); void engine_stopped(); + void switch_io (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 (ARDOUR::Port *, ARDOUR::Port *); + + static std::string meter_point_string (ARDOUR::MeterPoint); }; #endif /* __ardour_mixer_strip__ */