From 6fe15aefb0c67c6edc5cbe53a6b166c5f89cb0ad Mon Sep 17 00:00:00 2001 From: Matthew Allum Date: Fri, 13 Jun 2008 23:03:45 +0000 Subject: [PATCH] 2008-06-14 Matthew Allum * README: Make needed GL version 1.4, note GLES2 support, add some notes for COGL. --- gl/cogl-defines.h.in | 2 ++ gl/cogl-texture.c | 73 +++++++++++++++++++++++++++++++++++++++++--- gl/cogl-texture.h | 1 + 3 files changed, 72 insertions(+), 4 deletions(-) diff --git a/gl/cogl-defines.h.in b/gl/cogl-defines.h.in index a93f9f030..3beeddcaf 100644 --- a/gl/cogl-defines.h.in +++ b/gl/cogl-defines.h.in @@ -26,6 +26,8 @@ #ifndef __COGL_DEFINES_H__ #define __COGL_DEFINES_H__ +#define GL_GLEXT_PROTOTYPES 1 + #include <@CLUTTER_GL_HEADER@> G_BEGIN_DECLS diff --git a/gl/cogl-texture.c b/gl/cogl-texture.c index 24f37b9b1..ae2e722a6 100644 --- a/gl/cogl-texture.c +++ b/gl/cogl-texture.c @@ -38,6 +38,9 @@ #include #include +// #define HAVE_PBOS 1 +#include + /* #define COGL_DEBUG 1 @@ -244,7 +247,39 @@ _cogl_texture_upload_to_gl (CoglTexture *tex) x_span->start, y_span->start, FALSE); + { +#if HAVE_PBOS + void *io_mem; + GLuint buf; + + buf = g_array_index (tex->slice_buf_handles, GLuint, + y * tex->slice_x_spans->len + x); + + glBindBuffer (GL_PIXEL_UNPACK_BUFFER_ARB, buf); + glBufferData (GL_PIXEL_UNPACK_BUFFER_ARB, + tex->bitmap.height * tex->bitmap.rowstride, + NULL, + GL_STREAM_DRAW); + + io_mem = glMapBuffer (GL_PIXEL_UNPACK_BUFFER_ARB, GL_WRITE_ONLY); + + g_assert (io_mem); + memcpy (io_mem, tex->bitmap.data, + tex->bitmap.height * tex->bitmap.rowstride); + + GE( glUnmapBuffer(GL_PIXEL_UNPACK_BUFFER_ARB) ); + + GE( glBindTexture (tex->gl_target, gl_handle) ); + + GE( glTexSubImage2D (tex->gl_target, 0, 0, 0, + x_span->size - x_span->waste, + y_span->size - y_span->waste, + tex->gl_format, tex->gl_type, + (char *)NULL) ); + + GE( glBindBuffer(GL_PIXEL_UNPACK_BUFFER_ARB, 0) ); +#else /* Upload new image data */ GE( glBindTexture (tex->gl_target, gl_handle) ); @@ -253,6 +288,8 @@ _cogl_texture_upload_to_gl (CoglTexture *tex) y_span->size - y_span->waste, tex->gl_format, tex->gl_type, tex->bitmap.data) ); +#endif + } } } @@ -568,6 +605,9 @@ _cogl_texture_slices_create (CoglTexture *tex) gint max_width; gint max_height; GLuint *gl_handles; +#if HAVE_PBOS + GLuint *buf_handles; +#endif gint n_x_slices; gint n_y_slices; gint n_slices; @@ -703,7 +743,17 @@ _cogl_texture_slices_create (CoglTexture *tex) gl_handles = (GLuint*) tex->slice_gl_handles->data; GE( glGenTextures (n_slices, gl_handles) ); + +#if HAVE_PBOS + tex->slice_buf_handles = g_array_sized_new (FALSE, FALSE, + sizeof (GLuint), + n_slices); + g_array_set_size (tex->slice_buf_handles, n_slices); + buf_handles = (GLuint*) tex->slice_buf_handles->data; + + GE( glGenBuffers(n_slices, buf_handles) ); +#endif /* Init each GL texture object */ for (y = 0; y < n_y_slices; ++y) @@ -712,8 +762,11 @@ _cogl_texture_slices_create (CoglTexture *tex) for (x = 0; x < n_x_slices; ++x) { +#if HAVE_PBOS + glBindBuffer(GL_PIXEL_UNPACK_BUFFER_ARB, 0); +#endif x_span = &g_array_index (tex->slice_x_spans, CoglTexSliceSpan, x); - + #if COGL_DEBUG printf ("CREATE SLICE (%d,%d)\n", x,y); printf ("size: (%d x %d)\n", @@ -721,9 +774,12 @@ _cogl_texture_slices_create (CoglTexture *tex) y_span->size - y_span->waste); #endif /* Setup texture parameters */ - GE( glBindTexture (tex->gl_target, gl_handles[y * n_x_slices + x]) ); - GE( glTexParameteri (tex->gl_target, GL_TEXTURE_MAG_FILTER, tex->mag_filter) ); - GE( glTexParameteri (tex->gl_target, GL_TEXTURE_MIN_FILTER, tex->min_filter) ); + GE( glBindTexture (tex->gl_target, + gl_handles[y * n_x_slices + x]) ); + GE( glTexParameteri (tex->gl_target, + GL_TEXTURE_MAG_FILTER, tex->mag_filter) ); + GE( glTexParameteri (tex->gl_target, + GL_TEXTURE_MIN_FILTER, tex->min_filter) ); GE( glTexParameteri (tex->gl_target, GL_TEXTURE_WRAP_S, tex->wrap_mode) ); @@ -768,6 +824,15 @@ _cogl_texture_slices_free (CoglTexture *tex) g_array_free (tex->slice_gl_handles, TRUE); } + +#if HAVE_PBOS + if (tex->slice_buf_handles != NULL) + { + glDeleteBuffers(tex->slice_buf_handles->len, + (GLuint*) tex->slice_buf_handles->data); + + } +#endif } static gboolean diff --git a/gl/cogl-texture.h b/gl/cogl-texture.h index 117437458..3dfed0993 100644 --- a/gl/cogl-texture.h +++ b/gl/cogl-texture.h @@ -51,6 +51,7 @@ struct _CoglTexture GArray *slice_x_spans; GArray *slice_y_spans; GArray *slice_gl_handles; + GArray *slice_buf_handles; gint max_waste; COGLenum min_filter; COGLenum mag_filter;