| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2006, 2007 Apple Computer, Inc. | 2 * Copyright (C) 2006, 2007 Apple Computer, Inc. |
| 3 * Copyright (c) 2006, 2007, 2008, 2009, 2012 Google Inc. All rights reserved. | 3 * Copyright (c) 2006, 2007, 2008, 2009, 2012 Google Inc. All rights reserved. |
| 4 * | 4 * |
| 5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
| 6 * modification, are permitted provided that the following conditions are | 6 * modification, are permitted provided that the following conditions are |
| 7 * met: | 7 * met: |
| 8 * | 8 * |
| 9 * * Redistributions of source code must retain the above copyright | 9 * * Redistributions of source code must retain the above copyright |
| 10 * notice, this list of conditions and the following disclaimer. | 10 * notice, this list of conditions and the following disclaimer. |
| (...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 90 // static | 90 // static |
| 91 void FontCache::setStatusFontMetrics(const wchar_t* familyName, int32_t fontHeig
ht) | 91 void FontCache::setStatusFontMetrics(const wchar_t* familyName, int32_t fontHeig
ht) |
| 92 { | 92 { |
| 93 s_statusFontFamilyName = new AtomicString(familyName); | 93 s_statusFontFamilyName = new AtomicString(familyName); |
| 94 s_statusFontHeight = ensureMinimumFontHeightIfNeeded(fontHeight); | 94 s_statusFontHeight = ensureMinimumFontHeightIfNeeded(fontHeight); |
| 95 } | 95 } |
| 96 | 96 |
| 97 FontCache::FontCache() | 97 FontCache::FontCache() |
| 98 : m_purgePreventCount(0) | 98 : m_purgePreventCount(0) |
| 99 { | 99 { |
| 100 SkFontMgr* fontManager; | 100 if (s_fontManager) { |
| 101 | 101 m_fontManager = s_fontManager; |
| 102 if (s_useDirectWrite) { | 102 } else if (s_useDirectWrite) { |
| 103 fontManager = SkFontMgr_New_DirectWrite(s_directWriteFactory); | 103 m_fontManager = adoptRef(SkFontMgr_New_DirectWrite()); |
| 104 s_useSubpixelPositioning = true; | |
| 105 } else { | 104 } else { |
| 106 fontManager = SkFontMgr_New_GDI(); | 105 m_fontManager = adoptRef(SkFontMgr_New_GDI()); |
| 107 // Subpixel text positioning is not supported by the GDI backend. | |
| 108 s_useSubpixelPositioning = false; | |
| 109 } | 106 } |
| 110 | 107 |
| 111 ASSERT(fontManager); | 108 // Subpixel text positioning is only supported by the DirectWrite backend (n
ot GDI). |
| 112 m_fontManager = adoptPtr(fontManager); | 109 s_useSubpixelPositioning = s_useDirectWrite; |
| 110 |
| 111 ASSERT(m_fontManager.get()); |
| 113 } | 112 } |
| 114 | 113 |
| 115 | 114 |
| 116 // Given the desired base font, this will create a SimpleFontData for a specific | 115 // Given the desired base font, this will create a SimpleFontData for a specific |
| 117 // font that can be used to render the given range of characters. | 116 // font that can be used to render the given range of characters. |
| 118 PassRefPtr<SimpleFontData> FontCache::fallbackFontForCharacter( | 117 PassRefPtr<SimpleFontData> FontCache::fallbackFontForCharacter( |
| 119 const FontDescription& fontDescription, UChar32 character, | 118 const FontDescription& fontDescription, UChar32 character, |
| 120 const SimpleFontData* originalFontData) | 119 const SimpleFontData* originalFontData) |
| 121 { | 120 { |
| 122 // First try the specified font with standard style & weight. | 121 // First try the specified font with standard style & weight. |
| (...skipping 297 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 420 if (typefacesMatchesFamily(tf.get(), family)) { | 419 if (typefacesMatchesFamily(tf.get(), family)) { |
| 421 result->setMinSizeForSubpixel(minSizeForSubpixelForFont); | 420 result->setMinSizeForSubpixel(minSizeForSubpixelForFont); |
| 422 break; | 421 break; |
| 423 } | 422 } |
| 424 } | 423 } |
| 425 | 424 |
| 426 return result.release(); | 425 return result.release(); |
| 427 } | 426 } |
| 428 | 427 |
| 429 } // namespace blink | 428 } // namespace blink |
| OLD | NEW |