X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fplugin_ui.h;h=ab30858eaf12f4481d2c39097f2890bf5d438695;hb=3162ffb4f418d85088d53d5e0a4a5d6ce7235e04;hp=72cfc465e6c5e0fd5237376d275f063d74a72362;hpb=8aa9508c82f32efcf9c7c00e2c9e76268d4dddce;p=ardour.git diff --git a/gtk2_ardour/plugin_ui.h b/gtk2_ardour/plugin_ui.h index 72cfc465e6..ab30858eaf 100644 --- a/gtk2_ardour/plugin_ui.h +++ b/gtk2_ardour/plugin_ui.h @@ -20,6 +20,10 @@ #ifndef __ardour_plugin_ui_h__ #define __ardour_plugin_ui_h__ +#ifdef WAF_BUILD +#include "gtk2ardour-config.h" +#endif + #include #include #include @@ -34,15 +38,15 @@ #include #include #include +#include +#include #include #include #include #include -#include +#include "ardour/types.h" -#include "ardour_dialog.h" -#include "latency_gui.h" #include "automation_controller.h" namespace ARDOUR { @@ -65,11 +69,14 @@ 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; @@ -79,21 +86,40 @@ class PlugUIBase : public virtual sigc::trackable 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 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_analysis_expander; + + 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); + void plugin_going_away (); }; -class GenericPluginUI : public PlugUIBase, public Gtk::VBox +class GenericPluginUI : public PlugUIBase, public Gtk::VBox { public: GenericPluginUI (boost::shared_ptr plug, bool scrollable=false); @@ -106,6 +132,8 @@ class GenericPluginUI : public PlugUIBase, public Gtk::VBox bool stop_updating(GdkEventAny*); private: + Gtk::VBox main_contents; + Gtk::HBox settings_box; Gtk::HBox hpacker; @@ -130,7 +158,7 @@ class GenericPluginUI : public PlugUIBase, public Gtk::VBox bool max_unbound; bool packed; - MeterInfo(int i) { + MeterInfo (int /*i*/) { meter = 0; packed = false; min = 1.0e10; @@ -150,14 +178,14 @@ class GenericPluginUI : public PlugUIBase, public Gtk::VBox boost::shared_ptr control; - ARDOUR::Parameter parameter() { return control->parameter(); } + Evoral::Parameter parameter() { return control->parameter(); } /* input */ Gtk::ComboBoxText* combo; - std::map* combo_map; + std::map* combo_map; Gtk::ToggleButton* button; - boost::shared_ptr controller; + boost::shared_ptr controller; Gtkmm2ext::ClickBox* clickbox; Gtk::Label label; bool logarithmic; @@ -184,8 +212,9 @@ class GenericPluginUI : public PlugUIBase, public Gtk::VBox void build (); ControlUI* build_control_ui (guint32 port_index, boost::shared_ptr); - std::vector setup_scale_values(guint32 port_index, ControlUI* cui); + 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); @@ -204,34 +233,45 @@ class GenericPluginUI : public PlugUIBase, public Gtk::VBox 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 (); 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 ();