X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Froute_ui.h;h=7e4dd2e9688bc4669ea9a6e440461552351936de;hb=63a71c597af9e24feaa4090ae37a56c584c25095;hp=0501c78937406c80721aadc299c37de2cedb716c;hpb=9bf55b26e808c6f1f13068e43bf17fcc60b44561;p=ardour.git diff --git a/gtk2_ardour/route_ui.h b/gtk2_ardour/route_ui.h index 0501c78937..7e4dd2e968 100644 --- a/gtk2_ardour/route_ui.h +++ b/gtk2_ardour/route_ui.h @@ -25,18 +25,24 @@ #include "pbd/xml++.h" #include "pbd/signals.h" +#include +#include + #include "gtkmm2ext/widget_state.h" #include "ardour/ardour.h" #include "ardour/mute_master.h" -#include "ardour/session_event.h" #include "ardour/session.h" +#include "ardour/session_event.h" +#include "ardour/session_handle.h" #include "ardour/route.h" #include "ardour/route_group.h" #include "ardour/track.h" #include "axis_view.h" #include "selectable.h" +#include "stripable_colorpicker.h" +#include "window_manager.h" namespace ARDOUR { class AudioTrack; @@ -49,18 +55,35 @@ namespace Gtk { class Widget; } -class BindableToggleButton; class ArdourButton; +class ArdourWindow; +class IOSelectorWindow; +class ControlSlaveUI; + +class RoutePinWindowProxy : public WM::ProxyBase +{ + public: + RoutePinWindowProxy (std::string const &, boost::shared_ptr); + ~RoutePinWindowProxy(); + + Gtk::Window* get (bool create = false); + ARDOUR::SessionHandlePtr* session_handle(); + + private: + boost::weak_ptr _route; + + void route_going_away (); + PBD::ScopedConnection going_away_connection; +}; -class RouteUI : public virtual AxisView +class RouteUI : public virtual Selectable, public virtual ARDOUR::SessionHandlePtr, public virtual PBD::ScopedConnectionList, public virtual sigc::trackable { public: - RouteUI(ARDOUR::Session*); - RouteUI(boost::shared_ptr, ARDOUR::Session*); + RouteUI (ARDOUR::Session*); virtual ~RouteUI(); - Gdk::Color color () const; + boost::shared_ptr stripable() const; virtual void set_route (boost::shared_ptr); virtual void set_button_names () = 0; @@ -77,15 +100,14 @@ class RouteUI : public virtual AxisView boost::shared_ptr audio_track() const; boost::shared_ptr midi_track() const; - std::string name() const; - // protected: XXX sigh this should be here boost::shared_ptr _route; void request_redraw (); - virtual void set_color (const Gdk::Color & c); + virtual void set_color (uint32_t c); + Gdk::Color route_color () const; void choose_color (); bool ignore_toggle; @@ -103,8 +125,9 @@ class RouteUI : public virtual AxisView Glib::RefPtr solo_safe_pixbuf; - ArdourButton* solo_safe_led; - ArdourButton* solo_isolated_led; + ArdourButton* solo_safe_led; + ArdourButton* solo_isolated_led; + Gtk::Label monitor_input_button_label; Gtk::Label monitor_disk_button_label; @@ -112,10 +135,14 @@ class RouteUI : public virtual AxisView void send_blink (bool); sigc::connection send_blink_connection; + sigc::connection rec_blink_connection; + Gtk::Menu* mute_menu; Gtk::Menu* solo_menu; Gtk::Menu* sends_menu; + boost::shared_ptr _current_delivery; + bool mute_press(GdkEventButton*); bool mute_release(GdkEventButton*); bool solo_press(GdkEventButton*); @@ -130,9 +157,11 @@ class RouteUI : public virtual AxisView bool monitor_input_release(GdkEventButton*); bool monitor_disk_press(GdkEventButton*); bool monitor_disk_release(GdkEventButton*); - void monitoring_changed (); void update_monitoring_display (); + void edit_input_configuration (); + void edit_output_configuration (); + void step_gain_up (); void step_gain_down (); void page_gain_up (); @@ -147,7 +176,6 @@ class RouteUI : public virtual AxisView void solo_changed(bool, void*); void solo_changed_so_update_mute (); - void mute_changed(void*); void listen_changed(void*); virtual void processors_changed (ARDOUR::RouteProcessorChange) {} void route_rec_enable_changed(); @@ -158,8 +186,8 @@ class RouteUI : public virtual AxisView void solo_isolated_toggle (void*, Gtk::CheckMenuItem*); void toggle_solo_isolated (Gtk::CheckMenuItem*); - bool solo_isolate_button_release (GdkEventButton*); - bool solo_safe_button_release (GdkEventButton*); + bool solo_isolate_button_release (GdkEventButton*); + bool solo_safe_button_release (GdkEventButton*); void solo_safe_toggle (void*, Gtk::CheckMenuItem*); void toggle_solo_safe (Gtk::CheckMenuItem*); @@ -178,24 +206,29 @@ class RouteUI : public virtual AxisView int set_color_from_route (); - void remove_this_route (bool apply_to_selection = false); - static gint idle_remove_this_route (RouteUI *); - void route_rename(); - virtual void property_changed (const PBD::PropertyChange&); + void manage_pins (); + void maybe_add_route_print_mgr (); + void fan_out (bool to_busses = true, bool group = true); + + virtual void route_property_changed (const PBD::PropertyChange&) = 0; void route_removed (); virtual void route_active_changed () {} void set_route_active (bool, bool); + void duplicate_selected_routes (); - Gtk::Menu* record_menu; - void build_record_menu (); + Gtk::Menu* record_menu; + void build_record_menu (); Gtk::CheckMenuItem *step_edit_item; void toggle_step_edit (); virtual void step_edit_changed (bool); + Gtk::CheckMenuItem *rec_safe_item; + void toggle_rec_safe (); + virtual void polarity_changed (); Gtk::CheckMenuItem *denormal_menu_item; @@ -205,7 +238,7 @@ class RouteUI : public virtual AxisView void disconnect_input (); void disconnect_output (); - virtual void update_rec_display (); + virtual void blink_rec_display (bool onoff); void update_mute_display (); void update_solo_display (); @@ -213,46 +246,69 @@ class RouteUI : public virtual AxisView virtual void map_frozen (); void adjust_latency (); + bool process_save_template_prompter (ArdourPrompter& prompter, const std::string& dir); void save_as_template (); - void open_remote_control_id_dialog (); - static Gtkmm2ext::ActiveState solo_active_state (boost::shared_ptr); - static Gtkmm2ext::ActiveState solo_isolate_active_state (boost::shared_ptr); - static Gtkmm2ext::ActiveState solo_safe_active_state (boost::shared_ptr); - static Gtkmm2ext::ActiveState mute_active_state (ARDOUR::Session*, boost::shared_ptr); + static Gtkmm2ext::ActiveState solo_active_state (boost::shared_ptr); + static Gtkmm2ext::ActiveState solo_isolate_active_state (boost::shared_ptr); + static Gtkmm2ext::ActiveState solo_safe_active_state (boost::shared_ptr); + static Gtkmm2ext::ActiveState mute_active_state (ARDOUR::Session*, boost::shared_ptr); /** Emitted when a bus has been set or unset from `display sends to this bus' mode * by a click on the `Sends' button. The parameter is the route that the sends are * to, or 0 if no route is now in this mode. */ - static sigc::signal > BusSendDisplayChanged; + static PBD::Signal1 > BusSendDisplayChanged; + + void comment_editor_done_editing (); + void setup_comment_editor (); + void open_comment_editor (); + void toggle_comment_editor (); + + gint comment_key_release_handler (GdkEventKey*); + void comment_changed (); + void comment_edited (); + bool ignore_comment_edit; protected: + + ArdourWindow* comment_window; + Gtk::TextView* comment_area; + IOSelectorWindow *input_selector; + IOSelectorWindow *output_selector; + PBD::ScopedConnectionList route_connections; bool self_destruct; - void init (); - void reset (); + void init (); + void reset (); void self_delete (); - virtual void start_step_editing () {} - virtual void stop_step_editing() {} + virtual void start_step_editing () {} + virtual void stop_step_editing() {} - void set_invert_sensitive (bool); + void set_invert_sensitive (bool); bool verify_new_route_name (const std::string& name); - void route_gui_changed (std::string); + void route_gui_changed (PBD::PropertyChange const&); virtual void route_color_changed () {} + void check_rec_enable_sensitivity (); + virtual void bus_send_display_changed (boost::shared_ptr); + static std::string program_port_prefix; + + bool mark_hidden (bool yn); + private: - void check_rec_enable_sensitivity (); - void parameter_changed (std::string const &); + void parameter_changed (std::string const&); void relabel_solo_button (); + void track_mode_changed (); std::string route_state_id () const; + protected: struct SoloMuteRelease { SoloMuteRelease (bool was_active) : active (was_active) @@ -269,6 +325,9 @@ class RouteUI : public virtual AxisView SoloMuteRelease* _solo_release; SoloMuteRelease* _mute_release; + ControlSlaveUI* csu; + +private: void setup_invert_buttons (); void set_invert_button_state (); void invert_menu_toggled (uint32_t); @@ -279,9 +338,11 @@ class RouteUI : public virtual AxisView std::vector _invert_buttons; Gtk::Menu* _invert_menu; + StripableColorDialog _color_picker; + static void set_showing_sends_to (boost::shared_ptr); static boost::weak_ptr _showing_sends_to; - + static uint32_t _max_invert_buttons; };