X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fbackends%2Fopengl%2Ftexturecube_backend.cpp;h=1cc3f8377f23eaf3027d8e54caeb58f83dbefd7b;hb=8a8cce8ef4ee28b3572a72958b8b407759f9f826;hp=cc8945896fea9bdaad6763e4eedda5af50df859c;hpb=57ca8f2bd18525d80ed6ad5d3f72e57901162d55;p=libs%2Fgl.git diff --git a/source/backends/opengl/texturecube_backend.cpp b/source/backends/opengl/texturecube_backend.cpp index cc894589..1cc3f837 100644 --- a/source/backends/opengl/texturecube_backend.cpp +++ b/source/backends/opengl/texturecube_backend.cpp @@ -32,7 +32,7 @@ void OpenGLTextureCube::allocate() unsigned levels = static_cast(this)->levels; if(!id) - generate_id(); + create(); GLenum gl_fmt = get_gl_pixelformat(storage_fmt); if(ARB_texture_storage) @@ -75,6 +75,22 @@ void OpenGLTextureCube::sub_image(unsigned face, unsigned level, int x, int y, u } } +size_t OpenGLTextureCube::get_data_size() const +{ + if(!id) + return 0; + + unsigned size = static_cast(this)->size; + unsigned levels = static_cast(this)->levels; + + size_t level_size = size*size*get_pixel_size(storage_fmt); + size_t total_size = level_size; + for(unsigned i=0; i>=2) + total_size += level_size; + return total_size; +} + + unsigned get_gl_cube_face(unsigned face) { switch(static_cast(face))