--- deliantra/Deliantra-Client/pango-render.c 2007/08/11 11:32:29 1.8 +++ deliantra/Deliantra-Client/pango-render.c 2007/08/11 11:41:24 1.9 @@ -275,8 +275,22 @@ gl->a = a; gl->flags = flags; + glEnable (GL_TEXTURE_2D); + glTexEnvi (GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); + glEnable (GL_BLEND); + gl_BlendFuncSeparate (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA, + GL_ONE , GL_ONE_MINUS_SRC_ALPHA); + glEnable (GL_ALPHA_TEST); + glAlphaFunc (GL_GREATER, 0.01f); + pango_renderer_draw_layout (renderer, layout, x, y); + rc_draw (gl->rc); + + glDisable (GL_ALPHA_TEST); + glDisable (GL_BLEND); + glDisable (GL_TEXTURE_2D); + rc_free (gl->rc); } @@ -303,7 +317,7 @@ static void prepare_run (PangoRenderer *renderer, PangoLayoutRun *run) { - PangoOpenGLRenderer *glrenderer = (PangoOpenGLRenderer *)renderer; + PangoOpenGLRenderer *gl = (PangoOpenGLRenderer *)renderer; PangoColor *fg = 0; GSList *l; unsigned char r, g, b, a; @@ -311,9 +325,9 @@ renderer->underline = PANGO_UNDERLINE_NONE; renderer->strikethrough = FALSE; - glrenderer->key.mode = GL_QUADS; - glrenderer->key.format = GL_T2F_V3F; - glrenderer->key.texname = 0; + gl->key.mode = GL_QUADS; + gl->key.format = GL_T2F_V3F; + gl->key.texname = 0; for (l = run->item->analysis.extra_attrs; l; l = l->next) { @@ -346,50 +360,36 @@ } else { - r = glrenderer->r * 255.f; - g = glrenderer->g * 255.f; - b = glrenderer->b * 255.f; + r = gl->r * 255.f; + g = gl->g * 255.f; + b = gl->b * 255.f; } - a = glrenderer->a * 255.f; + a = gl->a * 255.f; - if (glrenderer->flags & FLAG_INVERSE) + if (gl->flags & FLAG_INVERSE) { r ^= 0xffU; g ^= 0xffU; b ^= 0xffU; } - glrenderer->key.r = r; - glrenderer->key.g = g; - glrenderer->key.b = b; - glrenderer->key.a = a; + gl->key.r = r; + gl->key.g = g; + gl->key.b = b; + gl->key.a = a; } static void draw_begin (PangoRenderer *renderer_) { PangoOpenGLRenderer *renderer = (PangoOpenGLRenderer *)renderer_; - - glEnable (GL_TEXTURE_2D); - glTexEnvi (GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE); - glEnable (GL_BLEND); - gl_BlendFuncSeparate (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA, - GL_ONE , GL_ONE_MINUS_SRC_ALPHA); - glEnable (GL_ALPHA_TEST); - glAlphaFunc (GL_GREATER, 0.01f); } static void draw_end (PangoRenderer *renderer_) { PangoOpenGLRenderer *renderer = (PangoOpenGLRenderer *)renderer_; - - rc_draw (renderer->rc); - - glDisable (GL_ALPHA_TEST); - glDisable (GL_BLEND); - glDisable (GL_TEXTURE_2D); } static void