diff options
author | Shiva <shiv@shiv.me> | 2017-01-29 21:40:45 -0800 |
---|---|---|
committer | Shiva <shiv@shiv.me> | 2017-01-29 21:40:45 -0800 |
commit | e0a07a93920addd911486ff5525e5675a7ceda7b (patch) | |
tree | de72c824ff93ce3c9d09094ab848600c99d9d52b /st.c | |
parent | 10bf3c85073325a2e3fd4c2201b7a3e4770e70d3 (diff) |
vertically center lines in space available
Diffstat (limited to 'st.c')
-rw-r--r-- | st.c | 8 |
1 files changed, 5 insertions, 3 deletions
@@ -281,6 +281,7 @@ typedef struct { int w, h; /* window width and height */ int ch; /* char height */ int cw; /* char width */ + int cyo; /* char y offset */ char state; /* focus, redraw, visible */ int cursor; /* cursor style */ } XWindow; @@ -3583,6 +3584,7 @@ xloadfonts(char *fontstr, double fontsize) /* Setting character width and height. */ xw.cw = ceilf(dc.font.width * cwscale); xw.ch = ceilf(dc.font.height * chscale); + xw.cyo = ceilf(dc.font.height * (chscale - 1) / 2); FcPatternDel(pattern, FC_SLANT); FcPatternAddInteger(pattern, FC_SLANT, FC_SLANT_ITALIC); @@ -3808,7 +3810,7 @@ xmakeglyphfontspecs(XftGlyphFontSpec *specs, const Glyph *glyphs, int len, int x font = &dc.bfont; frcflags = FRC_BOLD; } - yp = winy + font->ascent; + yp = winy + font->ascent + xw.cyo; } /* Lookup character index with default font. */ @@ -4019,12 +4021,12 @@ xdrawglyphfontspecs(const XftGlyphFontSpec *specs, Glyph base, int len, int x, i /* Render underline and strikethrough. */ if (base.mode & ATTR_UNDERLINE) { - XftDrawRect(xw.draw, fg, winx, winy + dc.font.ascent + 1, + XftDrawRect(xw.draw, fg, winx, winy + xw.cyo + dc.font.ascent + 1, width, 1); } if (base.mode & ATTR_STRUCK) { - XftDrawRect(xw.draw, fg, winx, winy + 2 * dc.font.ascent / 3, + XftDrawRect(xw.draw, fg, winx, winy + xw.cyo + 2 * dc.font.ascent / 3, width, 1); } |