adjusting region fade in/out lengths makes the fade in/out active; new font sizes...
[ardour.git] / gtk2_ardour / plugin_ui.h
index fd5516cee12d408996258e89629f4ae074e2bd62..19a6ad5092745fcd8a5c5ebf62c5c96a4232676d 100644 (file)
@@ -15,7 +15,6 @@
     along with this program; if not, write to the Free Software
     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
 
-    $Id$
 */
 
 #ifndef __ardour_plugin_ui_h__
@@ -71,8 +70,12 @@ class PlugUIBase : public virtual sigc::trackable
        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 () {}
 
   protected:
        boost::shared_ptr<ARDOUR::PluginInsert> insert;
@@ -86,14 +89,15 @@ class PlugUIBase : public virtual sigc::trackable
        void bypass_toggled();
 };
 
-class LadspaPluginUI : public PlugUIBase, public Gtk::VBox 
+class GenericPluginUI : public PlugUIBase, public Gtk::VBox 
 {
   public:
-       LadspaPluginUI (boost::shared_ptr<ARDOUR::PluginInsert> plug, bool scrollable=false);
-       ~LadspaPluginUI ();
+       GenericPluginUI (boost::shared_ptr<ARDOUR::PluginInsert> 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*);
 
@@ -202,12 +206,19 @@ class PluginUIWindow : public ArdourDialog
 
        void resize_preferred();
 
-       virtual bool on_key_press_event (GdkEventKey*);
-       virtual bool on_key_release_event (GdkEventKey*);
-       
+       bool on_key_press_event (GdkEventKey*);
+       bool on_key_release_event (GdkEventKey*);
+       void on_show ();
+       void on_hide ();
+
   private:
        PlugUIBase* _pluginui;
-       void plugin_going_away (ARDOUR::Redirect*);
+       bool non_gtk_gui;
+       void app_activated (bool);
+       void plugin_going_away ();
+
+       bool create_vst_editor (boost::shared_ptr<ARDOUR::PluginInsert>);
+       bool create_audiounit_editor (boost::shared_ptr<ARDOUR::PluginInsert>);
 };
 
 #ifdef VST_SUPPORT
@@ -218,6 +229,7 @@ class VSTPluginUI : public PlugUIBase, public Gtk::VBox
        ~VSTPluginUI ();
 
        gint get_preferred_height ();
+       gint get_preferred_width ();
        bool start_updating(GdkEventAny*) {return false;}
        bool stop_updating(GdkEventAny*) {return false;}
 
@@ -234,4 +246,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<ARDOUR::PluginInsert>, Gtk::VBox**);
+#endif
+
 #endif /* __ardour_plugin_ui_h__ */