diff options
Diffstat (limited to 'src/ports')
-rw-r--r-- | src/ports/SkFontHost_FreeType.cpp | 2 | ||||
-rw-r--r-- | src/ports/SkFontHost_mac_atsui.cpp | 2 | ||||
-rw-r--r-- | src/ports/SkFontHost_mac_coretext.cpp | 2 | ||||
-rw-r--r-- | src/ports/SkFontHost_none.cpp | 2 | ||||
-rwxr-xr-x | src/ports/SkFontHost_win.cpp | 45 | ||||
-rw-r--r-- | src/ports/SkFontHost_win_dw.cpp | 2 |
6 files changed, 41 insertions, 14 deletions
diff --git a/src/ports/SkFontHost_FreeType.cpp b/src/ports/SkFontHost_FreeType.cpp index 5d351331cf..ce8f409731 100644 --- a/src/ports/SkFontHost_FreeType.cpp +++ b/src/ports/SkFontHost_FreeType.cpp @@ -637,7 +637,7 @@ static bool isAxisAligned(const SkScalerContext::Rec& rec) { bothZero(rec.fPost2x2[0][0], rec.fPost2x2[1][1])); } -void SkFontHost::FilterRec(SkScalerContext::Rec* rec) { +void SkFontHost::FilterRec(SkScalerContext::Rec* rec, SkTypeface*) { //BOGUS: http://code.google.com/p/chromium/issues/detail?id=121119 //Cap the requested size as larger sizes give bogus values. //Remove when http://code.google.com/p/skia/issues/detail?id=554 is fixed. diff --git a/src/ports/SkFontHost_mac_atsui.cpp b/src/ports/SkFontHost_mac_atsui.cpp index f8251ab0bb..84f7f0b224 100644 --- a/src/ports/SkFontHost_mac_atsui.cpp +++ b/src/ports/SkFontHost_mac_atsui.cpp @@ -97,7 +97,7 @@ private: static OSStatus Close(void *cb); }; -void SkFontHost::FilterRec(SkScalerContext::Rec* rec) { +void SkFontHost::FilterRec(SkScalerContext::Rec* rec, SkTypeface*) { // we only support 2 levels of hinting SkPaint::Hinting h = rec->getHinting(); if (SkPaint::kSlight_Hinting == h) { diff --git a/src/ports/SkFontHost_mac_coretext.cpp b/src/ports/SkFontHost_mac_coretext.cpp index 622b8ede1f..e385337388 100644 --- a/src/ports/SkFontHost_mac_coretext.cpp +++ b/src/ports/SkFontHost_mac_coretext.cpp @@ -1811,7 +1811,7 @@ SkFontID SkFontHost::NextLogicalFont(SkFontID currFontID, SkFontID origFontID) { return nextFontID; } -void SkFontHost::FilterRec(SkScalerContext::Rec* rec) { +void SkFontHost::FilterRec(SkScalerContext::Rec* rec, SkTypeface*) { unsigned flagsWeDontSupport = SkScalerContext::kDevKernText_Flag | SkScalerContext::kAutohinting_Flag; diff --git a/src/ports/SkFontHost_none.cpp b/src/ports/SkFontHost_none.cpp index a68391915c..21eda8e1b8 100644 --- a/src/ports/SkFontHost_none.cpp +++ b/src/ports/SkFontHost_none.cpp @@ -37,7 +37,7 @@ SkAdvancedTypefaceMetrics* SkFontHost::GetAdvancedTypefaceMetrics( return NULL; } -void SkFontHost::FilterRec(SkScalerContext::Rec* rec) { +void SkFontHost::FilterRec(SkScalerContext::Rec* rec, SkTypeface*) { } /////////////////////////////////////////////////////////////////////////////// diff --git a/src/ports/SkFontHost_win.cpp b/src/ports/SkFontHost_win.cpp index 015df7835b..f2603e99a8 100755 --- a/src/ports/SkFontHost_win.cpp +++ b/src/ports/SkFontHost_win.cpp @@ -210,11 +210,39 @@ static unsigned calculateOutlineGlyphCount(HDC hdc) { class LogFontTypeface : public SkTypeface { public: - LogFontTypeface(SkTypeface::Style style, SkFontID fontID, const LOGFONT& lf) : - SkTypeface(style, fontID, false), fLogFont(lf), fSerializeAsStream(false) {} + LogFontTypeface(SkTypeface::Style style, SkFontID fontID, const LOGFONT& lf, bool serializeAsStream = false) : + SkTypeface(style, fontID, false), fLogFont(lf), fSerializeAsStream(serializeAsStream) { + + // If the font has cubic outlines, it will not be rendered with ClearType. + HFONT font = CreateFontIndirect(&lf); + + HDC deviceContext = ::CreateCompatibleDC(NULL); + HFONT savefont = (HFONT)SelectObject(deviceContext, font); + + TEXTMETRIC textMetric; + if (0 == GetTextMetrics(deviceContext, &textMetric)) { + SkFontHost::EnsureTypefaceAccessible(*this); + if (0 == GetTextMetrics(deviceContext, &textMetric)) { + textMetric.tmPitchAndFamily = TMPF_TRUETYPE; + } + } + if (deviceContext) { + ::SelectObject(deviceContext, savefont); + ::DeleteDC(deviceContext); + } + if (font) { + ::DeleteObject(font); + } + + // Used a logfont on a memory context, should never get a device font. + // Therefore all TMPF_DEVICE will be PostScript (cubic) fonts. + fCanBeLCD = !((textMetric.tmPitchAndFamily & TMPF_VECTOR) && + (textMetric.tmPitchAndFamily & TMPF_DEVICE)); + } LOGFONT fLogFont; bool fSerializeAsStream; + bool fCanBeLCD; static LogFontTypeface* Create(const LOGFONT& lf) { SkTypeface::Style style = get_style(lf); @@ -229,8 +257,7 @@ public: * Takes ownership of fontMemResource. */ FontMemResourceTypeface(SkTypeface::Style style, SkFontID fontID, const LOGFONT& lf, HANDLE fontMemResource) : - LogFontTypeface(style, fontID, lf), fFontMemResource(fontMemResource) { - fSerializeAsStream = true; + LogFontTypeface(style, fontID, lf, true), fFontMemResource(fontMemResource) { } HANDLE fFontMemResource; @@ -1673,7 +1700,7 @@ SkTypeface* SkFontHost::CreateTypefaceFromFile(const char path[]) { return face; } -void SkFontHost::FilterRec(SkScalerContext::Rec* rec) { +void SkFontHost::FilterRec(SkScalerContext::Rec* rec, SkTypeface* typeface) { unsigned flagsWeDontSupport = SkScalerContext::kDevKernText_Flag | SkScalerContext::kAutohinting_Flag | SkScalerContext::kEmbeddedBitmapText_Flag | @@ -1713,9 +1740,9 @@ void SkFontHost::FilterRec(SkScalerContext::Rec* rec) { } #endif -#if 0 - if (SkMask::kLCD16_Format == rec->fMaskFormat) { - rec->fMaskFormat = SkMask::kLCD32_Format; + LogFontTypeface* logfontTypeface = static_cast<LogFontTypeface*>(typeface); + if (!logfontTypeface->fCanBeLCD && isLCD(*rec)) { + rec->fMaskFormat = SkMask::kA8_Format; + rec->fFlags &= ~SkScalerContext::kGenA8FromLCD_Flag; } -#endif } diff --git a/src/ports/SkFontHost_win_dw.cpp b/src/ports/SkFontHost_win_dw.cpp index d91cfa9b02..82d44eeb33 100644 --- a/src/ports/SkFontHost_win_dw.cpp +++ b/src/ports/SkFontHost_win_dw.cpp @@ -1264,7 +1264,7 @@ SkTypeface* SkFontHost::CreateTypefaceFromFile(const char path[]) { return NULL; } -void SkFontHost::FilterRec(SkScalerContext::Rec* rec) { +void SkFontHost::FilterRec(SkScalerContext::Rec* rec, SkTypeface*) { unsigned flagsWeDontSupport = SkScalerContext::kDevKernText_Flag | SkScalerContext::kAutohinting_Flag | SkScalerContext::kEmbeddedBitmapText_Flag | |