diff options
author | David Schleef <ds@schleef.org> | 2007-12-27 00:52:23 +0000 |
---|---|---|
committer | David Schleef <ds@schleef.org> | 2007-12-27 00:52:23 +0000 |
commit | 3b15f24af01272a011b9e8d9df500a7c62eb496d (patch) | |
tree | 91291cff718e109a715332794c0f575786555121 /sys/glsink/gstglupload.c | |
parent | 28eec0700150e32a4f257985a53c22ab22cf562f (diff) | |
download | gst-plugins-bad-3b15f24af01272a011b9e8d9df500a7c62eb496d.tar.gz gst-plugins-bad-3b15f24af01272a011b9e8d9df500a7c62eb496d.tar.bz2 gst-plugins-bad-3b15f24af01272a011b9e8d9df500a7c62eb496d.zip |
sys/glsink/: Remove code that handles non-texture buffers. Add a
Original commit message from CVS:
* sys/glsink/BUGS:
* sys/glsink/Makefile.am:
* sys/glsink/gstglbuffer.c:
* sys/glsink/gstglbuffer.h:
* sys/glsink/gstglconvert.c:
* sys/glsink/gstgldisplay.c:
* sys/glsink/gstglfilter.c:
* sys/glsink/gstglfilter.h:
* sys/glsink/gstglfilterexample.c:
* sys/glsink/gstgltestsrc.c:
* sys/glsink/gstglupload.c:
* sys/glsink/gstopengl.c:
Remove code that handles non-texture buffers. Add a
GstGLBufferFormat type that corresponds to how to use the
texture, not the original video format. Convert gstflfilter.c
into a base class, add glfilterexample and glconvert elements.
* sys/glsink/color_matrix.c:
Minor ramblings about color conversion matrices.
Diffstat (limited to 'sys/glsink/gstglupload.c')
-rw-r--r-- | sys/glsink/gstglupload.c | 29 |
1 files changed, 17 insertions, 12 deletions
diff --git a/sys/glsink/gstglupload.c b/sys/glsink/gstglupload.c index 90f7dc2e..3b5cbc5f 100644 --- a/sys/glsink/gstglupload.c +++ b/sys/glsink/gstglupload.c @@ -50,7 +50,8 @@ struct _GstGLUpload /* < private > */ GstGLDisplay *display; - GstVideoFormat format; + GstVideoFormat video_format; + GstGLBufferFormat format; int width; int height; @@ -77,10 +78,14 @@ GST_STATIC_PAD_TEMPLATE ("src", ); static GstStaticPadTemplate gst_gl_upload_sink_pad_template = -GST_STATIC_PAD_TEMPLATE ("sink", + GST_STATIC_PAD_TEMPLATE ("sink", GST_PAD_SINK, GST_PAD_ALWAYS, - GST_STATIC_CAPS (GST_VIDEO_CAPS_RGBx) + GST_STATIC_CAPS (GST_VIDEO_CAPS_RGBx ";" + GST_VIDEO_CAPS_BGRx ";" + GST_VIDEO_CAPS_xRGB ";" + GST_VIDEO_CAPS_xBGR ";" + GST_VIDEO_CAPS_YUV ("{ YUY2, UYVY, AYUV, YV12, I420 }")) ); enum @@ -178,7 +183,7 @@ gst_gl_upload_reset (GstGLUpload * upload) g_object_unref (upload->display); upload->display = NULL; } - upload->format = GST_VIDEO_FORMAT_RGBx; + upload->format = GST_GL_BUFFER_FORMAT_RGB; upload->peek = FALSE; } @@ -187,7 +192,7 @@ gst_gl_upload_start (GstGLUpload * upload) { gboolean ret; - upload->format = GST_VIDEO_FORMAT_RGBx; + upload->format = GST_GL_BUFFER_FORMAT_RGB; upload->display = gst_gl_display_new (); ret = gst_gl_display_connect (upload->display, NULL); @@ -206,7 +211,7 @@ static gboolean gst_gl_upload_sink_setcaps (GstPad * pad, GstCaps * caps) { GstGLUpload *upload; - GstVideoFormat format; + GstVideoFormat video_format; int height; int width; gboolean ret; @@ -214,15 +219,15 @@ gst_gl_upload_sink_setcaps (GstPad * pad, GstCaps * caps) upload = GST_GL_UPLOAD (gst_pad_get_parent (pad)); - ret = gst_video_format_parse_caps (caps, &format, &width, &height); + ret = gst_video_format_parse_caps (caps, &video_format, &width, &height); if (!ret) return FALSE; - upload->format = format; + upload->video_format = video_format; upload->width = width; upload->height = height; - GST_ERROR ("setcaps %d %d %d", format, width, height); + GST_DEBUG ("setcaps %d %d %d", video_format, width, height); srccaps = gst_caps_new_simple ("video/x-raw-gl", "width", G_TYPE_INT, width, "height", G_TYPE_INT, height, NULL); @@ -240,8 +245,9 @@ gst_gl_upload_chain (GstPad * pad, GstBuffer * buf) upload = GST_GL_UPLOAD (gst_pad_get_parent (pad)); - outbuf = gst_gl_buffer_new (upload->display, upload->format, - upload->width, upload->height); + outbuf = gst_gl_buffer_new_from_data (upload->display, + upload->video_format, upload->width, upload->height, + GST_BUFFER_DATA (buf)); gst_buffer_copy_metadata (GST_BUFFER (outbuf), buf, GST_BUFFER_COPY_TIMESTAMPS | GST_BUFFER_COPY_FLAGS); @@ -249,7 +255,6 @@ gst_gl_upload_chain (GstPad * pad, GstBuffer * buf) GST_DEBUG ("uploading %p size %d", GST_BUFFER_DATA (buf), GST_BUFFER_SIZE (buf)); - gst_gl_buffer_upload (outbuf, GST_BUFFER_DATA (buf)); gst_buffer_unref (buf); if (upload->peek) { |