ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/rxvtfont.C
(Generate patch)

Comparing rxvt-unicode/src/rxvtfont.C (file contents):
Revision 1.111 by sasha, Fri Aug 17 22:01:33 2007 UTC vs.
Revision 1.112 by sasha, Mon Aug 20 20:13:35 2007 UTC

1322 { 1322 {
1323 rxvt_drawable &d2 = d.screen->scratch_drawable (w, h); 1323 rxvt_drawable &d2 = d.screen->scratch_drawable (w, h);
1324 bool back_rendered = false; 1324 bool back_rendered = false;
1325 1325
1326#ifdef HAVE_BG_PIXMAP 1326#ifdef HAVE_BG_PIXMAP
1327 if (term->bgPixmap.pixmap && (bg < 0 || term->pix_colors[bg].c.color.alpha < 0x0ff00)) 1327 if (term->bgPixmap.pixmap)
1328 { 1328 {
1329 if (term->bgPixmap.pmap_width >= x + term->window_vt_x+w 1329 Picture dst = 0;
1330 && term->bgPixmap.pmap_height >= y + term->window_vt_y+h) 1330 if (bg >= 0 && term->pix_colors[bg].c.color.alpha < 0x0ff00)
1331 dst = XftDrawPicture(d2);
1332
1333 if (bg < 0 || dst != 0)
1331 { 1334 {
1335 if (term->bgPixmap.pmap_width >= x + term->window_vt_x+w
1336 && term->bgPixmap.pmap_height >= y + term->window_vt_y+h)
1337 {
1332 XCopyArea (disp, term->bgPixmap.pixmap, d2, gc, 1338 XCopyArea (disp, term->bgPixmap.pixmap, d2, gc,
1333 x + term->window_vt_x, y + term->window_vt_y, 1339 x + term->window_vt_x, y + term->window_vt_y,
1334 w, h, 0, 0); 1340 w, h, 0, 0);
1335 } 1341 }
1336 else 1342 else
1337 { 1343 {
1338 XGCValues gcv; 1344 XGCValues gcv;
1339 1345
1340 gcv.fill_style = FillTiled; 1346 gcv.fill_style = FillTiled;
1341 gcv.tile = term->bgPixmap.pixmap; 1347 gcv.tile = term->bgPixmap.pixmap;
1342 gcv.ts_x_origin = -x; 1348 gcv.ts_x_origin = -x;
1343 gcv.ts_y_origin = -y; 1349 gcv.ts_y_origin = -y;
1344 1350
1345#if 0 1351 #if 0
1346 GC gc2 = XCreateGC (disp, d2, 1352 GC gc2 = XCreateGC (disp, d2,
1347 GCTile | GCTileStipXOrigin | GCTileStipYOrigin | GCFillStyle, 1353 GCTile | GCTileStipXOrigin | GCTileStipYOrigin | GCFillStyle,
1348 &gcv); 1354 &gcv);
1349#endif 1355 #endif
1350 XChangeGC (disp, gc, 1356 XChangeGC (disp, gc,
1351 GCTile | GCTileStipXOrigin | GCTileStipYOrigin | GCFillStyle, 1357 GCTile | GCTileStipXOrigin | GCTileStipYOrigin | GCFillStyle,
1352 &gcv); 1358 &gcv);
1353 1359
1354 XFillRectangle (disp, d2, gc/*gc2*/, 0, 0, w, h); 1360 XFillRectangle (disp, d2, gc/*gc2*/, 0, 0, w, h);
1355 1361
1356 gcv.fill_style = FillSolid; 1362 gcv.fill_style = FillSolid;
1357 XChangeGC (disp, gc, GCFillStyle, &gcv); 1363 XChangeGC (disp, gc, GCFillStyle, &gcv);
1358 /* XFreeGC (disp, gc2); */ 1364 /* XFreeGC (disp, gc2); */
1359 1365
1360 } 1366 }
1361 if (bg > 0) 1367 if (bg >= 0)
1362 {
1363 Picture dst = XftDrawPicture(d2);
1364 if (dst != 0)
1365 { 1368 {
1366 Picture solid_color_pict = XftDrawSrcPicture (d2, &term->pix_colors[bg].c); 1369 Picture solid_color_pict = XftDrawSrcPicture (d2, &term->pix_colors[bg].c);
1367 XRenderComposite (disp, PictOpOver, solid_color_pict, None, dst, 0, 0, 0, 0, 0, 0, w, h); 1370 XRenderComposite (disp, PictOpOver, solid_color_pict, None, dst, 0, 0, 0, 0, 0, 0, w, h);
1368 } 1371 }
1372 back_rendered = true;
1369 } 1373 }
1370 back_rendered = true;
1371 } 1374 }
1372#endif 1375#endif
1373 1376
1374 if(bg > 0 && !back_rendered) 1377 if(bg >= 0 && !back_rendered)
1375 XftDrawRect (d2, &term->pix_colors[bg].c, 0, 0, w, h); 1378 XftDrawRect (d2, &term->pix_colors[bg].c, 0, 0, w, h);
1376 1379
1377 XftDrawGlyphSpec (d2, &term->pix_colors[fg].c, f, enc, ep - enc); 1380 XftDrawGlyphSpec (d2, &term->pix_colors[fg].c, f, enc, ep - enc);
1378 XCopyArea (disp, d2, d, gc, 0, 0, w, h, x, y); 1381 XCopyArea (disp, d2, d, gc, 0, 0, w, h, x, y);
1379 } 1382 }

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines