X-Git-Url: https://git.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fplugin_ui.h;h=e65abbac59d33a8741988d6d1c441aa943f426c1;hb=49f28513f5f3f343ee9d51b0df25c7bd78478542;hp=17d643f2a1e3e0abae47cb831fe8724044b8c1ab;hpb=2177f008411821e7bce9ca3c306ec64c70b1c58e;p=ardour.git diff --git a/gtk2_ardour/plugin_ui.h b/gtk2_ardour/plugin_ui.h index 17d643f2a1..e65abbac59 100644 --- a/gtk2_ardour/plugin_ui.h +++ b/gtk2_ardour/plugin_ui.h @@ -34,15 +34,15 @@ #include #include #include +#include +#include #include #include #include #include -#include -#include +#include "ardour/types.h" -#include "latency_gui.h" #include "automation_controller.h" namespace ARDOUR { @@ -65,41 +65,71 @@ namespace Gtkmm2ext { class PixmapButton; } +class LatencyGUI; +class ArdourDialog; + class PlugUIBase : public virtual sigc::trackable { public: - PlugUIBase (boost::shared_ptr, nframes64_t sample_rate, nframes64_t period_size); - virtual ~PlugUIBase() {} + PlugUIBase (boost::shared_ptr); + 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; - LatencyGUI latency_gui; + 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, nframes64_t sample_rate, nframes64_t period_size, 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; @@ -144,7 +174,7 @@ class LadspaPluginUI : public PlugUIBase, public Gtk::VBox boost::shared_ptr control; - ARDOUR::Parameter parameter() { return control->parameter(); } + Evoral::Parameter parameter() { return control->parameter(); } /* input */ @@ -180,6 +210,7 @@ class LadspaPluginUI : public PlugUIBase, public Gtk::VBox ControlUI* build_control_ui (guint32 port_index, boost::shared_ptr); std::vector setup_scale_values(guint32 port_index, 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); @@ -195,32 +226,52 @@ 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, nframes64_t sample_rate, nframes64_t period_size, 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 class VSTPluginUI : public PlugUIBase, public Gtk::VBox { public: - VSTPluginUI (boost::shared_ptr, boost::shared_ptr, nframes64_t sample_rate, nframes64_t period_size); + VSTPluginUI (boost::shared_ptr, boost::shared_ptr); ~VSTPluginUI (); gint get_preferred_height (); + gint get_preferred_width (); bool start_updating(GdkEventAny*) {return false;} bool stop_updating(GdkEventAny*) {return false;} @@ -237,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__ */