X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fplugin_ui.h;h=6b886cf268a259778f420bba891fb627311da3a2;hb=5932b7903a7c43cc3b5cfd043e64d577e0125799;hp=e1d9cfafce008cbe8de5839068728f366fc1f2f8;hpb=3a1af63fedc4792a3c98de446d031bfe27e9202d;p=ardour.git diff --git a/gtk2_ardour/plugin_ui.h b/gtk2_ardour/plugin_ui.h index e1d9cfafce..6b886cf268 100644 --- a/gtk2_ardour/plugin_ui.h +++ b/gtk2_ardour/plugin_ui.h @@ -46,15 +46,19 @@ #include #include "ardour/types.h" +#include "ardour/plugin.h" #include "automation_controller.h" +#include "ardour_button.h" namespace ARDOUR { class PluginInsert; class Plugin; - class VSTPlugin; + class WindowsVSTPlugin; + class LXVSTPlugin; class IOProcessor; class AUPlugin; + class Processor; } namespace PBD { @@ -70,9 +74,10 @@ namespace Gtkmm2ext { } class LatencyGUI; -class ArdourDialog; +class ArdourWindow; +class PluginEqGui; -class PlugUIBase : public virtual sigc::trackable +class PlugUIBase : public virtual sigc::trackable, public PBD::ScopedConnectionList { public: PlugUIBase (boost::shared_ptr); @@ -80,13 +85,15 @@ class PlugUIBase : public virtual sigc::trackable virtual gint get_preferred_height () = 0; virtual gint get_preferred_width () = 0; + virtual bool resizable () { return true; } virtual bool start_updating(GdkEventAny*) = 0; virtual bool stop_updating(GdkEventAny*) = 0; virtual void activate () {} virtual void deactivate () {} - virtual void update_presets (); + void update_preset_list (); + void update_preset (); void latency_button_clicked (); @@ -101,36 +108,57 @@ class PlugUIBase : public virtual sigc::trackable protected: boost::shared_ptr insert; boost::shared_ptr plugin; - Gtk::ComboBoxText preset_combo; + + /* UI elements that can subclasses can add to their widgets */ + + /** a ComboBoxText which lists presets and manages their selection */ + Gtk::ComboBoxText _preset_combo; + /** a label which has a * in if the current settings are different from the preset being shown */ + Gtk::Label _preset_modified; + /** a button to add a preset */ Gtk::Button add_button; + /** a button to save the current settings as a new user preset */ Gtk::Button save_button; + /** a button to delete the current preset (if it is a user one) */ Gtk::Button delete_button; - Gtk::ToggleButton bypass_button; + /** a button to bypass the plugin */ + ArdourButton bypass_button; + /** a button to acquire keyboard focus */ Gtk::EventBox focus_button; - + /** an expander containing the plugin description */ + Gtk::Expander description_expander; + /** an expander containing the plugin analysis graph */ + Gtk::Expander plugin_analysis_expander; + /** a label indicating the plugin latency */ Gtk::Label latency_label; + /** a button which, when clicked, opens the latency GUI */ Gtk::Button latency_button; + void set_latency_label (); LatencyGUI* latency_gui; - ArdourDialog* latency_dialog; + ArdourWindow* latency_dialog; - Gtk::Expander plugin_analysis_expander; + PluginEqGui* eqgui; + Gtk::Requisition pre_eq_size; Gtk::Image* focus_out_image; Gtk::Image* focus_in_image; - bool no_load_preset; + int _no_load_preset; - void setting_selected(); + virtual void preset_selected (); void add_plugin_setting (); void save_plugin_setting (); void delete_plugin_setting (); bool focus_toggled(GdkEventButton*); - void bypass_toggled(); + bool bypass_button_release(GdkEventButton*); + void toggle_description (); void toggle_plugin_analysis (); void processor_active_changed (boost::weak_ptr p); void plugin_going_away (); - void update_sensitivity (); + virtual void parameter_changed (uint32_t, float); + void preset_added_or_removed (); + void update_preset_modified (); PBD::ScopedConnection death_connection; PBD::ScopedConnection active_connection; @@ -196,34 +224,34 @@ class GenericPluginUI : public PlugUIBase, public Gtk::VBox /* FIXME: Unify with AutomationController */ struct ControlUI : public Gtk::HBox { + uint32_t port_index; boost::shared_ptr control; Evoral::Parameter parameter() { return control->parameter(); } - /* input */ + /* input */ - Gtk::ComboBoxText* combo; - std::map* combo_map; - Gtk::ToggleButton* button; - boost::shared_ptr controller; - Gtkmm2ext::ClickBox* clickbox; - Gtk::Label label; - bool logarithmic; - bool update_pending; - char ignore_change; - Gtk::Button automate_button; + Gtk::ComboBoxText* combo; + boost::shared_ptr scale_points; + Gtk::ToggleButton* button; + boost::shared_ptr controller; + Gtkmm2ext::ClickBox* clickbox; + Gtk::Label label; + bool update_pending; + char ignore_change; + Gtk::Button automate_button; - /* output */ + /* output */ - Gtk::EventBox *display; - Gtk::Label* display_label; + Gtk::EventBox* display; + Gtk::Label* display_label; - Gtk::HBox * hbox; - Gtk::VBox * vbox; - MeterInfo * meterinfo; + Gtk::HBox* hbox; + Gtk::VBox* vbox; + MeterInfo* meterinfo; - ControlUI (); - ~ControlUI(); + ControlUI (); + ~ControlUI (); }; std::vector input_controls; @@ -233,28 +261,30 @@ 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); - void parameter_changed (ControlUI* cui); + void ui_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 processor_active_changed (boost::weak_ptr); - void astate_clicked (ControlUI*, uint32_t parameter); void automation_state_changed (ControlUI*); void set_automation_state (ARDOUR::AutoState state, ControlUI* cui); void start_touch (ControlUI*); void stop_touch (ControlUI*); + /* XXX: remove */ void print_parameter (char *buf, uint32_t len, uint32_t param); + bool integer_printer (char* buf, Gtk::Adjustment &, ControlUI *); }; class PluginUIWindow : public Gtk::Window { public: - PluginUIWindow (Gtk::Window*, boost::shared_ptr insert, bool scrollable=false); + PluginUIWindow (Gtk::Window*, + boost::shared_ptr insert, + bool scrollable=false, + bool editor=true); ~PluginUIWindow (); PlugUIBase& pluginui() { return *_pluginui; } @@ -282,57 +312,23 @@ class PluginUIWindow : public Gtk::Window Gtk::VBox vbox; bool was_visible; bool _keyboard_focused; +#ifdef AUDIOUNIT_SUPPORT + int pre_deactivate_x; + int pre_deactivate_y; +#endif + void keyboard_focused (bool yn); void app_activated (bool); void plugin_going_away (); - bool create_vst_editor (boost::shared_ptr); + bool create_windows_vst_editor (boost::shared_ptr); + bool create_lxvst_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); - ~VSTPluginUI (); - - gint get_preferred_height (); - gint get_preferred_width (); - bool start_updating(GdkEventAny*) {return false;} - bool stop_updating(GdkEventAny*) {return false;} - - int package (Gtk::Window&); - - private: - boost::shared_ptr vst; - Gtk::Socket socket; - Gtk::HBox preset_box; - Gtk::VBox vpacker; - Gtk::ComboBox vst_preset_combo; - Glib::RefPtr preset_model; - - struct PresetModelColumns : public Gtk::TreeModel::ColumnRecord { - PresetModelColumns() { - add (name); - add (number); - } - Gtk::TreeModelColumn name; - Gtk::TreeModelColumn number; - }; - - PresetModelColumns preset_columns; - - bool configure_handler (GdkEventConfigure*, Gtk::Socket*); - void save_plugin_setting (); - void preset_chosen (); - void update_presets (); -}; -#endif // VST_SUPPORT - -#ifdef AUDIOUNITS +#ifdef AUDIOUNIT_SUPPORT /* this function has to be in a .mm file */ extern PlugUIBase* create_au_gui (boost::shared_ptr, Gtk::VBox**); #endif