FreeType: fix garbled bitmap glyphs.

At some point (probably in one of the LCD patches), the fMaskFormat
for bitmap glyphs changed from kA8 to kBW. Formerly, bitmap glyphs
were always transformed into A8 format. With this patch, we check the
fMaskFormat and pick the correct transform at run time.

http://code.google.com/p/chromium/issues/detail?id=18531
http://codereview.appspot.com/104071


git-svn-id: http://skia.googlecode.com/svn/trunk@313 2bbb7eff-a529-9590-31e7-b0007b416f81
This commit is contained in:
agl@chromium.org 2009-08-11 17:22:38 +00:00
parent 4484d23ab4
commit 558434a9e1

View File

@ -693,7 +693,9 @@ void SkScalerContext_FreeType::generateImage(const SkGlyph& glyph) {
const uint8_t* src = (const uint8_t*)fFace->glyph->bitmap.buffer; const uint8_t* src = (const uint8_t*)fFace->glyph->bitmap.buffer;
uint8_t* dst = (uint8_t*)glyph.fImage; uint8_t* dst = (uint8_t*)glyph.fImage;
if (fFace->glyph->bitmap.pixel_mode == FT_PIXEL_MODE_GRAY) { if (fFace->glyph->bitmap.pixel_mode == FT_PIXEL_MODE_GRAY ||
(fFace->glyph->bitmap.pixel_mode == FT_PIXEL_MODE_MONO &&
glyph.fMaskFormat == SkMask::kBW_Format)) {
unsigned srcRowBytes = fFace->glyph->bitmap.pitch; unsigned srcRowBytes = fFace->glyph->bitmap.pitch;
unsigned dstRowBytes = glyph.rowBytes(); unsigned dstRowBytes = glyph.rowBytes();
unsigned minRowBytes = SkMin32(srcRowBytes, dstRowBytes); unsigned minRowBytes = SkMin32(srcRowBytes, dstRowBytes);
@ -705,7 +707,8 @@ void SkScalerContext_FreeType::generateImage(const SkGlyph& glyph) {
src += srcRowBytes; src += srcRowBytes;
dst += dstRowBytes; dst += dstRowBytes;
} }
} else if (fFace->glyph->bitmap.pixel_mode == FT_PIXEL_MODE_MONO) { } else if (fFace->glyph->bitmap.pixel_mode == FT_PIXEL_MODE_MONO &&
glyph.fMaskFormat == SkMask::kA8_Format) {
for (int y = 0; y < fFace->glyph->bitmap.rows; ++y) { for (int y = 0; y < fFace->glyph->bitmap.rows; ++y) {
uint8_t byte = 0; uint8_t byte = 0;
int bits = 0; int bits = 0;
@ -726,6 +729,8 @@ void SkScalerContext_FreeType::generateImage(const SkGlyph& glyph) {
src += fFace->glyph->bitmap.pitch; src += fFace->glyph->bitmap.pitch;
dst += glyph.rowBytes(); dst += glyph.rowBytes();
} }
} else {
SkASSERT(!"unknown glyph bitmap transform needed");
} }
if (lcdRenderMode) if (lcdRenderMode)