2011-11-18 16:26:35 +00:00
|
|
|
/*
|
2008-06-11 18:33:53 +00:00
|
|
|
* GStreamer
|
2008-09-20 13:44:24 +00:00
|
|
|
* Copyright (C) 2007 David Schleef <ds@schleef.org>
|
2008-06-11 18:33:53 +00:00
|
|
|
* Copyright (C) 2008 Julien Isorce <julien.isorce@gmail.com>
|
2008-08-11 07:52:16 +00:00
|
|
|
* Copyright (C) 2008 Filippo Argiolas <filippo.argiolas@gmail.com>
|
2008-06-11 18:33:53 +00:00
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Library General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Library General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
|
|
|
* License along with this library; if not, write to the
|
2012-11-08 11:53:56 +00:00
|
|
|
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
|
|
|
|
* Boston, MA 02110-1301, USA.
|
2008-06-11 18:33:53 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _GST_GL_FILTER_H_
|
|
|
|
#define _GST_GL_FILTER_H_
|
|
|
|
|
|
|
|
#include <gst/gst.h>
|
|
|
|
#include <gst/base/gstbasetransform.h>
|
|
|
|
#include <gst/video/video.h>
|
|
|
|
|
2013-07-11 09:03:31 +00:00
|
|
|
#include <gst/gl/gl.h>
|
2008-06-11 18:33:53 +00:00
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
2012-09-27 05:53:46 +00:00
|
|
|
GType gst_gl_filter_get_type(void);
|
2008-06-11 18:33:53 +00:00
|
|
|
#define GST_TYPE_GL_FILTER (gst_gl_filter_get_type())
|
|
|
|
#define GST_GL_FILTER(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj),GST_TYPE_GL_FILTER,GstGLFilter))
|
|
|
|
#define GST_IS_GL_FILTER(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj),GST_TYPE_GL_FILTER))
|
|
|
|
#define GST_GL_FILTER_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass) ,GST_TYPE_GL_FILTER,GstGLFilterClass))
|
|
|
|
#define GST_IS_GL_FILTER_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass) ,GST_TYPE_GL_FILTER))
|
|
|
|
#define GST_GL_FILTER_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj) ,GST_TYPE_GL_FILTER,GstGLFilterClass))
|
2012-09-27 05:53:46 +00:00
|
|
|
|
2008-06-11 18:33:53 +00:00
|
|
|
typedef struct _GstGLFilter GstGLFilter;
|
|
|
|
typedef struct _GstGLFilterClass GstGLFilterClass;
|
|
|
|
|
2012-09-27 05:53:46 +00:00
|
|
|
/**
|
|
|
|
* GstGLFilter:
|
|
|
|
* @base_transform: parent #GstBaseTransform
|
|
|
|
* @pool: the currently configured #GstBufferPool
|
|
|
|
* @display: the currently configured #GstGLDisplay
|
|
|
|
* @in_info: the video info for input buffers
|
|
|
|
* @out_info: the video info for output buffers
|
|
|
|
* @fbo: GL Framebuffer object used for transformations
|
|
|
|
* @depthbuffer: GL renderbuffer attached to @fbo
|
|
|
|
* @upload: the object used for uploading data, if needed
|
|
|
|
* @download: the object used for downloading data, if needed
|
|
|
|
*
|
|
|
|
* #GstGLFilter is a base class that provides the logic of getting the GL context
|
|
|
|
* from downstream and automatic upload/download for non-#GstGLMemory
|
|
|
|
* #GstBuffer<!-- -->s.
|
|
|
|
*/
|
2008-06-11 18:33:53 +00:00
|
|
|
struct _GstGLFilter
|
|
|
|
{
|
2012-09-27 05:53:46 +00:00
|
|
|
GstBaseTransform base_transform;
|
2008-06-11 18:33:53 +00:00
|
|
|
|
2012-09-27 05:53:46 +00:00
|
|
|
GstBufferPool *pool;
|
2012-07-09 12:27:48 +00:00
|
|
|
|
2012-09-27 05:53:46 +00:00
|
|
|
GstGLDisplay *display;
|
2008-06-21 21:38:42 +00:00
|
|
|
|
2012-09-27 05:53:46 +00:00
|
|
|
GstVideoInfo in_info;
|
|
|
|
GstVideoInfo out_info;
|
|
|
|
GLuint fbo;
|
|
|
|
GLuint depthbuffer;
|
2009-11-17 22:47:24 +00:00
|
|
|
|
2012-09-27 05:53:46 +00:00
|
|
|
GstGLUpload *upload;
|
|
|
|
GstGLDownload *download;
|
2010-04-29 06:27:29 +00:00
|
|
|
|
2012-09-27 05:53:46 +00:00
|
|
|
/* <private> */
|
|
|
|
GLuint in_tex_id;
|
|
|
|
GLuint out_tex_id;
|
2012-09-16 11:42:08 +00:00
|
|
|
|
2012-09-27 05:53:46 +00:00
|
|
|
GstGLShader *default_shader;
|
|
|
|
|
2013-07-17 09:22:02 +00:00
|
|
|
guint64 external_gl_context;
|
2008-06-11 18:33:53 +00:00
|
|
|
};
|
|
|
|
|
2012-09-27 05:53:46 +00:00
|
|
|
/**
|
|
|
|
* GstGLFilterClass:
|
|
|
|
* @base_transform_class: parent class
|
|
|
|
* @set_caps: mirror from #GstBaseTransform
|
|
|
|
* @filter: perform operations on the input and output buffers. In general,
|
|
|
|
* you should avoid using this method if at all possible. One valid
|
|
|
|
* use-case for using this is keeping previous buffers for future calculations.
|
|
|
|
* Note: If @filter exists, then @filter_texture is not run
|
|
|
|
* @filter_texture: given @in_tex, transform it into @out_tex. Not used
|
|
|
|
* if @filter exists
|
|
|
|
* @onInitFBO: perform initialization when the Framebuffer object is created
|
|
|
|
* @onStart: called when element activates see also #GstBaseTransform
|
|
|
|
* @onStop: called when the element deactivates e also #GstBaseTransform
|
|
|
|
* @onReset: called on inizialation and after @onStop
|
|
|
|
* @display_init_cb: execute arbitrary gl code on start
|
|
|
|
* @display_reset_cb: execute arbitrary gl code at stop
|
|
|
|
*/
|
2008-06-11 18:33:53 +00:00
|
|
|
struct _GstGLFilterClass
|
|
|
|
{
|
2008-08-11 07:52:16 +00:00
|
|
|
GstBaseTransformClass base_transform_class;
|
2011-11-18 16:26:35 +00:00
|
|
|
|
2012-09-27 05:53:46 +00:00
|
|
|
gboolean (*set_caps) (GstGLFilter* filter, GstCaps* incaps, GstCaps* outcaps);
|
|
|
|
gboolean (*filter) (GstGLFilter *filter, GstBuffer *inbuf, GstBuffer *outbuf);
|
|
|
|
gboolean (*filter_texture) (GstGLFilter *filter, guint in_tex, guint out_tex);
|
|
|
|
gboolean (*onInitFBO) (GstGLFilter *filter);
|
|
|
|
|
|
|
|
void (*onStart) (GstGLFilter *filter);
|
|
|
|
void (*onStop) (GstGLFilter *filter);
|
|
|
|
void (*onReset) (GstGLFilter *filter);
|
2008-08-11 07:52:16 +00:00
|
|
|
|
|
|
|
/* useful to init and cleanup custom gl resources */
|
2012-09-27 05:53:46 +00:00
|
|
|
void (*display_init_cb) (GstGLFilter *filter);
|
|
|
|
void (*display_reset_cb) (GstGLFilter *filter);
|
2008-06-11 18:33:53 +00:00
|
|
|
};
|
|
|
|
|
2012-09-20 13:06:49 +00:00
|
|
|
gboolean gst_gl_filter_filter_texture (GstGLFilter * filter, GstBuffer * inbuf,
|
|
|
|
GstBuffer * outbuf);
|
2008-08-10 09:22:34 +00:00
|
|
|
|
2012-09-27 05:53:46 +00:00
|
|
|
void gst_gl_filter_render_to_target (GstGLFilter *filter, gboolean resize, GLuint input,
|
|
|
|
GLuint target, GLCB func, gpointer data);
|
2012-09-25 07:59:27 +00:00
|
|
|
|
2013-01-09 14:13:23 +00:00
|
|
|
#if GST_GL_HAVE_OPENGL
|
2012-09-27 05:53:46 +00:00
|
|
|
void gst_gl_filter_render_to_target_with_shader (GstGLFilter * filter, gboolean resize,
|
|
|
|
GLuint input, GLuint target, GstGLShader *shader);
|
2008-08-10 09:22:34 +00:00
|
|
|
|
2012-09-25 07:59:27 +00:00
|
|
|
void gst_gl_filter_draw_texture (GstGLFilter *filter, GLuint texture, guint width, guint height);
|
2013-01-09 14:13:23 +00:00
|
|
|
#endif /* GST_GL_HAVE_OPENGL */
|
2008-08-10 09:22:34 +00:00
|
|
|
|
2008-06-11 18:33:53 +00:00
|
|
|
G_END_DECLS
|
|
|
|
|
2012-09-27 05:53:46 +00:00
|
|
|
#endif /* _GST_GL_FILTER_H_ */
|