diff options
-rw-r--r-- | HISTORY | 2 | ||||
-rw-r--r-- | genfontfile.c | 11 |
2 files changed, 9 insertions, 4 deletions
@@ -3199,3 +3199,5 @@ Video Disk Recorder Revision History - Fixed setting 'synced' in cRemux when recording radio channels (thanks to Laurence Abbott). - Removed the LOCK_THREAD from the LIRC thread (thanks to Ludwig Nussel). +- Fixed genfontfile.c (sometimes the character width was wrong, and the codes were + shifted one too far to the left). diff --git a/genfontfile.c b/genfontfile.c index bc171cf2..af45ad5d 100644 --- a/genfontfile.c +++ b/genfontfile.c @@ -240,7 +240,7 @@ printGlyph(FontInfoPtr font, int c) { PerGlyphInfoPtr glyph; unsigned char *bitmapData; - int width, height, spanLength; + int width, height, spanLength, charWidth; int x, y, l; char buf[1000], *b; @@ -253,12 +253,15 @@ printGlyph(FontInfoPtr font, int c) width = glyph->width; spanLength = (width + 7) / 8; height = glyph->height; + charWidth = glyph->xoffset + width; + if (charWidth < glyph->advance) + charWidth = glyph->advance; printf(" { // %d\n", c); - printf(" %d, %d,\n", glyph->advance, font->max_ascent + font->max_descent); + printf(" %d, %d,\n", charWidth, font->max_ascent + font->max_descent); for (y = 0; y < font->max_ascent - glyph->yoffset - height; y++) { printf(" 0x%08X, // ", 0); - for (x = 0; x < glyph->xoffset + width || x < glyph->advance; x++) + for (x = 0; x < charWidth; x++) putchar('.'); putchar('\n'); } @@ -269,13 +272,13 @@ printGlyph(FontInfoPtr font, int c) *b++ = '.'; if (bitmapData) { for (x = 0; x < width; x++) { + l <<= 1; if (bitmapData[y * spanLength + x / 8] & (1 << (x & 7))) { *b++ = '*'; l |= 1; } else *b++ = '.'; - l <<= 1; } for (x = 0; x < glyph->advance - width - glyph->xoffset; x++) { *b++ = '.'; |