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.92 by root, Mon Jan 30 04:53:30 2006 UTC vs.
Revision 1.95 by root, Sat Feb 18 14:14:43 2006 UTC

158 0x304c, 0x672c, // が本 158 0x304c, 0x672c, // が本
159}; 159};
160 160
161#define NUM_EXTENT_TEST_CHARS (sizeof (extent_test_chars) / sizeof (extent_test_chars[0])) 161#define NUM_EXTENT_TEST_CHARS (sizeof (extent_test_chars) / sizeof (extent_test_chars[0]))
162 162
163#define dTermDisplay Display *disp = term->xdisp 163#define dTermDisplay Display *disp = term->dpy
164#define dTermGC GC gc = term->gc 164#define dTermGC GC gc = term->gc
165
166/////////////////////////////////////////////////////////////////////////////
167
168#if XFT
169rxvt_drawable::~rxvt_drawable ()
170{
171 if (xftdrawable)
172 XftDrawDestroy (xftdrawable);
173}
174
175rxvt_drawable::operator XftDraw *()
176{
177 if (!xftdrawable)
178 xftdrawable = XftDrawCreate (screen->xdisp, drawable, screen->visual, screen->cmap);
179
180 return xftdrawable;
181}
182#endif
183 165
184///////////////////////////////////////////////////////////////////////////// 166/////////////////////////////////////////////////////////////////////////////
185 167
186static const char * 168static const char *
187enc_char (const text_t *text, uint32_t len, codeset cs, bool &zero) 169enc_char (const text_t *text, uint32_t len, codeset cs, bool &zero)
514rxvt_font_x11::get_property (XFontStruct *f, Atom property, const char *repl) const 496rxvt_font_x11::get_property (XFontStruct *f, Atom property, const char *repl) const
515{ 497{
516 unsigned long value; 498 unsigned long value;
517 499
518 if (XGetFontProperty (f, property, &value)) 500 if (XGetFontProperty (f, property, &value))
519 return XGetAtomName (term->xdisp, value); 501 return XGetAtomName (term->dpy, value);
520 else 502 else
521 return rxvt_strdup (repl); 503 return rxvt_strdup (repl);
522} 504}
523 505
524rxvt_fontprop 506rxvt_fontprop
547rxvt_font_x11::set_properties (rxvt_fontprop &p, XFontStruct *f) 529rxvt_font_x11::set_properties (rxvt_fontprop &p, XFontStruct *f)
548{ 530{
549 unsigned long height; 531 unsigned long height;
550 532
551#if 0 533#if 0
552 if (!XGetFontProperty (f, XInternAtom (term->xdisp, "PIXEL_SIZE", 0), &height)) 534 if (!XGetFontProperty (f, XInternAtom (term->dpy, "PIXEL_SIZE", 0), &height))
553 return false; 535 return false;
554#else 536#else
555 height = f->ascent + f->descent; 537 height = f->ascent + f->descent;
556#endif 538#endif
557 539
892void 874void
893rxvt_font_x11::clear () 875rxvt_font_x11::clear ()
894{ 876{
895 if (f) 877 if (f)
896 { 878 {
897 XFreeFont (term->xdisp, f); 879 XFreeFont (term->dpy, f);
898 f = 0; 880 f = 0;
899 } 881 }
900} 882}
901 883
902bool 884bool
1074void 1056void
1075rxvt_font_xft::clear () 1057rxvt_font_xft::clear ()
1076{ 1058{
1077 if (f) 1059 if (f)
1078 { 1060 {
1079 XftFontClose (term->xdisp, f); 1061 XftFontClose (term->dpy, f);
1080 f = 0; 1062 f = 0;
1081 } 1063 }
1082} 1064}
1083 1065
1084rxvt_fontprop 1066rxvt_fontprop
1251bool 1233bool
1252rxvt_font_xft::has_char (unicode_t unicode, const rxvt_fontprop *prop, bool &careful) const 1234rxvt_font_xft::has_char (unicode_t unicode, const rxvt_fontprop *prop, bool &careful) const
1253{ 1235{
1254 careful = false; 1236 careful = false;
1255 1237
1256 if (!XftCharExists (term->xdisp, f, unicode)) 1238 if (!XftCharExists (term->dpy, f, unicode))
1257 return false; 1239 return false;
1258 1240
1259 if (!prop || prop->width == rxvt_fontprop::unset) 1241 if (!prop || prop->width == rxvt_fontprop::unset)
1260 return true; 1242 return true;
1261 1243
1262 // check character against base font bounding box 1244 // check character against base font bounding box
1263 FcChar32 ch = unicode; 1245 FcChar32 ch = unicode;
1264 XGlyphInfo g; 1246 XGlyphInfo g;
1265 XftTextExtents32 (term->xdisp, f, &ch, 1, &g); 1247 XftTextExtents32 (term->dpy, f, &ch, 1, &g);
1266 1248
1267 int w = g.width - g.x; 1249 int w = g.width - g.x;
1268 int wcw = max (WCWIDTH (unicode), 1); 1250 int wcw = max (WCWIDTH (unicode), 1);
1269 1251
1270 careful = g.x > 0 || w > prop->width * wcw; 1252 careful = g.x > 0 || w > prop->width * wcw;
1282void 1264void
1283rxvt_font_xft::draw (rxvt_drawable &d, int x, int y, 1265rxvt_font_xft::draw (rxvt_drawable &d, int x, int y,
1284 const text_t *text, int len, 1266 const text_t *text, int len,
1285 int fg, int bg) 1267 int fg, int bg)
1286{ 1268{
1287 clear_rect (d, x, y, term->fwidth * len, term->fheight, bg);
1288
1289 XGlyphInfo extents; 1269 XGlyphInfo extents;
1290 XftGlyphSpec *enc = (XftGlyphSpec *)rxvt_temp_buf (len * sizeof (XftGlyphSpec)); 1270 XftGlyphSpec *enc = (XftGlyphSpec *)rxvt_temp_buf (len * sizeof (XftGlyphSpec));
1291 XftGlyphSpec *ep = enc; 1271 XftGlyphSpec *ep = enc;
1292 1272
1293 dTermDisplay; 1273 dTermDisplay;
1294 dTermGC; 1274 dTermGC;
1295 1275
1276 int w = term->fwidth * len;
1277 int h = term->fheight;
1278
1279 bool buffered = false;
1280
1296 // cut trailing spaces 1281 // cut trailing spaces
1297 while (len && text [len - 1] == ' ') 1282 while (len && text [len - 1] == ' ')
1298 len--; 1283 len--;
1284
1285 int x_ = buffered ? 0 : x;
1286 int y_ = buffered ? 0 : y;
1299 1287
1300 while (len) 1288 while (len)
1301 { 1289 {
1302 int cwidth = term->fwidth; 1290 int cwidth = term->fwidth;
1303 FcChar32 fc = *text++; len--; 1291 FcChar32 fc = *text++; len--;
1308 if (fc != ' ') // skip spaces 1296 if (fc != ' ') // skip spaces
1309 { 1297 {
1310 FT_UInt glyph = XftCharIndex (disp, f, fc); 1298 FT_UInt glyph = XftCharIndex (disp, f, fc);
1311 XftGlyphExtents (disp, f, &glyph, 1, &extents); 1299 XftGlyphExtents (disp, f, &glyph, 1, &extents);
1312 1300
1313
1314 ep->glyph = glyph; 1301 ep->glyph = glyph;
1315 ep->x = x + (cwidth - extents.xOff >> 1); 1302 ep->x = x_ + (cwidth - extents.xOff >> 1);
1316 ep->y = y + ascent; 1303 ep->y = y_ + ascent;
1317 1304
1318 if (extents.xOff == 0) 1305 if (extents.xOff == 0)
1319 ep->x = x + cwidth; 1306 ep->x = x_ + cwidth;
1320 1307
1321 ep++; 1308 ep++;
1322 } 1309 }
1323 1310
1324 x += cwidth; 1311 x_ += cwidth;
1312 }
1313
1314 if (buffered)
1325 } 1315 {
1326
1327 if (ep != enc) 1316 if (ep != enc)
1317 {
1318 rxvt_drawable &d2 = d.screen->scratch_drawable (w, h);
1319
1320 XftDrawRect (d2, &term->pix_colors[bg].c, 0, 0, w, h);
1321
1322 XftDrawGlyphSpec (d2, &term->pix_colors[fg].c, f, enc, ep - enc);
1323 XCopyArea (disp, d2, d, gc, 0, 0, w, h, x, y);
1324 }
1325 else
1326 clear_rect (d, x, y, w, h, bg);
1327 }
1328 else
1329 {
1330 clear_rect (d, x, y, w, h, bg);
1328 XftDrawGlyphSpec (d, &term->pix_colors[fg].c, f, enc, ep - enc); 1331 XftDrawGlyphSpec (d, &term->pix_colors[fg].c, f, enc, ep - enc);
1332 }
1329} 1333}
1334
1330#endif 1335#endif
1331 1336
1332///////////////////////////////////////////////////////////////////////////// 1337/////////////////////////////////////////////////////////////////////////////
1333 1338
1334rxvt_fontset::rxvt_fontset (rxvt_term *term) 1339rxvt_fontset::rxvt_fontset (rxvt_term *term)
1577 FcPatternAddInteger (p, FC_SLANT, prop.slant); 1582 FcPatternAddInteger (p, FC_SLANT, prop.slant);
1578 FcPatternAddBool (p, FC_MINSPACE, 1); 1583 FcPatternAddBool (p, FC_MINSPACE, 1);
1579 //FcPatternAddBool (p, FC_ANTIALIAS, 1); 1584 //FcPatternAddBool (p, FC_ANTIALIAS, 1);
1580 1585
1581 XftResult result; 1586 XftResult result;
1582 FcPattern *match = XftFontMatch (term->xdisp, term->display->screen, p, &result); 1587 FcPattern *match = XftFontMatch (term->dpy, term->display->screen, p, &result);
1583 1588
1584 FcPatternDestroy (p); 1589 FcPatternDestroy (p);
1585 1590
1586 if (match) 1591 if (match)
1587 { 1592 {

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines