X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fplugin_ui.h;h=e65abbac59d33a8741988d6d1c441aa943f426c1;hb=49f28513f5f3f343ee9d51b0df25c7bd78478542;hp=c1d538b3d13e56ae9a4f6cd8015f4103a0a33589;hpb=82232f06ba3eea4a2b4342ad91fab552f4044402;p=ardour.git diff --git a/gtk2_ardour/plugin_ui.h b/gtk2_ardour/plugin_ui.h index c1d538b3d1..e65abbac59 100644 --- a/gtk2_ardour/plugin_ui.h +++ b/gtk2_ardour/plugin_ui.h @@ -15,7 +15,6 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id$ */ #ifndef __ardour_plugin_ui_h__ @@ -35,20 +34,22 @@ #include #include #include +#include #include #include #include #include #include -#include -#include +#include "ardour/types.h" + +#include "automation_controller.h" namespace ARDOUR { class PluginInsert; class Plugin; class VSTPlugin; - class Redirect; + class IOProcessor; class AUPlugin; } @@ -64,40 +65,71 @@ namespace Gtkmm2ext { class PixmapButton; } +class LatencyGUI; +class ArdourDialog; + class PlugUIBase : public virtual sigc::trackable { public: PlugUIBase (boost::shared_ptr); - virtual ~PlugUIBase() {} + virtual ~PlugUIBase(); virtual gint get_preferred_height () = 0; + virtual gint get_preferred_width () = 0; virtual bool start_updating(GdkEventAny*) = 0; virtual bool stop_updating(GdkEventAny*) = 0; + + virtual void activate () {} + virtual void deactivate () {} + + virtual void update_presets (); + + void latency_button_clicked (); protected: boost::shared_ptr insert; boost::shared_ptr plugin; - Gtk::ComboBoxText combo; + Gtk::ComboBoxText preset_combo; Gtk::Button save_button; Gtk::ToggleButton bypass_button; + Gtk::EventBox focus_button; + + Gtk::Label latency_label; + Gtk::Button latency_button; + void set_latency_label (); + + LatencyGUI* latency_gui; + ArdourDialog* latency_dialog; + + Gtk::Expander plugin_eq_bin; + Gtk::ToggleButton eqgui_toggle; + + Gtk::Image* focus_out_image; + Gtk::Image* focus_in_image; void setting_selected(); void save_plugin_setting (void); + bool focus_toggled(GdkEventButton*); void bypass_toggled(); + void toggle_plugin_analysis (); + void processor_active_changed (boost::weak_ptr p); }; -class LadspaPluginUI : public PlugUIBase, public Gtk::VBox +class GenericPluginUI : public PlugUIBase, public Gtk::HPaned { public: - LadspaPluginUI (boost::shared_ptr plug, bool scrollable=false); - ~LadspaPluginUI (); + GenericPluginUI (boost::shared_ptr plug, bool scrollable=false); + ~GenericPluginUI (); gint get_preferred_height () { return prefheight; } - + gint get_preferred_width () { return -1; } + bool start_updating(GdkEventAny*); bool stop_updating(GdkEventAny*); private: + Gtk::VBox main_contents; + Gtk::HBox settings_box; Gtk::HBox hpacker; @@ -137,17 +169,19 @@ class LadspaPluginUI : public PlugUIBase, public Gtk::VBox static const int32_t initial_output_rows = 1; static const int32_t initial_output_cols = 4; + /* FIXME: Unify with AutomationController */ struct ControlUI : public Gtk::HBox { - uint32_t port_index; + boost::shared_ptr control; + + Evoral::Parameter parameter() { return control->parameter(); } /* input */ - Gtk::Adjustment* adjustment; Gtk::ComboBoxText* combo; std::map* combo_map; Gtk::ToggleButton* button; - Gtkmm2ext::BarController* control; + boost::shared_ptr controller; Gtkmm2ext::ClickBox* clickbox; Gtk::Label label; bool logarithmic; @@ -173,15 +207,15 @@ class LadspaPluginUI : public PlugUIBase, public Gtk::VBox void output_update(); void build (); - ControlUI* build_control_ui (guint32 port_index, PBD::Controllable *); + ControlUI* build_control_ui (guint32 port_index, boost::shared_ptr); std::vector setup_scale_values(guint32 port_index, ControlUI* cui); - void control_adjustment_changed (ControlUI* cui); - void parameter_changed (uint32_t, float, ControlUI* cui); + void parameter_changed (ControlUI* cui); + void toggle_parameter_changed (ControlUI* cui); void update_control_display (ControlUI* cui); void control_port_toggled (ControlUI* cui); void control_combo_changed (ControlUI* cui); - void redirect_active_changed (ARDOUR::Redirect*, void*); + void processor_active_changed (boost::weak_ptr); void astate_clicked (ControlUI*, uint32_t parameter); void automation_state_changed (ControlUI*); @@ -192,22 +226,41 @@ class LadspaPluginUI : public PlugUIBase, public Gtk::VBox void print_parameter (char *buf, uint32_t len, uint32_t param); }; -class PluginUIWindow : public ArdourDialog +class PluginUIWindow : public Gtk::Window { public: - PluginUIWindow (boost::shared_ptr insert, bool scrollable=false); + PluginUIWindow (Gtk::Window*, boost::shared_ptr insert, bool scrollable=false); ~PluginUIWindow (); PlugUIBase& pluginui() { return *_pluginui; } void resize_preferred(); + void set_parent (Gtk::Window*); + + bool on_enter_notify_event (GdkEventCrossing*); + bool on_leave_notify_event (GdkEventCrossing*); + bool on_focus_in_event (GdkEventFocus*); + bool on_focus_out_event (GdkEventFocus*); + bool on_key_press_event (GdkEventKey*); + bool on_key_release_event (GdkEventKey*); + void on_show (); + void on_hide (); + void on_map (); - virtual bool on_key_press_event (GdkEventKey*); - virtual bool on_key_release_event (GdkEventKey*); - private: PlugUIBase* _pluginui; + sigc::connection death_connection; + Gtk::Window* parent; + Gtk::VBox vbox; + bool non_gtk_gui; + bool was_visible; + + void app_activated (bool); void plugin_going_away (); + + bool create_vst_editor (boost::shared_ptr); + bool create_audiounit_editor (boost::shared_ptr); + bool create_lv2_editor (boost::shared_ptr); }; #ifdef VST_SUPPORT @@ -218,6 +271,7 @@ class VSTPluginUI : public PlugUIBase, public Gtk::VBox ~VSTPluginUI (); gint get_preferred_height (); + gint get_preferred_width (); bool start_updating(GdkEventAny*) {return false;} bool stop_updating(GdkEventAny*) {return false;} @@ -234,4 +288,9 @@ class VSTPluginUI : public PlugUIBase, public Gtk::VBox }; #endif // VST_SUPPORT +#ifdef HAVE_AUDIOUNITS +/* this function has to be in a .mm file */ +extern PlugUIBase* create_au_gui (boost::shared_ptr, Gtk::VBox**); +#endif + #endif /* __ardour_plugin_ui_h__ */