X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fplugin_ui.h;h=ad800e284dd7f9b3c5ca3f945027a340403ba16d;hb=caae0546a76eb8c41701b92ba52ac0c6f199d79e;hp=d2e5e21cca15f918d86fd0337ffbc7b9fc292f7d;hpb=ac008dac028cf86970c2b2604480beb87880e578;p=ardour.git diff --git a/gtk2_ardour/plugin_ui.h b/gtk2_ardour/plugin_ui.h index d2e5e21cca..ad800e284d 100644 --- a/gtk2_ardour/plugin_ui.h +++ b/gtk2_ardour/plugin_ui.h @@ -42,7 +42,6 @@ #include #include #include -#include #include #include "ardour/types.h" @@ -51,6 +50,7 @@ #include "ardour_button.h" #include "ardour_dropdown.h" +#include "ardour_spinner.h" #include "ardour_window.h" #include "automation_controller.h" @@ -79,6 +79,7 @@ namespace Gtkmm2ext { class LatencyGUI; class ArdourWindow; class PluginEqGui; +class VSTPluginUI; class PlugUIBase : public virtual sigc::trackable, public PBD::ScopedConnectionList { @@ -129,6 +130,8 @@ class PlugUIBase : public virtual sigc::trackable, public PBD::ScopedConnectionL ArdourButton reset_button; /** a button to bypass the plugin */ ArdourButton bypass_button; + /** and self-explaining button :) */ + ArdourButton pin_management_button; /** a button to acquire keyboard focus */ Gtk::EventBox focus_button; /** an expander containing the plugin description */ @@ -152,7 +155,6 @@ class PlugUIBase : public virtual sigc::trackable, public PBD::ScopedConnectionL ArdourWindow* latency_dialog; PluginEqGui* eqgui; - Gtk::Requisition pre_eq_size; Gtk::Image* focus_out_image; Gtk::Image* focus_in_image; @@ -163,6 +165,7 @@ class PlugUIBase : public virtual sigc::trackable, public PBD::ScopedConnectionL void save_plugin_setting (); void delete_plugin_setting (); void reset_plugin_parameters (); + void manage_pins (); bool focus_toggled(GdkEventButton*); bool bypass_button_release(GdkEventButton*); void toggle_description (); @@ -194,17 +197,8 @@ class GenericPluginUI : public PlugUIBase, public Gtk::VBox private: Gtk::VBox main_contents; - Gtk::HBox settings_box; Gtk::HBox hpacker; - - Gtk::Table button_table; - Gtk::Table output_table; - - Gtk::ScrolledWindow scroller; - Gtk::Adjustment hAdjustment; - Gtk::Adjustment vAdjustment; - Gtk::Viewport scroller_view; Gtk::Menu* automation_menu; gint prefheight; @@ -229,11 +223,6 @@ class GenericPluginUI : public PlugUIBase, public Gtk::VBox } }; - static const int32_t initial_button_rows = 12; - static const int32_t initial_button_cols = 1; - 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 { @@ -244,16 +233,19 @@ class GenericPluginUI : public PlugUIBase, public Gtk::VBox /* input */ - Gtk::ComboBoxText* combo; boost::shared_ptr scale_points; - Gtk::ToggleButton* button; boost::shared_ptr controller; - Gtkmm2ext::ClickBox* clickbox; + + ArdourButton automate_button; Gtk::Label label; - bool update_pending; - char ignore_change; - Gtk::Button automate_button; + ArdourDropdown* combo; + Gtkmm2ext::ClickBox* clickbox; Gtk::FileChooserButton* file_button; + ArdourSpinner* spin_box; + + bool button; + bool update_pending; + bool ignore_change; /* output */ @@ -266,43 +258,54 @@ class GenericPluginUI : public PlugUIBase, public Gtk::VBox ControlUI (const Evoral::Parameter& param); ~ControlUI (); + + /* layout */ + Gtk::Table* knobtable; + int x0, x1, y0, y1; }; - std::vector input_controls; + std::vector input_controls; // workaround for preset load std::vector input_controls_with_automation; std::vector output_controls; + sigc::connection screen_update_connection; + void output_update(); void build (); + void automatic_layout (const std::vector& control_uis); + void custom_layout (const std::vector& control_uis); + ControlUI* build_control_ui (const Evoral::Parameter& param, const ARDOUR::ParameterDescriptor& desc, boost::shared_ptr mcontrol, float value, - bool is_input); + bool is_input, + bool use_knob = false); 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 update_input_displays (); // workaround for preset load + void control_combo_changed (ControlUI* cui, float value); - void astate_clicked (ControlUI*); + bool astate_button_event (GdkEventButton* ev, ControlUI*); void automation_state_changed (ControlUI*); void set_automation_state (ARDOUR::AutoState state, ControlUI* cui); void set_all_automation (ARDOUR::AutoState state); + void knob_size_request(Gtk::Requisition* req, ControlUI* cui); + /* XXX: remove */ void print_parameter (char *buf, uint32_t len, uint32_t param); bool integer_printer (char* buf, Gtk::Adjustment &, ControlUI *); bool midinote_printer(char* buf, Gtk::Adjustment &, ControlUI *); - void set_property (const ARDOUR::ParameterDescriptor& desc, - Gtk::FileChooserButton* widget); - void property_changed (uint32_t key, const ARDOUR::Variant& value); + typedef std::map FilePathControls; + FilePathControls _filepath_controls; + void set_path_property (const ARDOUR::ParameterDescriptor& desc, + Gtk::FileChooserButton* widget); + void path_property_changed (uint32_t key, const ARDOUR::Variant& value); - typedef std::map PropertyControls; - PropertyControls _property_controls; }; class PluginUIWindow : public ArdourWindow @@ -345,10 +348,18 @@ class PluginUIWindow : public ArdourWindow bool create_windows_vst_editor (boost::shared_ptr); bool create_lxvst_editor(boost::shared_ptr); + bool create_mac_vst_editor(boost::shared_ptr); bool create_audiounit_editor (boost::shared_ptr); bool create_lv2_editor (boost::shared_ptr); }; +#ifdef MACVST_SUPPORT +/* this function has to be in a .mm file + * because MacVSTPluginUI has Cocoa members + */ +extern VSTPluginUI* create_mac_vst_gui (boost::shared_ptr); +#endif + #ifdef AUDIOUNIT_SUPPORT /* this function has to be in a .mm file */ extern PlugUIBase* create_au_gui (boost::shared_ptr, Gtk::VBox**);