From 99484ceda65aa659af28e1ec9a366284c022e802 Mon Sep 17 00:00:00 2001 From: Mathieu Virbel Date: Sun, 4 Nov 2012 22:29:20 +0100 Subject: [PATCH] texture: if a non-npot texture with mipmap has been requested, force the allocation before doing a glTexSubImage2d, and delay the mipmap generation to prevent double generation. Closes #781, #782, #656 --- kivy/graphics/texture.pyx | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/kivy/graphics/texture.pyx b/kivy/graphics/texture.pyx index a88810531..352dfc6b1 100644 --- a/kivy/graphics/texture.pyx +++ b/kivy/graphics/texture.pyx @@ -409,12 +409,13 @@ cdef Texture _texture_create(int width, int height, str colorfmt, str bufferfmt, cdef int texture_width, texture_height cdef int glbufferfmt = _buffer_fmt_to_gl(bufferfmt) cdef int make_npot = 0 + cdef int is_npot = 0 cdef int glfmt, iglbufferfmt, datasize, dataerr = 0 cdef void *data = NULL # check if it's a pot or not if not _is_pow2(width) or not _is_pow2(height): - make_npot = 1 + make_npot = is_npot = 1 IF not USE_OPENGL_ES2: if gl_get_version_major() < 3: @@ -423,6 +424,7 @@ cdef Texture _texture_create(int width, int height, str colorfmt, str bufferfmt, # in case of mipmap is asked for npot texture, make it pot compatible if mipmap: make_npot = 0 + allocate = 1 # depending if npot is available, use the real size or pot size if make_npot and gl_has_capability(c_GLCAP_NPOT): @@ -480,7 +482,7 @@ cdef Texture _texture_create(int width, int height, str colorfmt, str bufferfmt, free(data) # create mipmap if needed - if mipmap: + if mipmap and is_npot == 0: glGenerateMipmap(target) else: dataerr = 1