From f3a4a969c095b5bc6111b6a31ca9c5482d94bfb0 Mon Sep 17 00:00:00 2001 From: dg <dg@51575b47-30f0-44d4-a5cc-537603b46e54> Date: Mon, 4 Jan 2010 13:04:04 +0000 Subject: [PATCH] always power of 2 textures This is CRUDE, it needs to not create/blit a surface each time ! git-svn-id: http://svn.net-core.org/repos/t-engine4@194 51575b47-30f0-44d4-a5cc-537603b46e54 --- game/engine/Dialog.lua | 4 +- game/modules/tome/class/Game.lua | 2 +- src/core_lua.c | 166 +++++++++++++++++++++---------- 3 files changed, 117 insertions(+), 55 deletions(-) diff --git a/game/engine/Dialog.lua b/game/engine/Dialog.lua index 5c45bb4bd3..576bd6e776 100644 --- a/game/engine/Dialog.lua +++ b/game/engine/Dialog.lua @@ -33,7 +33,7 @@ function _M:init(title, w, h, x, y, alpha, font) self.iw, self.ih = w - 2 * 5, h - 8 - 16 - 3 self.internal_surface = core.display.newSurface(self.iw, self.ih) self.surface:alpha(alpha or 220) - self.texture = self.surface:glTexture() + self.texture = self.surface:glTexture2() self.changed = true end @@ -60,7 +60,7 @@ function _M:display() local tw, th = self.font:size(self.title) s:drawColorString(self.font, self.title, (self.w - tw) / 2, 4, 255,255,255) - self.internal_surface:erase() + self.internal_surface:erase(0, 0, 0, 200) self:drawDialog(self.internal_surface) s:merge(self.internal_surface, 5, 20 + 3) diff --git a/game/modules/tome/class/Game.lua b/game/modules/tome/class/Game.lua index e15ac847d3..c6e3d41b86 100644 --- a/game/modules/tome/class/Game.lua +++ b/game/modules/tome/class/Game.lua @@ -69,7 +69,7 @@ function _M:run() -- Ok everything is good to go, activate the game in the engine! self:setCurrent() - self:setupDisplayMode() + if self.level then self:setupDisplayMode() end end function _M:newGame() diff --git a/src/core_lua.c b/src/core_lua.c index a945b83d90..b878622967 100644 --- a/src/core_lua.c +++ b/src/core_lua.c @@ -359,6 +359,7 @@ static int sdl_surface_drawstring(lua_State *L) SDL_Surface *txt = TTF_RenderUTF8_Solid(*f, str, color); if (txt) { + SDL_SetAlpha(txt, 0, 0); sdlDrawImage(*s, txt, x, y); SDL_FreeSurface(txt); } @@ -389,7 +390,34 @@ static int sdl_surface_drawstring_newsurface(lua_State *L) return 1; } +static SDL_Surface *make_surface(int w, int h) +{ + Uint32 rmask, gmask, bmask, amask; +#if SDL_BYTEORDER == SDL_BIG_ENDIAN + rmask = 0xff000000; + gmask = 0x00ff0000; + bmask = 0x0000ff00; + amask = 0x000000ff; +#else + rmask = 0x000000ff; + gmask = 0x0000ff00; + bmask = 0x00ff0000; + amask = 0xff000000; +#endif + + SDL_Surface *s = SDL_CreateRGBSurface( + SDL_SWSURFACE | SDL_SRCALPHA, + w, + h, + 32, + rmask, gmask, bmask, amask + ); + + if (s == NULL) + printf("ERROR : SDL_CreateRGBSurface : %s\n",SDL_GetError()); + return s; +} static int sdl_new_tile(lua_State *L) { @@ -413,26 +441,7 @@ static int sdl_new_tile(lua_State *L) SDL_Surface **s = (SDL_Surface**)lua_newuserdata(L, sizeof(SDL_Surface*)); auxiliar_setclass(L, "sdl{surface}", -1); - Uint32 rmask, gmask, bmask, amask; -#if SDL_BYTEORDER == SDL_BIG_ENDIAN - rmask = 0xff000000; - gmask = 0x00ff0000; - bmask = 0x0000ff00; - amask = 0x000000ff; -#else - rmask = 0x000000ff; - gmask = 0x0000ff00; - bmask = 0x00ff0000; - amask = 0xff000000; -#endif - - *s = SDL_CreateRGBSurface( - SDL_SWSURFACE | SDL_SRCALPHA, - w, - h, - 32, - rmask, gmask, bmask, amask - ); + *s = make_surface(w, h); SDL_FillRect(*s, NULL, SDL_MapRGBA((*s)->format, br, bg, bb, alpha)); @@ -453,31 +462,7 @@ static int sdl_new_surface(lua_State *L) SDL_Surface **s = (SDL_Surface**)lua_newuserdata(L, sizeof(SDL_Surface*)); auxiliar_setclass(L, "sdl{surface}", -1); - - Uint32 rmask, gmask, bmask, amask; -#if SDL_BYTEORDER == SDL_BIG_ENDIAN - rmask = 0xff000000; - gmask = 0x00ff0000; - bmask = 0x0000ff00; - amask = 0x000000ff; -#else - rmask = 0x000000ff; - gmask = 0x0000ff00; - bmask = 0x00ff0000; - amask = 0xff000000; -#endif - - *s = SDL_CreateRGBSurface( - SDL_SWSURFACE | SDL_SRCALPHA, - w, - h, - 32, - rmask, gmask, bmask, amask - ); - - if (s == NULL) - printf("ERROR : SDL_CreateRGBSurface : %s\n",SDL_GetError()); - + *s = make_surface(w, h); return 1; } @@ -576,6 +561,16 @@ static int sdl_surface_toscreen(lua_State *L) int x = luaL_checknumber(L, 2); int y = luaL_checknumber(L, 3); + int nw = 1, nh = 1; + while (nw < (*s)->w) nw *= 2; + while (nh < (*s)->h) nh *= 2; + if (nw > nh) nh = nw; + else nw = nh; + SDL_Surface *st = make_surface(nw, nh); + SDL_FillRect(st, NULL, SDL_MapRGBA((*s)->format, 0, 0, 0, 0)); + SDL_SetAlpha(*s, 0, 0); + sdlDrawImage(st, *s, 0, 0); + GLuint t; glGenTextures(1, &t); glBindTexture(GL_TEXTURE_2D, t); @@ -586,20 +581,29 @@ static int sdl_surface_toscreen(lua_State *L) glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); // get the number of channels in the SDL surface - GLint nOfColors = (*s)->format->BytesPerPixel; - GLenum texture_format = sdl_gl_texture_format(*s); + GLint nOfColors = st->format->BytesPerPixel; + GLenum texture_format = sdl_gl_texture_format(st); - glTexImage2D(GL_TEXTURE_2D, 0, nOfColors, (*s)->w, (*s)->h, 0, texture_format, GL_UNSIGNED_BYTE, (*s)->pixels); + glTexImage2D(GL_TEXTURE_2D, 0, nOfColors, st->w, st->h, 0, texture_format, GL_UNSIGNED_BYTE, st->pixels); GLenum err = glGetError(); if (err != GL_NO_ERROR) { printf("glTexImage2D : %s\n",gluErrorString(err)); } - draw_textured_quad(x,y,(*s)->w,(*s)->h); +// draw_textured_quad(x,y,(*s)->w,(*s)->h); + glBegin( GL_QUADS ); + float fw = (float)(*s)->w / (float)nw, fh = (float)(*s)->h / (float)nh; + glTexCoord2f(0,0); glVertex2f(0 + x, 0 + y); + glTexCoord2f(0,fh); glVertex2f(0 + x, (*s)->h + y); + glTexCoord2f(fw,fh); glVertex2f((*s)->w + x, (*s)->h + y); + glTexCoord2f(fw,0); glVertex2f((*s)->w + x, 0 + y); + glEnd( ); glDeleteTextures(1, &t); + SDL_FreeSurface(st); + return 0; } @@ -610,21 +614,77 @@ static int sdl_surface_toscreen_with_texture(lua_State *L) int x = luaL_checknumber(L, 3); int y = luaL_checknumber(L, 4); + int nw = 1, nh = 1; + while (nw < (*s)->w) nw *= 2; + while (nh < (*s)->h) nh *= 2; + if (nw > nh) nh = nw; + else nw = nh; + SDL_Surface *st = make_surface(nw, nh); + SDL_FillRect(st, NULL, SDL_MapRGBA((*s)->format, 0, 0, 0, 0)); + SDL_SetAlpha(*s, 0, 0); + sdlDrawImage(st, *s, 0, 0); + glBindTexture(GL_TEXTURE_2D, *t); - GLenum texture_format = sdl_gl_texture_format(*s); + GLenum texture_format = sdl_gl_texture_format(st); - glTexSubImage2D(GL_TEXTURE_2D, 0, 0, 0, (*s)->w, (*s)->h, texture_format, GL_UNSIGNED_BYTE, (*s)->pixels); + glTexSubImage2D(GL_TEXTURE_2D, 0, 0, 0, st->w, st->h, texture_format, GL_UNSIGNED_BYTE, st->pixels); GLenum err = glGetError(); if (err != GL_NO_ERROR) { printf("glTexSubImage2D : %s\n",gluErrorString(err)); } - draw_textured_quad(x,y,(*s)->w,(*s)->h); +// draw_textured_quad(x,y,(*s)->w,(*s)->h); + glBegin( GL_QUADS ); + float fw = (float)(*s)->w / (float)nw, fh = (float)(*s)->h / (float)nh; + glTexCoord2f(0,0); glVertex2f(0 + x, 0 + y); + glTexCoord2f(0,fh); glVertex2f(0 + x, (*s)->h + y); + glTexCoord2f(fw,fh); glVertex2f((*s)->w + x, (*s)->h + y); + glTexCoord2f(fw,0); glVertex2f((*s)->w + x, 0 + y); + glEnd( ); + + SDL_FreeSurface(st); + return 0; } +static int sdl_surface_to_texture2(lua_State *L) +{ + SDL_Surface **s = (SDL_Surface**)auxiliar_checkclass(L, "sdl{surface}", 1); + + int nw = 1, nh = 1; + while (nw < (*s)->w) nw *= 2; + while (nh < (*s)->h) nh *= 2; + if (nw > nh) nh = nw; + else nw = nh; + SDL_Surface *st = make_surface(nw, nh); + SDL_FillRect(st, NULL, SDL_MapRGBA((*s)->format, 0, 0, 0, 0)); + SDL_SetAlpha(*s, 0, 0); + sdlDrawImage(st, *s, 0, 0); + + GLuint *t = (GLuint*)lua_newuserdata(L, sizeof(GLuint)); + auxiliar_setclass(L, "gl{texture}", -1); + + glGenTextures(1, t); + glBindTexture(GL_TEXTURE_2D, *t); + + // Paramétrage de la texture. + glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT); + glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT); + glTexParameteri(GL_TEXTURE_2D, GL_TEXTURE_MIN_FILTER, GL_LINEAR); + + // get the number of channels in the SDL surface + GLint nOfColors = st->format->BytesPerPixel; + GLenum texture_format = sdl_gl_texture_format(st); + + glTexImage2D(GL_TEXTURE_2D, 0, nOfColors, st->w, st->h, 0, texture_format, GL_UNSIGNED_BYTE, st->pixels); + + SDL_FreeSurface(st); + + return 1; +} + static int sdl_surface_to_texture(lua_State *L) { SDL_Surface **s = (SDL_Surface**)auxiliar_checkclass(L, "sdl{surface}", 1); @@ -656,6 +716,7 @@ static int sdl_surface_merge(lua_State *L) int y = luaL_checknumber(L, 4); if (dst && *dst && src && *src) { + SDL_SetAlpha(*src, 0, 0); sdlDrawImage(*dst, *src, x, y); } return 0; @@ -730,6 +791,7 @@ static const struct luaL_reg sdl_surface_reg[] = {"drawString", sdl_surface_drawstring}, {"alpha", sdl_surface_alpha}, {"glTexture", sdl_surface_to_texture}, + {"glTexture2", sdl_surface_to_texture2}, {NULL, NULL}, }; -- GitLab