[cogl/wip/gles2-context: 4/6] framebuffer: Create a depth buffer for the foreign context
- From: Tomeu Vizoso <tomeuv src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [cogl/wip/gles2-context: 4/6] framebuffer: Create a depth buffer for the foreign context
- Date: Wed, 14 Dec 2011 19:03:46 +0000 (UTC)
commit ebbe60e83c962ecfcb0bfca3c1adfa8efbafcb35
Author: Tomeu Vizoso <tomeu vizoso collabora com>
Date: Wed Dec 14 09:56:12 2011 +0100
framebuffer: Create a depth buffer for the foreign context
cogl/cogl-framebuffer.c | 23 +++++++++++++++++++++++
1 files changed, 23 insertions(+), 0 deletions(-)
---
diff --git a/cogl/cogl-framebuffer.c b/cogl/cogl-framebuffer.c
index 0c16261..5c698f2 100644
--- a/cogl/cogl-framebuffer.c
+++ b/cogl/cogl-framebuffer.c
@@ -2420,16 +2420,21 @@ cogl_framebuffer_push_gles2_context (CoglFramebuffer *framebuffer,
GLuint tex_gl_handle;
GLenum tex_gl_target;
GLuint fbo_gl_handle;
+ GLuint gl_stencil_handle;
+ gint width, height;
gboolean result;
+ GLenum status;
if (!cogl_has_feature (ctx, COGL_FEATURE_ID_GLES2_CONTEXT))
return FALSE;
+ /* Make current the GL context being pushed */
winsys = ctx->display->renderer->winsys_vtable;
result = winsys->make_current (gles2_ctx, error);
if (!result)
return FALSE;
+ /* Ensure we have a framebuffer in this context */
fbo_gl_handle = cogl_object_get_user_data (COGL_OBJECT (framebuffer), gles2_ctx);
if (fbo_gl_handle == 0)
{
@@ -2437,6 +2442,7 @@ cogl_framebuffer_push_gles2_context (CoglFramebuffer *framebuffer,
cogl_object_set_user_data (COGL_OBJECT (framebuffer), gles2_ctx, fbo_gl_handle, NULL);
}
+ /* Bind the new framebuffer */
GE (ctx, glBindFramebuffer (GL_FRAMEBUFFER, fbo_gl_handle));
if (!cogl_texture_get_gl_texture (offscreen->texture,
@@ -2447,6 +2453,23 @@ cogl_framebuffer_push_gles2_context (CoglFramebuffer *framebuffer,
tex_gl_target, tex_gl_handle,
offscreen->texture_level));
+ /* Create the depth buffer */
+ width = offscreen->texture_level_width;
+ height = offscreen->texture_level_height;
+
+ /* FIXME: should keep a reference for deleting */
+ GE (ctx, glGenRenderbuffers (1, &gl_stencil_handle));
+ GE (ctx, glBindRenderbuffer (GL_RENDERBUFFER, gl_stencil_handle));
+ GE (ctx, glRenderbufferStorage (GL_RENDERBUFFER, GL_STENCIL_INDEX8,
+ width, height));
+ GE (ctx, glBindRenderbuffer (GL_RENDERBUFFER, 0));
+ GE (ctx, glFramebufferRenderbuffer (GL_FRAMEBUFFER,
+ GL_STENCIL_ATTACHMENT,
+ GL_RENDERBUFFER, gl_stencil_handle));
+
+ status = ctx->glCheckFramebufferStatus (GL_FRAMEBUFFER);
+ g_return_val_if_fail (status == GL_FRAMEBUFFER_COMPLETE, FALSE);
+
return TRUE;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]