X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fvst_plugin_ui.cc;h=532fcf672201b17edf859f2dfd2fcb9011d889fc;hb=54fd56de755a44420d906ad660b18c2d671f1057;hp=be8eae3240269a052241b3642e408fa4436b6a3f;hpb=40aa7e5e9034321f8af0b3067bd5f3005c537d5d;p=ardour.git diff --git a/gtk2_ardour/vst_plugin_ui.cc b/gtk2_ardour/vst_plugin_ui.cc index be8eae3240..532fcf6722 100644 --- a/gtk2_ardour/vst_plugin_ui.cc +++ b/gtk2_ardour/vst_plugin_ui.cc @@ -17,10 +17,19 @@ */ +#include #include "ardour/vst_plugin.h" #include "ardour/vst_types.h" +#include "ardour/plugin_insert.h" #include "vst_plugin_ui.h" + +#ifdef PLATFORM_WINDOWS +#include +#elif defined __APPLE__ +// TODO +#else #include +#endif VSTPluginUI::VSTPluginUI (boost::shared_ptr insert, boost::shared_ptr plugin) : PlugUIBase (insert) @@ -30,16 +39,22 @@ VSTPluginUI::VSTPluginUI (boost::shared_ptr insert, boost: box->set_spacing (6); box->set_border_width (6); box->pack_end (focus_button, false, false); - box->pack_end (bypass_button, false, false, 10); + box->pack_end (bypass_button, false, false, 4); + box->pack_end (reset_button, false, false, 4); box->pack_end (delete_button, false, false); box->pack_end (save_button, false, false); box->pack_end (add_button, false, false); box->pack_end (_preset_combo, false, false); + box->pack_end (_preset_modified, false, false); + box->pack_end (pin_management_button, false, false); bypass_button.set_active (!insert->active ()); pack_start (*box, false, false); +#ifdef GDK_WINDOWING_X11 pack_start (_socket, true, true); + _socket.set_border_width (0); +#endif } VSTPluginUI::~VSTPluginUI () @@ -48,33 +63,40 @@ VSTPluginUI::~VSTPluginUI () } void -VSTPluginUI::preset_selected () +VSTPluginUI::preset_selected (ARDOUR::Plugin::PresetRecord preset) { +#ifdef GDK_WINDOWING_X11 _socket.grab_focus (); - PlugUIBase::preset_selected (); +#endif + PlugUIBase::preset_selected (preset); } int VSTPluginUI::get_preferred_height () { - return _vst->state()->height; + return _vst->state()->height + _vst->state()->voffset; } int VSTPluginUI::get_preferred_width () { - return _vst->state()->width; + return _vst->state()->width + _vst->state()->hoffset; } int VSTPluginUI::package (Gtk::Window& win) { +#ifdef GDK_WINDOWING_X11 /* Forward configure events to plugin window */ win.signal_configure_event().connect (sigc::mem_fun (*this, &VSTPluginUI::configure_handler), false); /* This assumes that the window's owner understands the XEmbed protocol */ _socket.add_id (get_XID ()); - + _socket.set_size_request( + _vst->state()->width + _vst->state()->hoffset, + _vst->state()->height + _vst->state()->voffset); +#endif + return 0; } @@ -96,6 +118,7 @@ VSTPluginUI::on_window_hide() bool VSTPluginUI::configure_handler (GdkEventConfigure*) { +#ifdef GDK_WINDOWING_X11 XEvent event; gint x, y; GdkWindow* w; @@ -129,6 +152,6 @@ VSTPluginUI::configure_handler (GdkEventConfigure*) XSendEvent (GDK_WINDOW_XDISPLAY (w), GDK_WINDOW_XWINDOW (w), False, StructureNotifyMask, &event); gdk_error_trap_pop (); +#endif return false; } -