ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/Deliantra-Client/pango-render.c
(Generate patch)

Comparing deliantra/Deliantra-Client/pango-render.c (file contents):
Revision 1.2 by root, Tue Jul 4 23:44:23 2006 UTC vs.
Revision 1.10 by root, Sat Aug 11 12:07:54 2007 UTC

35 35
36struct _PangoOpenGLRenderer 36struct _PangoOpenGLRenderer
37{ 37{
38 PangoRenderer parent_instance; 38 PangoRenderer parent_instance;
39 float r, g, b, a; // modulate 39 float r, g, b, a; // modulate
40 GLuint curtex; // current texture 40 int flags;
41 rc_t *rc; // rendercache
42 rc_key_t key; // current render key
43 rc_array_t *arr;
41}; 44};
42 45
43G_DEFINE_TYPE (PangoOpenGLRenderer, pango_opengl_renderer, PANGO_TYPE_RENDERER) 46G_DEFINE_TYPE (PangoOpenGLRenderer, pango_opengl_renderer, PANGO_TYPE_RENDERER)
44 47
45typedef struct 48typedef struct
146} 149}
147 150
148typedef struct glyph_info { 151typedef struct glyph_info {
149 tc_area tex; 152 tc_area tex;
150 int left, top; 153 int left, top;
154 int generation;
151} glyph_info; 155} glyph_info;
152 156
153static void 157static void
154free_glyph_info (glyph_info *g) 158free_glyph_info (glyph_info *g)
155{ 159{
172 glyph = PANGO_GLYPH_UNKNOWN_FLAG; 176 glyph = PANGO_GLYPH_UNKNOWN_FLAG;
173 } 177 }
174 178
175 g = _pango_opengl_font_get_cache_glyph_data (font, glyph); 179 g = _pango_opengl_font_get_cache_glyph_data (font, glyph);
176 180
177 if (!g) 181 if (!g || g->generation != tc_generation)
178 { 182 {
179 Glyph bm; 183 Glyph bm;
180 font_render_glyph (&bm, font, glyph); 184 font_render_glyph (&bm, font, glyph);
181 185
186 if (g)
187 g->generation = tc_generation;
188 else
189 {
182 g = g_slice_new (glyph_info); 190 g = g_slice_new (glyph_info);
191
192 _pango_opengl_font_set_glyph_cache_destroy (font, (GDestroyNotify)free_glyph_info);
193 _pango_opengl_font_set_cache_glyph_data (font, glyph, g);
194 }
183 195
184 tc_get (&g->tex, bm.width, bm.height); 196 tc_get (&g->tex, bm.width, bm.height);
185 197
186 g->left = bm.left; 198 g->left = bm.left;
187 g->top = bm.top; 199 g->top = bm.top;
188
189 if (renderer->curtex)
190 {
191 glEnd ();
192 renderer->curtex = 0;
193 }
194 200
195 glBindTexture (GL_TEXTURE_2D, g->tex.name); 201 glBindTexture (GL_TEXTURE_2D, g->tex.name);
196 glPixelStorei (GL_UNPACK_ROW_LENGTH, bm.stride); 202 glPixelStorei (GL_UNPACK_ROW_LENGTH, bm.stride);
197 glPixelStorei (GL_UNPACK_ALIGNMENT, 1); 203 glPixelStorei (GL_UNPACK_ALIGNMENT, 1);
198 glTexSubImage2D (GL_TEXTURE_2D, 0, g->tex.x, g->tex.y, bm.width, bm.height, GL_ALPHA, GL_UNSIGNED_BYTE, bm.bitmap); 204 glTexSubImage2D (GL_TEXTURE_2D, 0, g->tex.x, g->tex.y, bm.width, bm.height, GL_ALPHA, GL_UNSIGNED_BYTE, bm.bitmap);
199 glPixelStorei (GL_UNPACK_ROW_LENGTH, 0); 205 glPixelStorei (GL_UNPACK_ROW_LENGTH, 0);
200 glPixelStorei (GL_UNPACK_ALIGNMENT, 4); 206 glPixelStorei (GL_UNPACK_ALIGNMENT, 4);
201
202 _pango_opengl_font_set_glyph_cache_destroy (font, (GDestroyNotify)free_glyph_info);
203 _pango_opengl_font_set_cache_glyph_data (font, glyph, g);
204 } 207 }
205 208
206 x += g->left; 209 x += g->left;
207 y -= g->top; 210 y -= g->top;
208 211
209 x1 = g->tex.x * (1. / TC_WIDTH ); 212 x1 = g->tex.x * (1. / TC_WIDTH );
210 y1 = g->tex.y * (1. / TC_HEIGHT); 213 y1 = g->tex.y * (1. / TC_HEIGHT);
211 x2 = g->tex.w * (1. / TC_WIDTH ) + x1; 214 x2 = g->tex.w * (1. / TC_WIDTH ) + x1;
212 y2 = g->tex.h * (1. / TC_HEIGHT) + y1; 215 y2 = g->tex.h * (1. / TC_HEIGHT) + y1;
213 216
214 if (g->tex.name != renderer->curtex) 217 if (g->tex.name != renderer->key.texname)
215 { 218 {
216 if (renderer->curtex)
217 glEnd ();
218
219 glBindTexture (GL_TEXTURE_2D, g->tex.name);
220 renderer->curtex = g->tex.name; 219 renderer->key.texname = g->tex.name;
221 glBegin (GL_QUADS); 220 renderer->arr = rc_array (renderer->rc, &renderer->key);
222 } 221 }
223 222
224 glTexCoord2f (x1, y1); glVertex2i (x , y ); 223 rc_t2f_v3f (renderer->arr, x1, y1, x , y , 0);
225 glTexCoord2f (x2, y1); glVertex2i (x + g->tex.w, y ); 224 rc_t2f_v3f (renderer->arr, x2, y1, x + g->tex.w, y , 0);
226 glTexCoord2f (x2, y2); glVertex2i (x + g->tex.w, y + g->tex.h); 225 rc_t2f_v3f (renderer->arr, x2, y2, x + g->tex.w, y + g->tex.h, 0);
227 glTexCoord2f (x1, y2); glVertex2i (x , y + g->tex.h); 226 rc_t2f_v3f (renderer->arr, x1, y2, x , y + g->tex.h, 0);
228} 227}
229 228
230static void 229static void
231draw_trapezoid (PangoRenderer *renderer_, 230draw_trapezoid (PangoRenderer *renderer_,
232 PangoRenderPart part, 231 PangoRenderPart part,
236 double y2, 235 double y2,
237 double x12, 236 double x12,
238 double x22) 237 double x22)
239{ 238{
240 PangoOpenGLRenderer *renderer = (PangoOpenGLRenderer *)renderer_; 239 PangoOpenGLRenderer *renderer = (PangoOpenGLRenderer *)renderer_;
240 rc_key_t key = renderer->key;
241 rc_array_t *arr;
241 242
242 if (renderer->curtex) 243 key.mode = GL_QUADS;
243 { 244 key.format = GL_V2F;
244 glEnd (); 245 key.texname = 0;
245 renderer->curtex = 0;
246 }
247 246
248 glDisable (GL_TEXTURE_2D); 247 arr = rc_array (renderer->rc, &key);
249 248
250 glBegin (GL_QUADS); 249 rc_v2f (arr, x11, y1);
251 glVertex2d (x11, y1); 250 rc_v2f (arr, x21, y1);
252 glVertex2d (x12, y1); 251 rc_v2f (arr, x22, y2);
253 glVertex2d (x22, y2); 252 rc_v2f (arr, x12, y2);
254 glVertex2d (x21, y2);
255 glEnd ();
256
257 glEnable (GL_TEXTURE_2D);
258} 253}
259 254
260void 255void
261pango_opengl_render_layout_subpixel (PangoLayout *layout, 256pango_opengl_render_layout_subpixel (PangoLayout *layout,
257 rc_t *rc,
262 int x, int y, 258 int x, int y,
263 float r, float g, float b, float a) 259 float r, float g, float b, float a,
260 int flags)
264{ 261{
265 PangoContext *context; 262 PangoContext *context;
266 PangoFontMap *fontmap; 263 PangoFontMap *fontmap;
267 PangoRenderer *renderer; 264 PangoRenderer *renderer;
265 PangoOpenGLRenderer *gl;
268 266
269 context = pango_layout_get_context (layout); 267 context = pango_layout_get_context (layout);
270 fontmap = pango_context_get_font_map (context); 268 fontmap = pango_context_get_font_map (context);
271 renderer = _pango_opengl_font_map_get_renderer (PANGO_OPENGL_FONT_MAP (fontmap)); 269 renderer = _pango_opengl_font_map_get_renderer (PANGO_OPENGL_FONT_MAP (fontmap));
272
273 PANGO_OPENGL_RENDERER (renderer)->r = r; 270 gl = PANGO_OPENGL_RENDERER (renderer);
274 PANGO_OPENGL_RENDERER (renderer)->g = g; 271
275 PANGO_OPENGL_RENDERER (renderer)->b = b; 272 gl->rc = rc;
276 PANGO_OPENGL_RENDERER (renderer)->a = a; 273 gl->r = r;
274 gl->g = g;
275 gl->b = b;
276 gl->a = a;
277 gl->flags = flags;
277 278
278 pango_renderer_draw_layout (renderer, layout, x, y); 279 pango_renderer_draw_layout (renderer, layout, x, y);
279} 280}
280 281
281void 282void
282pango_opengl_render_layout (PangoLayout *layout, 283pango_opengl_render_layout (PangoLayout *layout,
284 rc_t *rc,
283 int x, int y, 285 int x, int y,
284 float r, float g, float b, float a) 286 float r, float g, float b, float a,
287 int flags)
285{ 288{
286 pango_opengl_render_layout_subpixel (layout, x * PANGO_SCALE, y * PANGO_SCALE, r, g, b, a); 289 pango_opengl_render_layout_subpixel (
290 layout, rc, x * PANGO_SCALE, y * PANGO_SCALE, r, g, b, a, flags
291 );
287} 292}
288 293
289static void 294static void
290pango_opengl_renderer_init (PangoOpenGLRenderer *renderer) 295pango_opengl_renderer_init (PangoOpenGLRenderer *renderer)
291{ 296{
297 memset (&renderer->key, 0, sizeof (rc_key_t));
298
292 renderer->r = 1.; 299 renderer->r = 1.;
293 renderer->g = 1.; 300 renderer->g = 1.;
294 renderer->b = 1.; 301 renderer->b = 1.;
295 renderer->a = 1.; 302 renderer->a = 1.;
296} 303}
297 304
298static void 305static void
299prepare_run (PangoRenderer *renderer, PangoLayoutRun *run) 306prepare_run (PangoRenderer *renderer, PangoLayoutRun *run)
300{ 307{
301 PangoOpenGLRenderer *glrenderer = (PangoOpenGLRenderer *)renderer; 308 PangoOpenGLRenderer *gl = (PangoOpenGLRenderer *)renderer;
302 PangoColor *fg = 0; 309 PangoColor *fg = 0;
303 GSList *l; 310 GSList *l;
311 unsigned char r, g, b, a;
304 312
305 renderer->underline = PANGO_UNDERLINE_NONE; 313 renderer->underline = PANGO_UNDERLINE_NONE;
306 renderer->strikethrough = FALSE; 314 renderer->strikethrough = FALSE;
315
316 gl->key.mode = GL_QUADS;
317 gl->key.format = GL_T2F_V3F;
318 gl->key.texname = 0;
307 319
308 for (l = run->item->analysis.extra_attrs; l; l = l->next) 320 for (l = run->item->analysis.extra_attrs; l; l = l->next)
309 { 321 {
310 PangoAttribute *attr = l->data; 322 PangoAttribute *attr = l->data;
311 323
327 break; 339 break;
328 } 340 }
329 } 341 }
330 342
331 if (fg) 343 if (fg)
332 glColor4f (fg->red / 65535., fg->green / 65535., fg->blue / 65535., glrenderer->a); 344 {
345 r = fg->red * (255.f / 65535.f);
346 g = fg->green * (255.f / 65535.f);
347 b = fg->blue * (255.f / 65535.f);
348 }
333 else 349 else
334 glColor4f (glrenderer->r, glrenderer->g, glrenderer->b, glrenderer->a); 350 {
351 r = gl->r * 255.f;
352 g = gl->g * 255.f;
353 b = gl->b * 255.f;
354 }
355
356 a = gl->a * 255.f;
357
358 if (gl->flags & FLAG_INVERSE)
359 {
360 r ^= 0xffU;
361 g ^= 0xffU;
362 b ^= 0xffU;
363 }
364
365 gl->key.r = r;
366 gl->key.g = g;
367 gl->key.b = b;
368 gl->key.a = a;
335} 369}
336 370
337static void 371static void
338draw_begin (PangoRenderer *renderer_) 372draw_begin (PangoRenderer *renderer_)
339{ 373{
340 PangoOpenGLRenderer *renderer = (PangoOpenGLRenderer *)renderer_; 374 PangoOpenGLRenderer *renderer = (PangoOpenGLRenderer *)renderer_;
341
342 renderer->curtex = 0;
343
344 glEnable (GL_TEXTURE_2D);
345 glTexEnvi (GL_TEXTURE_ENV, GL_TEXTURE_ENV_MODE, GL_MODULATE);
346 glEnable (GL_BLEND);
347 gl_BlendFuncSeparate (GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA,
348 GL_ONE , GL_ONE_MINUS_SRC_ALPHA);
349 glEnable (GL_ALPHA_TEST);
350 glAlphaFunc (GL_GREATER, 0.01f);
351} 375}
352 376
353static void 377static void
354draw_end (PangoRenderer *renderer_) 378draw_end (PangoRenderer *renderer_)
355{ 379{
356 PangoOpenGLRenderer *renderer = (PangoOpenGLRenderer *)renderer_; 380 PangoOpenGLRenderer *renderer = (PangoOpenGLRenderer *)renderer_;
357
358 if (renderer->curtex)
359 glEnd ();
360
361 glDisable (GL_ALPHA_TEST);
362 glDisable (GL_BLEND);
363 glDisable (GL_TEXTURE_2D);
364} 381}
365 382
366static void 383static void
367pango_opengl_renderer_class_init (PangoOpenGLRendererClass *klass) 384pango_opengl_renderer_class_init (PangoOpenGLRendererClass *klass)
368{ 385{

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines