X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fplugin_pin_dialog.h;h=c652af8a33511f7ea886a8f5493f1b0a3fffbce6;hb=6b1b72a247bf04c81292fc41af4f69c9b7f90379;hp=d2fa327b70d02d79a6a2ec31cc98004df43b4624;hpb=5242aeb871d173c80e0ecde567831c7afcbf0fac;p=ardour.git diff --git a/gtk2_ardour/plugin_pin_dialog.h b/gtk2_ardour/plugin_pin_dialog.h index d2fa327b70..c652af8a33 100644 --- a/gtk2_ardour/plugin_pin_dialog.h +++ b/gtk2_ardour/plugin_pin_dialog.h @@ -27,17 +27,28 @@ #include "ardour/plugin_insert.h" #include "ardour/route.h" -#include "ardour_button.h" -#include "ardour_dropdown.h" +#include +#include +#include +#include +#include + +#include "gtkmm2ext/persistent_tooltip.h" + +#include "widgets/ardour_button.h" +#include "widgets/ardour_dropdown.h" +#include "widgets/ardour_fader.h" +#include "widgets/slider_controller.h" + #include "ardour_window.h" #include "io_selector.h" -class PluginPinDialog : public ArdourWindow +class PluginPinWidget : public ARDOUR::SessionHandlePtr, public Gtk::VBox { public: - PluginPinDialog (boost::shared_ptr); - ~PluginPinDialog (); - + PluginPinWidget (boost::shared_ptr); + ~PluginPinWidget (); + void set_session (ARDOUR::Session *); private: typedef enum { Input, @@ -79,20 +90,32 @@ private: CtrlElemList _elements; CtrlElem _drag_dst; + /* cache settings for expose */ + typedef std::map Mappings; + Mappings _in_map; + Mappings _out_map; + ARDOUR::ChanMapping _thru_map; + bool _has_midi_bypass; + Gtk::DrawingArea darea; - ArdourButton _set_config; - ArdourButton _tgl_sidechain; - ArdourButton _add_plugin; - ArdourButton _del_plugin; - ArdourButton _add_output_audio; - ArdourButton _del_output_audio; - ArdourButton _add_output_midi; - ArdourButton _del_output_midi; - ArdourButton _add_sc_audio; - ArdourButton _add_sc_midi; - - ArdourDropdown _out_presets; + + ArdourWidgets::ArdourButton _set_config; + ArdourWidgets::ArdourButton _tgl_sidechain; + ArdourWidgets::ArdourButton _add_plugin; + ArdourWidgets::ArdourButton _del_plugin; + ArdourWidgets::ArdourButton _add_input_audio; + ArdourWidgets::ArdourButton _del_input_audio; + ArdourWidgets::ArdourButton _add_input_midi; + ArdourWidgets::ArdourButton _del_input_midi; + ArdourWidgets::ArdourButton _add_output_audio; + ArdourWidgets::ArdourButton _del_output_audio; + ArdourWidgets::ArdourButton _add_output_midi; + ArdourWidgets::ArdourButton _del_output_midi; + ArdourWidgets::ArdourButton _add_sc_audio; + ArdourWidgets::ArdourButton _add_sc_midi; + + ArdourWidgets::ArdourDropdown _out_presets; Gtk::Menu reset_menu; Gtk::Menu input_menu; @@ -122,7 +145,9 @@ private: void draw_connection (cairo_t*, double, double, double, double, bool, bool, bool dashed = false); void draw_connection (cairo_t*, const CtrlWidget&, const CtrlWidget&, bool dashed = false); const CtrlWidget& get_io_ctrl (CtrlType ct, ARDOUR::DataType dt, uint32_t id, uint32_t ip = 0) const; + static void edge_coordinates (const CtrlWidget& w, double &x, double &y); + static std::string port_label (const std::string&, bool); void reset_mapping (); void reset_configuration (); @@ -130,6 +155,7 @@ private: void connect_sidechain (); void add_remove_plugin_clicked (bool); void add_remove_port_clicked (bool, ARDOUR::DataType); + void add_remove_inpin_clicked (bool, ARDOUR::DataType); void add_sidechain_port (ARDOUR::DataType); void select_output_preset (uint32_t n_audio); void handle_input_action (const CtrlElem &, const CtrlElem &); @@ -138,10 +164,11 @@ private: bool handle_disconnect (const CtrlElem &, bool no_signal = false); void disconnect_other_outputs (uint32_t skip_pc, ARDOUR::DataType dt, uint32_t id); void disconnect_other_thru (ARDOUR::DataType dt, uint32_t id); - void add_port_to_table (boost::shared_ptr, uint32_t, bool); void remove_port (boost::weak_ptr); void disconnect_port (boost::weak_ptr); void connect_port (boost::weak_ptr, boost::weak_ptr); + void add_send_from (boost::weak_ptr, boost::weak_ptr); + uint32_t add_port_to_table (boost::shared_ptr, uint32_t, bool); uint32_t maybe_add_route_to_input_menu (boost::shared_ptr, ARDOUR::DataType, boost::weak_ptr); void port_connected_or_disconnected (boost::weak_ptr, boost::weak_ptr); @@ -152,6 +179,11 @@ private: PBD::ScopedConnection _io_connection; boost::shared_ptr _pi; + void queue_idle_update (); + bool idle_update (); + + void error_message_dialog (std::string const&) const; + uint32_t _n_plugins; ARDOUR::ChanCount _in, _ins, _out; ARDOUR::ChanCount _sinks, _sources; @@ -172,6 +204,51 @@ private: bool _dragging; double _drag_x, _drag_y; + class Control: public sigc::trackable { + public: + Control (boost::shared_ptr, std::string const &); + ~Control (); + Gtk::Alignment box; + private: + void slider_adjusted (); + void control_changed (); + void set_tooltip (); + + boost::weak_ptr _control; + Gtk::Adjustment _adjustment; + ArdourWidgets::HSliderController _slider; + Gtkmm2ext::PersistentTooltip _slider_persistant_tooltip; + + bool _ignore_ui_adjustment; + sigc::connection timer_connection; + std::string _name; + }; + std::list _controls; +}; + + +class PluginPinDialog : public ArdourWindow +{ +public: + PluginPinDialog (boost::shared_ptr); + PluginPinDialog (boost::shared_ptr); + + void set_session (ARDOUR::Session *); +private: + Gtk::ScrolledWindow* scroller; + Gtk::VBox *vbox; + typedef boost::shared_ptr PluginPinWidgetPtr; + typedef std::vector PluginPinWidgetList; + + void route_going_away (); + void route_processors_changed (ARDOUR::RouteProcessorChange); + void add_processor (boost::weak_ptr); + void map_height (Gtk::Allocation&); + + boost::shared_ptr _route; + PluginPinWidgetList ppw; + PBD::ScopedConnectionList _route_connections; + bool _height_mapped; }; #endif