diff options
Diffstat (limited to 'sys')
-rw-r--r-- | sys/glsink/gstglsink.c | 90 |
1 files changed, 44 insertions, 46 deletions
diff --git a/sys/glsink/gstglsink.c b/sys/glsink/gstglsink.c index 30268d31..54d2938f 100644 --- a/sys/glsink/gstglsink.c +++ b/sys/glsink/gstglsink.c @@ -43,13 +43,26 @@ static GstElementDetails gst_glsink_details = { "OpenGL Sink/GLX", "Sink/GLVideo", - "LGPL", "An OpenGL based video sink - uses OpenGL and GLX to draw video, utilizing different acceleration options", - VERSION, - "Gernot Ziegler <gz@lysator.liu.se>", - "(C) 2002", + "Gernot Ziegler <gz@lysator.liu.se>" }; +/* default template - initiated with class struct to allow gst-register to work + with X running */ +GST_PAD_TEMPLATE_FACTORY (gst_glsink_sink_template_factory, + "sink", + GST_PAD_SINK, + GST_PAD_ALWAYS, + GST_CAPS_NEW ( "glsink_rgbsink", "video/x-raw-rgb", + "framerate", GST_PROPS_FLOAT_RANGE(0, G_MAXFLOAT), + "width", GST_PROPS_INT_RANGE(0, G_MAXINT), + "height", GST_PROPS_INT_RANGE(0, G_MAXINT)), + GST_CAPS_NEW ( "glsink_yuvsink", "video/x-raw-yuv", + "framerate", GST_PROPS_FLOAT_RANGE(0, G_MAXFLOAT), + "width", GST_PROPS_INT_RANGE(0, G_MAXINT), + "height", GST_PROPS_INT_RANGE(0, G_MAXINT)) +) + /* glsink signals and args */ enum { LAST_SIGNAL @@ -116,6 +129,7 @@ struct _GstGLSinkClass { static GType gst_glsink_get_type (void); +static void gst_glsink_base_init (gpointer g_class); static void gst_glsink_class_init (GstGLSinkClass *klass); static void gst_glsink_init (GstGLSink *sink); /* static void gst_glsink_dispose (GObject *object); */ @@ -165,7 +179,7 @@ gst_glsink_get_type (void) if (!videosink_type) { static const GTypeInfo videosink_info = { sizeof(GstGLSinkClass), - NULL, + gst_glsink_base_init, NULL, (GClassInitFunc) gst_glsink_class_init, NULL, @@ -180,13 +194,25 @@ gst_glsink_get_type (void) } static void +gst_glsink_base_init (gpointer g_class) +{ + GstElementClass *element_class = GST_ELEMENT_CLASS (g_class); + + gst_element_class_set_details (element_class, &gst_glsink_details); + + gst_element_class_add_pad_template ( + element_class, + GST_PAD_TEMPLATE_GET (gst_glsink_sink_template_factory)); +} + +static void gst_glsink_class_init (GstGLSinkClass *klass) { GObjectClass *gobject_class; GstElementClass *gstelement_class; gobject_class = (GObjectClass *) klass; - gstelement_class = (GstElementClass *) klass; + gstelement_class = (GstElementClass*) klass; parent_class = g_type_class_ref (GST_TYPE_ELEMENT); @@ -728,40 +754,13 @@ gst_glsink_change_state (GstElement *element) return GST_STATE_SUCCESS; } -#if 1 -/* default template - initiated with class struct to allow gst-register to work - with X running */ -GST_PAD_TEMPLATE_FACTORY (gst_glsink_sink_template_factory, - "sink", - GST_PAD_SINK, - GST_PAD_ALWAYS, - GST_CAPS_NEW ( "glsink_rgbsink", "video/x-raw-rgb", - "framerate", GST_PROPS_FLOAT_RANGE(0, G_MAXFLOAT), - "width", GST_PROPS_INT_RANGE(0, G_MAXINT), - "height", GST_PROPS_INT_RANGE(0, G_MAXINT)), - GST_CAPS_NEW ( "glsink_yuvsink", "video/x-raw-yuv", - "framerate", GST_PROPS_FLOAT_RANGE(0, G_MAXFLOAT), - "width", GST_PROPS_INT_RANGE(0, G_MAXINT), - "height", GST_PROPS_INT_RANGE(0, G_MAXINT)) -) -#endif - - static gboolean -plugin_init (GModule *module, GstPlugin *plugin) +plugin_init (GstPlugin *plugin) { - GstElementFactory *factory; - /* Loading the library containing GstVideoSink, our parent object */ if (!gst_library_load ("gstvideo")) return FALSE; - /* create an elementfactory for the xvideosink element */ - factory = gst_element_factory_new("glsink",GST_TYPE_GLSINK, - &gst_glsink_details); - - g_return_val_if_fail(factory != NULL, FALSE); - /* this is needed later on in the _real_ init (during a gst-launch) */ sink_template = gst_pad_template_new ( "sink", @@ -769,22 +768,21 @@ plugin_init (GModule *module, GstPlugin *plugin) GST_PAD_ALWAYS, NULL); -#if 0 - gst_element_factory_add_pad_template (factory, sink_template); -#else - gst_element_factory_add_pad_template ( - factory, - GST_PAD_TEMPLATE_GET (gst_glsink_sink_template_factory)); -#endif - - gst_plugin_add_feature (plugin, GST_PLUGIN_FEATURE (factory)); + if (!gst_element_register (plugin, "glsink", GST_RANK_NONE, GST_TYPE_GLSINK)) + return FALSE; return TRUE; } -GstPluginDesc plugin_desc = { +GST_PLUGIN_DEFINE ( GST_VERSION_MAJOR, GST_VERSION_MINOR, "glsink", - plugin_init -}; + "An OpenGL based video sink - uses OpenGL and GLX to draw video, utilizing different acceleration options", + plugin_init, + VERSION, + GST_LICENSE, + GST_COPYRIGHT, + GST_PACKAGE, + GST_ORIGIN +); |