mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-09-17 01:20:19 +00:00
[082/906] glfilter can request, use and reject a FBO (step 1)
git-svn-id: svn://svn.wobow.com/GStreamer_playground/gst-plugins-gl@494 93df14bb-0f41-7a43-8087-d3e2a2f0e464
This commit is contained in:
parent
31be382a90
commit
59dc400b7e
6 changed files with 419 additions and 301 deletions
|
@ -29,6 +29,8 @@ static void gst_gl_display_finalize (GObject * object);
|
||||||
static gpointer gst_gl_display_glutThreadFunc (GstGLDisplay* display);
|
static gpointer gst_gl_display_glutThreadFunc (GstGLDisplay* display);
|
||||||
static void gst_gl_display_glutCreateWindow (GstGLDisplay* display);
|
static void gst_gl_display_glutCreateWindow (GstGLDisplay* display);
|
||||||
static void gst_gl_display_glutGenerateFBO (GstGLDisplay *display);
|
static void gst_gl_display_glutGenerateFBO (GstGLDisplay *display);
|
||||||
|
static void gst_gl_display_glutUseFBO (GstGLDisplay *display);
|
||||||
|
static void gst_gl_display_glutDestroyFBO (GstGLDisplay *display);
|
||||||
static void gst_gl_display_glutDestroyWindow (GstGLDisplay* display);
|
static void gst_gl_display_glutDestroyWindow (GstGLDisplay* display);
|
||||||
static void gst_gl_display_glutSetVisibleWindow (GstGLDisplay* display);
|
static void gst_gl_display_glutSetVisibleWindow (GstGLDisplay* display);
|
||||||
static void gst_gl_display_glutPrepareTexture (GstGLDisplay* display);
|
static void gst_gl_display_glutPrepareTexture (GstGLDisplay* display);
|
||||||
|
@ -95,6 +97,8 @@ gst_gl_display_init (GstGLDisplay *display, GstGLDisplayClass *klass)
|
||||||
display->cond_clear = g_cond_new ();
|
display->cond_clear = g_cond_new ();
|
||||||
display->cond_video = g_cond_new ();
|
display->cond_video = g_cond_new ();
|
||||||
display->cond_generateFBO = g_cond_new ();
|
display->cond_generateFBO = g_cond_new ();
|
||||||
|
display->cond_useFBO = g_cond_new ();
|
||||||
|
display->cond_destroyFBO = g_cond_new ();
|
||||||
display->cond_create = g_cond_new ();
|
display->cond_create = g_cond_new ();
|
||||||
display->cond_destroy = g_cond_new ();
|
display->cond_destroy = g_cond_new ();
|
||||||
|
|
||||||
|
@ -113,6 +117,18 @@ gst_gl_display_init (GstGLDisplay *display, GstGLDisplayClass *klass)
|
||||||
display->requestedTextureFBO = 0;
|
display->requestedTextureFBO = 0;
|
||||||
display->requestedTextureFBOWidth = 0;
|
display->requestedTextureFBOWidth = 0;
|
||||||
display->requestedTextureFBOHeight = 0;
|
display->requestedTextureFBOHeight = 0;
|
||||||
|
display->usedFBO = 0;
|
||||||
|
display->usedDepthBuffer = 0;
|
||||||
|
display->usedTextureFBO = 0;
|
||||||
|
display->usedTextureFBOWidth = 0;
|
||||||
|
display->usedTextureFBOHeight = 0;
|
||||||
|
display->glsceneFBO_cb = NULL;
|
||||||
|
display->inputTextureWidth = 0;
|
||||||
|
display->inputTextureHeight = 0;
|
||||||
|
display->inputTexture = 0;
|
||||||
|
display->rejectedFBO = 0;
|
||||||
|
display->rejectedDepthBuffer = 0;
|
||||||
|
display->rejectedTextureFBO = 0;
|
||||||
|
|
||||||
display->requestedTexture = 0;
|
display->requestedTexture = 0;
|
||||||
display->requestedTexture_u = 0;
|
display->requestedTexture_u = 0;
|
||||||
|
@ -338,6 +354,14 @@ gst_gl_display_finalize (GObject *object)
|
||||||
g_cond_free (display->cond_generateFBO);
|
g_cond_free (display->cond_generateFBO);
|
||||||
display->cond_generateFBO = NULL;
|
display->cond_generateFBO = NULL;
|
||||||
}
|
}
|
||||||
|
if (display->cond_useFBO) {
|
||||||
|
g_cond_free (display->cond_useFBO);
|
||||||
|
display->cond_useFBO = NULL;
|
||||||
|
}
|
||||||
|
if (display->cond_destroyFBO) {
|
||||||
|
g_cond_free (display->cond_destroyFBO);
|
||||||
|
display->cond_destroyFBO = NULL;
|
||||||
|
}
|
||||||
if (display->cond_create) {
|
if (display->cond_create) {
|
||||||
g_cond_free (display->cond_create);
|
g_cond_free (display->cond_create);
|
||||||
display->cond_create = NULL;
|
display->cond_create = NULL;
|
||||||
|
@ -350,6 +374,8 @@ gst_gl_display_finalize (GObject *object)
|
||||||
display->clientReshapeCallback = NULL;
|
display->clientReshapeCallback = NULL;
|
||||||
if (display->clientDrawCallback)
|
if (display->clientDrawCallback)
|
||||||
display->clientDrawCallback = NULL;
|
display->clientDrawCallback = NULL;
|
||||||
|
if (display->glsceneFBO_cb)
|
||||||
|
display->glsceneFBO_cb = NULL;
|
||||||
|
|
||||||
//at this step, the next condition imply that the last display has been pushed
|
//at this step, the next condition imply that the last display has been pushed
|
||||||
if (g_hash_table_size (gst_gl_display_map) == 0)
|
if (g_hash_table_size (gst_gl_display_map) == 0)
|
||||||
|
@ -701,7 +727,73 @@ gst_gl_display_glutGenerateFBO (GstGLDisplay *display)
|
||||||
//unbind the FBO
|
//unbind the FBO
|
||||||
glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0);
|
glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0);
|
||||||
|
|
||||||
g_cond_signal (display->cond_video);
|
g_cond_signal (display->cond_generateFBO);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Called by the idle funtion */
|
||||||
|
static void
|
||||||
|
gst_gl_display_glutUseFBO (GstGLDisplay *display)
|
||||||
|
{
|
||||||
|
|
||||||
|
glutSetWindow (display->glutWinId);
|
||||||
|
|
||||||
|
glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, display->usedFBO);
|
||||||
|
|
||||||
|
glPushAttrib(GL_VIEWPORT_BIT);
|
||||||
|
|
||||||
|
glMatrixMode(GL_PROJECTION);
|
||||||
|
glPushMatrix();
|
||||||
|
glLoadIdentity();
|
||||||
|
gluPerspective(45, (gfloat)display->usedTextureFBOWidth/(gfloat)display->usedTextureFBOHeight, 0.1, 100);
|
||||||
|
//gluOrtho2D(0.0, display->usedTextureFBOWidth, 0.0, display->usedTextureFBOHeight);
|
||||||
|
|
||||||
|
glMatrixMode(GL_MODELVIEW);
|
||||||
|
glPushMatrix();
|
||||||
|
glLoadIdentity();
|
||||||
|
|
||||||
|
glViewport(0, 0, display->usedTextureFBOWidth, display->usedTextureFBOHeight);
|
||||||
|
|
||||||
|
glDrawBuffer(GL_COLOR_ATTACHMENT0_EXT);
|
||||||
|
glClearColor(0.0, 0.0, 0.0, 0.0);
|
||||||
|
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||||
|
|
||||||
|
//the opengl scene
|
||||||
|
display->glsceneFBO_cb (display->inputTextureWidth, display->inputTextureHeight, display->inputTexture);
|
||||||
|
|
||||||
|
glDrawBuffer(GL_NONE);
|
||||||
|
|
||||||
|
glUseProgramObjectARB (0);
|
||||||
|
|
||||||
|
glDisable(GL_TEXTURE_RECTANGLE_ARB);
|
||||||
|
|
||||||
|
glPopMatrix();
|
||||||
|
glMatrixMode(GL_PROJECTION);
|
||||||
|
glPopMatrix();
|
||||||
|
glMatrixMode(GL_MODELVIEW);
|
||||||
|
glPopAttrib();
|
||||||
|
|
||||||
|
glBindFramebufferEXT(GL_FRAMEBUFFER_EXT, 0);
|
||||||
|
|
||||||
|
g_cond_signal (display->cond_useFBO);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Called by the idle funtion */
|
||||||
|
static void
|
||||||
|
gst_gl_display_glutDestroyFBO (GstGLDisplay *display)
|
||||||
|
{
|
||||||
|
|
||||||
|
glutSetWindow (display->glutWinId);
|
||||||
|
|
||||||
|
glDeleteFramebuffersEXT (1, &display->rejectedFBO);
|
||||||
|
glDeleteRenderbuffersEXT(1, &display->rejectedDepthBuffer);
|
||||||
|
glDeleteTextures (1, &display->rejectedTextureFBO);
|
||||||
|
display->rejectedFBO = 0;
|
||||||
|
display->rejectedDepthBuffer = 0;
|
||||||
|
display->rejectedTextureFBO = 0;
|
||||||
|
|
||||||
|
g_cond_signal (display->cond_destroyFBO);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -903,6 +995,12 @@ gst_gl_display_glutDispatchAction (GstGLDisplayMsg* msg)
|
||||||
case GST_GL_DISPLAY_ACTION_GENFBO:
|
case GST_GL_DISPLAY_ACTION_GENFBO:
|
||||||
gst_gl_display_glutGenerateFBO (msg->display);
|
gst_gl_display_glutGenerateFBO (msg->display);
|
||||||
break;
|
break;
|
||||||
|
case GST_GL_DISPLAY_ACTION_DELFBO:
|
||||||
|
gst_gl_display_glutDestroyFBO (msg->display);
|
||||||
|
break;
|
||||||
|
case GST_GL_DISPLAY_ACTION_USEFBO:
|
||||||
|
gst_gl_display_glutUseFBO (msg->display);
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
g_assert_not_reached ();
|
g_assert_not_reached ();
|
||||||
}
|
}
|
||||||
|
@ -930,6 +1028,8 @@ gst_gl_display_checkMsgValidity (GstGLDisplayMsg *msg)
|
||||||
case GST_GL_DISPLAY_ACTION_VIDEO:
|
case GST_GL_DISPLAY_ACTION_VIDEO:
|
||||||
case GST_GL_DISPLAY_ACTION_REDISPLAY:
|
case GST_GL_DISPLAY_ACTION_REDISPLAY:
|
||||||
case GST_GL_DISPLAY_ACTION_GENFBO:
|
case GST_GL_DISPLAY_ACTION_GENFBO:
|
||||||
|
case GST_GL_DISPLAY_ACTION_DELFBO:
|
||||||
|
case GST_GL_DISPLAY_ACTION_USEFBO:
|
||||||
//msg is out of date if the associated display is not in the map
|
//msg is out of date if the associated display is not in the map
|
||||||
if (!g_hash_table_lookup (gst_gl_display_map, GINT_TO_POINTER (msg->glutWinId)))
|
if (!g_hash_table_lookup (gst_gl_display_map, GINT_TO_POINTER (msg->glutWinId)))
|
||||||
valid = FALSE;
|
valid = FALSE;
|
||||||
|
@ -1154,6 +1254,43 @@ gst_gl_display_requestFBO (GstGLDisplay* display, gint width, gint height,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Called by gst_gl elements */
|
||||||
|
void
|
||||||
|
gst_gl_display_useFBO (GstGLDisplay* display, gint textureFBOWidth, gint textureFBOheight,
|
||||||
|
guint fbo, guint depthbuffer, guint textureFBO, GLCB cb,
|
||||||
|
guint inputTextureWidth, guint inputTextureHeight, guint inputTexture)
|
||||||
|
{
|
||||||
|
gst_gl_display_lock (display);
|
||||||
|
display->usedFBO = fbo;
|
||||||
|
display->usedDepthBuffer = depthbuffer;
|
||||||
|
display->usedTextureFBO = textureFBO;
|
||||||
|
display->usedTextureFBOWidth = textureFBOWidth;
|
||||||
|
display->usedTextureFBOHeight = textureFBOheight;
|
||||||
|
display->glsceneFBO_cb = cb;
|
||||||
|
display->inputTextureWidth = inputTextureWidth;
|
||||||
|
display->inputTextureHeight = inputTextureHeight;
|
||||||
|
display->inputTexture = inputTexture;
|
||||||
|
gst_gl_display_postMessage (GST_GL_DISPLAY_ACTION_USEFBO, display);
|
||||||
|
g_cond_wait (display->cond_useFBO, display->mutex);
|
||||||
|
gst_gl_display_unlock (display);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Called by gst_gl elements */
|
||||||
|
void
|
||||||
|
gst_gl_display_rejectFBO (GstGLDisplay* display, guint fbo,
|
||||||
|
guint depthbuffer, guint texture)
|
||||||
|
{
|
||||||
|
gst_gl_display_lock (display);
|
||||||
|
display->rejectedFBO = fbo;
|
||||||
|
display->rejectedDepthBuffer = depthbuffer;
|
||||||
|
display->rejectedTextureFBO = texture;
|
||||||
|
gst_gl_display_postMessage (GST_GL_DISPLAY_ACTION_DELFBO, display);
|
||||||
|
g_cond_wait (display->cond_destroyFBO, display->mutex);
|
||||||
|
gst_gl_display_unlock (display);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Called by gst_gl elements */
|
/* Called by gst_gl elements */
|
||||||
void
|
void
|
||||||
gst_gl_display_set_windowId (GstGLDisplay* display, gulong winId)
|
gst_gl_display_set_windowId (GstGLDisplay* display, gulong winId)
|
||||||
|
|
|
@ -51,7 +51,9 @@ typedef enum {
|
||||||
GST_GL_DISPLAY_ACTION_CLEAR,
|
GST_GL_DISPLAY_ACTION_CLEAR,
|
||||||
GST_GL_DISPLAY_ACTION_VIDEO,
|
GST_GL_DISPLAY_ACTION_VIDEO,
|
||||||
GST_GL_DISPLAY_ACTION_REDISPLAY,
|
GST_GL_DISPLAY_ACTION_REDISPLAY,
|
||||||
GST_GL_DISPLAY_ACTION_GENFBO
|
GST_GL_DISPLAY_ACTION_GENFBO,
|
||||||
|
GST_GL_DISPLAY_ACTION_DELFBO,
|
||||||
|
GST_GL_DISPLAY_ACTION_USEFBO
|
||||||
|
|
||||||
} GstGLDisplayAction;
|
} GstGLDisplayAction;
|
||||||
|
|
||||||
|
@ -76,6 +78,9 @@ typedef struct _GstGLDisplayTex {
|
||||||
typedef void (* CRCB) ( GLuint, GLuint );
|
typedef void (* CRCB) ( GLuint, GLuint );
|
||||||
typedef gboolean (* CDCB) ( GLuint, GLuint, GLuint);
|
typedef gboolean (* CDCB) ( GLuint, GLuint, GLuint);
|
||||||
|
|
||||||
|
//opengl scene callback
|
||||||
|
typedef void (* GLCB) ( GLuint, GLuint, GLuint);
|
||||||
|
|
||||||
struct _GstGLDisplay {
|
struct _GstGLDisplay {
|
||||||
GObject object;
|
GObject object;
|
||||||
|
|
||||||
|
@ -88,6 +93,8 @@ struct _GstGLDisplay {
|
||||||
GCond* cond_clear;
|
GCond* cond_clear;
|
||||||
GCond* cond_video;
|
GCond* cond_video;
|
||||||
GCond* cond_generateFBO;
|
GCond* cond_generateFBO;
|
||||||
|
GCond* cond_useFBO;
|
||||||
|
GCond* cond_destroyFBO;
|
||||||
|
|
||||||
GCond* cond_create;
|
GCond* cond_create;
|
||||||
GCond* cond_destroy;
|
GCond* cond_destroy;
|
||||||
|
@ -119,6 +126,18 @@ struct _GstGLDisplay {
|
||||||
GLuint requestedTextureFBO;
|
GLuint requestedTextureFBO;
|
||||||
GLuint requestedTextureFBOWidth;
|
GLuint requestedTextureFBOWidth;
|
||||||
GLuint requestedTextureFBOHeight;
|
GLuint requestedTextureFBOHeight;
|
||||||
|
GLuint usedFBO;
|
||||||
|
GLuint usedDepthBuffer;
|
||||||
|
GLuint usedTextureFBO;
|
||||||
|
GLuint usedTextureFBOWidth;
|
||||||
|
GLuint usedTextureFBOHeight;
|
||||||
|
GLCB glsceneFBO_cb;
|
||||||
|
GLuint inputTextureWidth;
|
||||||
|
GLuint inputTextureHeight;
|
||||||
|
GLuint inputTexture;
|
||||||
|
GLuint rejectedFBO;
|
||||||
|
GLuint rejectedDepthBuffer;
|
||||||
|
GLuint rejectedTextureFBO;
|
||||||
|
|
||||||
GLuint requestedTexture;
|
GLuint requestedTexture;
|
||||||
GLuint requestedTexture_u;
|
GLuint requestedTexture_u;
|
||||||
|
@ -196,7 +215,7 @@ GType gst_gl_display_get_type (void);
|
||||||
|
|
||||||
|
|
||||||
//------------------------------------------------------------
|
//------------------------------------------------------------
|
||||||
//-------------------- Public d<EFBFBD>clarations ------------------
|
//-------------------- Public declarations ------------------
|
||||||
//------------------------------------------------------------
|
//------------------------------------------------------------
|
||||||
GstGLDisplay *gst_gl_display_new (void);
|
GstGLDisplay *gst_gl_display_new (void);
|
||||||
void gst_gl_display_initGLContext (GstGLDisplay* display,
|
void gst_gl_display_initGLContext (GstGLDisplay* display,
|
||||||
|
@ -222,6 +241,11 @@ void gst_gl_display_videoChanged (GstGLDisplay* display, GstVideoFormat video_fo
|
||||||
gboolean gst_gl_display_postRedisplay (GstGLDisplay* display);
|
gboolean gst_gl_display_postRedisplay (GstGLDisplay* display);
|
||||||
void gst_gl_display_requestFBO (GstGLDisplay* display, gint width, gint height,
|
void gst_gl_display_requestFBO (GstGLDisplay* display, gint width, gint height,
|
||||||
guint* fbo, guint* depthbuffer, guint* texture);
|
guint* fbo, guint* depthbuffer, guint* texture);
|
||||||
|
void gst_gl_display_useFBO (GstGLDisplay* display, gint textureFBOWidth, gint textureFBOheight,
|
||||||
|
guint fbo, guint depthbuffer, guint textureFBO, GLCB cb,
|
||||||
|
guint inputTextureWidth, guint inputTextureHeight, guint inputTexture);
|
||||||
|
void gst_gl_display_rejectFBO (GstGLDisplay* display, guint fbo,
|
||||||
|
guint depthbuffer, guint texture);
|
||||||
void gst_gl_display_set_windowId (GstGLDisplay* display, gulong winId);
|
void gst_gl_display_set_windowId (GstGLDisplay* display, gulong winId);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -105,10 +105,6 @@ gst_gl_filter_init (GstGLFilter * filter, GstGLFilterClass * klass)
|
||||||
filter->sinkpad = gst_element_get_static_pad (GST_ELEMENT (filter), "sink");
|
filter->sinkpad = gst_element_get_static_pad (GST_ELEMENT (filter), "sink");
|
||||||
filter->srcpad = gst_element_get_static_pad (GST_ELEMENT (filter), "src");
|
filter->srcpad = gst_element_get_static_pad (GST_ELEMENT (filter), "src");
|
||||||
|
|
||||||
/*gst_gl_display_requestFBO
|
|
||||||
|
|
||||||
filter->fbo = */
|
|
||||||
|
|
||||||
gst_gl_filter_reset (filter);
|
gst_gl_filter_reset (filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -143,12 +139,18 @@ gst_gl_filter_reset (GstGLFilter* filter)
|
||||||
{
|
{
|
||||||
if (filter->display)
|
if (filter->display)
|
||||||
{
|
{
|
||||||
|
//blocking call, delete the FBO
|
||||||
|
gst_gl_display_rejectFBO (filter->display, filter->fbo,
|
||||||
|
filter->depthbuffer, filter->texture);
|
||||||
g_object_unref (filter->display);
|
g_object_unref (filter->display);
|
||||||
filter->display = NULL;
|
filter->display = NULL;
|
||||||
}
|
}
|
||||||
filter->video_format = GST_VIDEO_FORMAT_UNKNOWN;
|
filter->video_format = GST_VIDEO_FORMAT_UNKNOWN;
|
||||||
filter->width = 0;
|
filter->width = 0;
|
||||||
filter->height = 0;
|
filter->height = 0;
|
||||||
|
filter->fbo = 0;
|
||||||
|
filter->depthbuffer = 0;
|
||||||
|
filter->texture = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
|
@ -194,7 +196,12 @@ gst_gl_filter_prepare_output_buffer (GstBaseTransform* trans,
|
||||||
filter = GST_GL_FILTER (trans);
|
filter = GST_GL_FILTER (trans);
|
||||||
|
|
||||||
if (filter->display == NULL)
|
if (filter->display == NULL)
|
||||||
|
{
|
||||||
filter->display = g_object_ref (gl_inbuf->display);
|
filter->display = g_object_ref (gl_inbuf->display);
|
||||||
|
//blocking call, generate a FBO
|
||||||
|
gst_gl_display_requestFBO (filter->display, filter->width, filter->height,
|
||||||
|
&filter->fbo, &filter->depthbuffer, &filter->texture);
|
||||||
|
}
|
||||||
|
|
||||||
gl_outbuf = gst_gl_buffer_new_from_video_format (filter->display,
|
gl_outbuf = gst_gl_buffer_new_from_video_format (filter->display,
|
||||||
filter->video_format,
|
filter->video_format,
|
||||||
|
@ -256,74 +263,7 @@ gst_gl_filter_do_transform (GstGLFilter * filter,
|
||||||
GstGLDisplay* display = inbuf->display;
|
GstGLDisplay* display = inbuf->display;
|
||||||
GstGLFilterClass* filter_class = GST_GL_FILTER_GET_CLASS (filter);
|
GstGLFilterClass* filter_class = GST_GL_FILTER_GET_CLASS (filter);
|
||||||
|
|
||||||
outbuf->texture = inbuf->texture;
|
|
||||||
|
|
||||||
/*unsigned int fbo;
|
|
||||||
|
|
||||||
gst_gl_display_lock (display);
|
|
||||||
|
|
||||||
glGenFramebuffersEXT (1, &fbo);
|
|
||||||
glBindFramebufferEXT (GL_FRAMEBUFFER_EXT, fbo);
|
|
||||||
|
|
||||||
glFramebufferTexture2DEXT (GL_FRAMEBUFFER_EXT,
|
|
||||||
GL_COLOR_ATTACHMENT0_EXT, GL_TEXTURE_RECTANGLE_ARB, outbuf->texture, 0);
|
|
||||||
|
|
||||||
glDrawBuffer (GL_COLOR_ATTACHMENT0_EXT);
|
|
||||||
glReadBuffer (GL_COLOR_ATTACHMENT0_EXT);
|
|
||||||
|
|
||||||
g_assert (glCheckFramebufferStatusEXT (GL_FRAMEBUFFER_EXT) ==
|
|
||||||
GL_FRAMEBUFFER_COMPLETE_EXT);
|
|
||||||
|
|
||||||
glViewport (0, 0, outbuf->width, outbuf->height);
|
|
||||||
|
|
||||||
glClearColor (0.3, 0.3, 0.3, 1.0);
|
|
||||||
glClear (GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
|
||||||
|
|
||||||
glMatrixMode (GL_PROJECTION);
|
|
||||||
glLoadIdentity ();
|
|
||||||
|
|
||||||
glMatrixMode (GL_MODELVIEW);
|
|
||||||
glLoadIdentity ();
|
|
||||||
|
|
||||||
glDisable (GL_CULL_FACE);
|
|
||||||
glEnableClientState (GL_TEXTURE_COORD_ARRAY);
|
|
||||||
|
|
||||||
glColor4f (1, 1, 1, 1);
|
|
||||||
|
|
||||||
glEnable (GL_TEXTURE_RECTANGLE_ARB);
|
|
||||||
glActiveTexture (GL_TEXTURE0);
|
|
||||||
glBindTexture (GL_TEXTURE_RECTANGLE_ARB, inbuf->texture);*/
|
|
||||||
|
|
||||||
filter_class->filter (filter, inbuf, outbuf);
|
filter_class->filter (filter, inbuf, outbuf);
|
||||||
/*
|
|
||||||
#if 0
|
|
||||||
glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
|
||||||
glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
|
|
||||||
glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_WRAP_S, GL_CLAMP);
|
|
||||||
glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_WRAP_T, GL_CLAMP);
|
|
||||||
glTexEnvi (GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE);
|
|
||||||
|
|
||||||
glColor4f (1, 0, 1, 1);
|
|
||||||
glBegin (GL_QUADS);
|
|
||||||
|
|
||||||
glNormal3f (0, 0, -1);
|
|
||||||
|
|
||||||
glTexCoord2f (inbuf->width, 0);
|
|
||||||
glVertex3f (0.9, -0.9, 0);
|
|
||||||
glTexCoord2f (0, 0);
|
|
||||||
glVertex3f (-1.0, -1.0, 0);
|
|
||||||
glTexCoord2f (0, inbuf->height);
|
|
||||||
glVertex3f (-1.0, 1.0, 0);
|
|
||||||
glTexCoord2f (inbuf->width, inbuf->height);
|
|
||||||
glVertex3f (1.0, 1.0, 0);
|
|
||||||
glEnd ();
|
|
||||||
#endif
|
|
||||||
|
|
||||||
glFlush ();
|
|
||||||
|
|
||||||
glDeleteFramebuffersEXT (1, &fbo);
|
|
||||||
|
|
||||||
gst_gl_display_unlock (display);*/
|
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
|
@ -48,8 +48,11 @@ struct _GstGLFilter
|
||||||
|
|
||||||
GstGLDisplay *display;
|
GstGLDisplay *display;
|
||||||
GstVideoFormat video_format;
|
GstVideoFormat video_format;
|
||||||
int width;
|
gint width;
|
||||||
int height;
|
gint height;
|
||||||
|
guint fbo;
|
||||||
|
guint depthbuffer;
|
||||||
|
guint texture;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct _GstGLFilterClass
|
struct _GstGLFilterClass
|
||||||
|
|
|
@ -51,6 +51,7 @@ static void gst_gl_filter_cube_get_property (GObject * object, guint prop_id,
|
||||||
|
|
||||||
static gboolean gst_gl_filter_cube_filter (GstGLFilter * filter,
|
static gboolean gst_gl_filter_cube_filter (GstGLFilter * filter,
|
||||||
GstGLBuffer * inbuf, GstGLBuffer * outbuf);
|
GstGLBuffer * inbuf, GstGLBuffer * outbuf);
|
||||||
|
static void gst_gl_filter_cube_callback (guint width, guint height, guint texture);
|
||||||
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
@ -85,7 +86,8 @@ gst_gl_filter_cube_set_property (GObject * object, guint prop_id,
|
||||||
{
|
{
|
||||||
//GstGLFilterCube *filter = GST_GL_FILTER_CUBE (object);
|
//GstGLFilterCube *filter = GST_GL_FILTER_CUBE (object);
|
||||||
|
|
||||||
switch (prop_id) {
|
switch (prop_id)
|
||||||
|
{
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
@ -98,7 +100,8 @@ gst_gl_filter_cube_get_property (GObject * object, guint prop_id,
|
||||||
{
|
{
|
||||||
//GstGLFilterCube *filter = GST_GL_FILTER_CUBE (object);
|
//GstGLFilterCube *filter = GST_GL_FILTER_CUBE (object);
|
||||||
|
|
||||||
switch (prop_id) {
|
switch (prop_id)
|
||||||
|
{
|
||||||
default:
|
default:
|
||||||
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
|
||||||
break;
|
break;
|
||||||
|
@ -109,79 +112,86 @@ static gboolean
|
||||||
gst_gl_filter_cube_filter (GstGLFilter* filter, GstGLBuffer* inbuf,
|
gst_gl_filter_cube_filter (GstGLFilter* filter, GstGLBuffer* inbuf,
|
||||||
GstGLBuffer* outbuf)
|
GstGLBuffer* outbuf)
|
||||||
{
|
{
|
||||||
GstGLFilterCube* cube = GST_GL_FILTER_CUBE(filter);
|
GstGLFilterCube* cube_filter = GST_GL_FILTER_CUBE(filter);
|
||||||
|
|
||||||
g_print ("gstglfiltercube: gst_gl_filter_cube_filter\n");
|
g_print ("gstglfiltercube: gst_gl_filter_cube_filter\n");
|
||||||
/*int i, j;
|
|
||||||
double *vertex_x, *vertex_y;
|
|
||||||
|
|
||||||
glDisable (GL_CULL_FACE);
|
//blocking call, generate a FBO
|
||||||
glEnableClientState (GL_TEXTURE_COORD_ARRAY);
|
gst_gl_display_useFBO (filter->display, filter->width, filter->height,
|
||||||
|
filter->fbo, filter->depthbuffer, filter->texture, gst_gl_filter_cube_callback,
|
||||||
|
inbuf->width, inbuf->height, inbuf->texture);
|
||||||
|
|
||||||
glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
outbuf->width = filter->width;
|
||||||
glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
|
outbuf->height = filter->height;
|
||||||
glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_WRAP_S, GL_CLAMP);
|
outbuf->texture = filter->texture;
|
||||||
glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_WRAP_T, GL_CLAMP);
|
|
||||||
glTexEnvi (GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE);
|
|
||||||
|
|
||||||
glColor4f (1, 0, 1, 1);
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
glMatrixMode (GL_COLOR);
|
|
||||||
glLoadMatrixd (matrix);
|
|
||||||
glPixelTransferf (GL_POST_COLOR_MATRIX_RED_BIAS, (1 - GAIN) / 2);
|
|
||||||
glPixelTransferf (GL_POST_COLOR_MATRIX_GREEN_BIAS, (1 - GAIN) / 2);
|
|
||||||
glPixelTransferf (GL_POST_COLOR_MATRIX_BLUE_BIAS, (1 - GAIN) / 2);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define N 10
|
|
||||||
#define SCALE (1.0/N)
|
|
||||||
#define NOISE() (0.1*SCALE*g_random_double_range(-1,1))
|
|
||||||
vertex_x = malloc (sizeof (double) * (N + 1) * (N + 1));
|
|
||||||
vertex_y = malloc (sizeof (double) * (N + 1) * (N + 1));
|
|
||||||
for (j = 0; j < N + 1; j++) {
|
|
||||||
for (i = 0; i < N + 1; i++) {
|
|
||||||
vertex_x[j * (N + 1) + i] = i * SCALE + NOISE ();
|
|
||||||
vertex_y[j * (N + 1) + i] = j * SCALE + NOISE ();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
for (j = 0; j < N; j++) {
|
|
||||||
for (i = 0; i < N; i++) {
|
|
||||||
glBegin (GL_QUADS);
|
|
||||||
glNormal3f (0, 0, -1);
|
|
||||||
glTexCoord2f (i * SCALE, j * SCALE);
|
|
||||||
glVertex3f (vertex_x[j * (N + 1) + i], vertex_y[j * (N + 1) + i], 0);
|
|
||||||
glTexCoord2f ((i + 1) * SCALE, j * SCALE);
|
|
||||||
glVertex3f (vertex_x[j * (N + 1) + (i + 1)],
|
|
||||||
vertex_y[j * (N + 1) + (i + 1)], 0);
|
|
||||||
glTexCoord2f ((i + 1) * SCALE, (j + 1) * SCALE);
|
|
||||||
glVertex3f (vertex_x[(j + 1) * (N + 1) + (i + 1)],
|
|
||||||
vertex_y[(j + 1) * (N + 1) + (i + 1)], 0);
|
|
||||||
glTexCoord2f (i * SCALE, (j + 1) * SCALE);
|
|
||||||
glVertex3f (vertex_x[(j + 1) * (N + 1) + i],
|
|
||||||
vertex_y[(j + 1) * (N + 1) + i], 0);
|
|
||||||
glEnd ();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
free (vertex_x);
|
|
||||||
free (vertex_y);
|
|
||||||
|
|
||||||
|
|
||||||
glFlush ();
|
|
||||||
|
|
||||||
glMatrixMode (GL_MODELVIEW);
|
|
||||||
glLoadIdentity ();
|
|
||||||
glMatrixMode (GL_TEXTURE);
|
|
||||||
glLoadIdentity ();
|
|
||||||
glMatrixMode (GL_COLOR);
|
|
||||||
glLoadIdentity ();
|
|
||||||
glPixelTransferf (GL_POST_COLOR_MATRIX_RED_SCALE, 1.0);
|
|
||||||
glPixelTransferf (GL_POST_COLOR_MATRIX_RED_BIAS, 0);
|
|
||||||
glPixelTransferf (GL_POST_COLOR_MATRIX_GREEN_BIAS, 0);
|
|
||||||
glPixelTransferf (GL_POST_COLOR_MATRIX_BLUE_BIAS, 0);*/
|
|
||||||
|
|
||||||
return TRUE;
|
return TRUE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//opengl scene, params: input texture (not the output filter->texture)
|
||||||
|
static void
|
||||||
|
gst_gl_filter_cube_callback (guint width, guint height, guint texture)
|
||||||
|
{
|
||||||
|
static GLfloat xrot = 0;
|
||||||
|
static GLfloat yrot = 0;
|
||||||
|
static GLfloat zrot = 0;
|
||||||
|
|
||||||
|
g_print ("gstglfiltercube: gst_gl_filter_cube_callback\n");
|
||||||
|
|
||||||
|
glEnable(GL_DEPTH_TEST);
|
||||||
|
|
||||||
|
glEnable (GL_TEXTURE_RECTANGLE_ARB);
|
||||||
|
glBindTexture (GL_TEXTURE_RECTANGLE_ARB, texture);
|
||||||
|
glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_MAG_FILTER, GL_LINEAR);
|
||||||
|
glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_MIN_FILTER, GL_LINEAR);
|
||||||
|
glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_WRAP_S, GL_CLAMP_TO_EDGE);
|
||||||
|
glTexParameteri (GL_TEXTURE_RECTANGLE_ARB, GL_TEXTURE_WRAP_T, GL_CLAMP_TO_EDGE);
|
||||||
|
glTexEnvi (GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_REPLACE);
|
||||||
|
|
||||||
|
glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||||
|
glMatrixMode(GL_MODELVIEW);
|
||||||
|
glLoadIdentity();
|
||||||
|
|
||||||
|
glTranslatef(0.0f,0.0f,-5.0f);
|
||||||
|
|
||||||
|
glRotatef(xrot,1.0f,0.0f,0.0f);
|
||||||
|
glRotatef(yrot,0.0f,1.0f,0.0f);
|
||||||
|
glRotatef(zrot,0.0f,0.0f,1.0f);
|
||||||
|
|
||||||
|
glBegin(GL_QUADS);
|
||||||
|
// Front Face
|
||||||
|
glTexCoord2f((gfloat)width, 0.0f); glVertex3f(-1.0f, -1.0f, 1.0f);
|
||||||
|
glTexCoord2f(0.0f, 0.0f); glVertex3f( 1.0f, -1.0f, 1.0f);
|
||||||
|
glTexCoord2f(0.0f, (gfloat)height); glVertex3f( 1.0f, 1.0f, 1.0f);
|
||||||
|
glTexCoord2f((gfloat)width, (gfloat)height); glVertex3f(-1.0f, 1.0f, 1.0f);
|
||||||
|
// Back Face
|
||||||
|
glTexCoord2f(0.0f, 0.0f); glVertex3f(-1.0f, -1.0f, -1.0f);
|
||||||
|
glTexCoord2f(0.0f, (gfloat)height); glVertex3f(-1.0f, 1.0f, -1.0f);
|
||||||
|
glTexCoord2f((gfloat)width, (gfloat)height); glVertex3f( 1.0f, 1.0f, -1.0f);
|
||||||
|
glTexCoord2f((gfloat)width, 0.0f); glVertex3f( 1.0f, -1.0f, -1.0f);
|
||||||
|
// Top Face
|
||||||
|
glTexCoord2f((gfloat)width, (gfloat)height); glVertex3f(-1.0f, 1.0f, -1.0f);
|
||||||
|
glTexCoord2f((gfloat)width, 0.0f); glVertex3f(-1.0f, 1.0f, 1.0f);
|
||||||
|
glTexCoord2f(0.0f, 0.0f); glVertex3f( 1.0f, 1.0f, 1.0f);
|
||||||
|
glTexCoord2f(0.0f, (gfloat)height); glVertex3f( 1.0f, 1.0f, -1.0f);
|
||||||
|
// Bottom Face
|
||||||
|
glTexCoord2f((gfloat)width, 0.0f); glVertex3f(-1.0f, -1.0f, -1.0f);
|
||||||
|
glTexCoord2f(0.0f, 0.0f); glVertex3f( 1.0f, -1.0f, -1.0f);
|
||||||
|
glTexCoord2f(0.0f, (gfloat)height); glVertex3f( 1.0f, -1.0f, 1.0f);
|
||||||
|
glTexCoord2f((gfloat)width,(gfloat)height); glVertex3f(-1.0f, -1.0f, 1.0f);
|
||||||
|
// Right face
|
||||||
|
glTexCoord2f(0.0f, 0.0f); glVertex3f( 1.0f, -1.0f, -1.0f);
|
||||||
|
glTexCoord2f(0.0f, (gfloat)height); glVertex3f( 1.0f, 1.0f, -1.0f);
|
||||||
|
glTexCoord2f((gfloat)width, (gfloat)height); glVertex3f( 1.0f, 1.0f, 1.0f);
|
||||||
|
glTexCoord2f((gfloat)width, 0.0f); glVertex3f( 1.0f, -1.0f, 1.0f);
|
||||||
|
// Left Face
|
||||||
|
glTexCoord2f((gfloat)width, 0.0f); glVertex3f(-1.0f, -1.0f, -1.0f);
|
||||||
|
glTexCoord2f(0.0f, 0.0f); glVertex3f(-1.0f, -1.0f, 1.0f);
|
||||||
|
glTexCoord2f(0.0f, (gfloat)height); glVertex3f(-1.0f, 1.0f, 1.0f);
|
||||||
|
glTexCoord2f((gfloat)width, (gfloat)height); glVertex3f(-1.0f, 1.0f, -1.0f);
|
||||||
|
glEnd();
|
||||||
|
|
||||||
|
xrot+=0.3f;
|
||||||
|
yrot+=0.2f;
|
||||||
|
zrot+=0.4f;
|
||||||
|
}
|
||||||
|
|
|
@ -168,7 +168,8 @@ gst_glimage_sink_set_property (GObject * object, guint prop_id,
|
||||||
|
|
||||||
glimage_sink = GST_GLIMAGE_SINK (object);
|
glimage_sink = GST_GLIMAGE_SINK (object);
|
||||||
|
|
||||||
switch (prop_id) {
|
switch (prop_id)
|
||||||
|
{
|
||||||
case ARG_DISPLAY:
|
case ARG_DISPLAY:
|
||||||
g_free (glimage_sink->display_name);
|
g_free (glimage_sink->display_name);
|
||||||
glimage_sink->display_name = g_strdup (g_value_get_string (value));
|
glimage_sink->display_name = g_strdup (g_value_get_string (value));
|
||||||
|
@ -188,9 +189,9 @@ gst_glimage_sink_finalize (GObject * object)
|
||||||
|
|
||||||
glimage_sink = GST_GLIMAGE_SINK (object);
|
glimage_sink = GST_GLIMAGE_SINK (object);
|
||||||
|
|
||||||
if (glimage_sink->caps) {
|
if (glimage_sink->caps)
|
||||||
gst_caps_unref (glimage_sink->caps);
|
gst_caps_unref (glimage_sink->caps);
|
||||||
}
|
|
||||||
g_free (glimage_sink->display_name);
|
g_free (glimage_sink->display_name);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -204,7 +205,8 @@ gst_glimage_sink_get_property (GObject * object, guint prop_id,
|
||||||
|
|
||||||
glimage_sink = GST_GLIMAGE_SINK (object);
|
glimage_sink = GST_GLIMAGE_SINK (object);
|
||||||
|
|
||||||
switch (prop_id) {
|
switch (prop_id)
|
||||||
|
{
|
||||||
case ARG_DISPLAY:
|
case ARG_DISPLAY:
|
||||||
g_value_set_string (value, glimage_sink->display_name);
|
g_value_set_string (value, glimage_sink->display_name);
|
||||||
break;
|
break;
|
||||||
|
@ -228,7 +230,8 @@ gst_glimage_sink_change_state (GstElement * element, GstStateChange transition)
|
||||||
|
|
||||||
glimage_sink = GST_GLIMAGE_SINK (element);
|
glimage_sink = GST_GLIMAGE_SINK (element);
|
||||||
|
|
||||||
switch (transition) {
|
switch (transition)
|
||||||
|
{
|
||||||
case GST_STATE_CHANGE_NULL_TO_READY:
|
case GST_STATE_CHANGE_NULL_TO_READY:
|
||||||
break;
|
break;
|
||||||
case GST_STATE_CHANGE_READY_TO_PAUSED:
|
case GST_STATE_CHANGE_READY_TO_PAUSED:
|
||||||
|
@ -243,7 +246,8 @@ gst_glimage_sink_change_state (GstElement * element, GstStateChange transition)
|
||||||
if (ret == GST_STATE_CHANGE_FAILURE)
|
if (ret == GST_STATE_CHANGE_FAILURE)
|
||||||
return ret;
|
return ret;
|
||||||
|
|
||||||
switch (transition) {
|
switch (transition)
|
||||||
|
{
|
||||||
case GST_STATE_CHANGE_PLAYING_TO_PAUSED:
|
case GST_STATE_CHANGE_PLAYING_TO_PAUSED:
|
||||||
break;
|
break;
|
||||||
case GST_STATE_CHANGE_PAUSED_TO_READY:
|
case GST_STATE_CHANGE_PAUSED_TO_READY:
|
||||||
|
|
Loading…
Reference in a new issue