| OLD | NEW |
| 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "content/renderer/render_view_impl.h" | 5 #include "content/renderer/render_view_impl.h" |
| 6 | 6 |
| 7 #include "content/common/renderer_preferences.h" | 7 #include "content/public/common/renderer_preferences.h" |
| 8 #include "third_party/WebKit/Source/WebKit/chromium/public/linux/WebFontRenderin
g.h" | 8 #include "third_party/WebKit/Source/WebKit/chromium/public/linux/WebFontRenderin
g.h" |
| 9 | 9 |
| 10 using WebKit::WebFontRendering; | 10 using WebKit::WebFontRendering; |
| 11 | 11 |
| 12 static SkPaint::Hinting RendererPreferencesToSkiaHinting( | 12 static SkPaint::Hinting RendererPreferencesToSkiaHinting( |
| 13 const RendererPreferences& prefs) { | 13 const content::RendererPreferences& prefs) { |
| 14 if (!prefs.should_antialias_text) { | 14 if (!prefs.should_antialias_text) { |
| 15 // When anti-aliasing is off, GTK maps all non-zero hinting settings to | 15 // When anti-aliasing is off, GTK maps all non-zero hinting settings to |
| 16 // 'Normal' hinting so we do the same. Otherwise, folks who have 'Slight' | 16 // 'Normal' hinting so we do the same. Otherwise, folks who have 'Slight' |
| 17 // hinting selected will see readable text in everything expect Chromium. | 17 // hinting selected will see readable text in everything expect Chromium. |
| 18 switch (prefs.hinting) { | 18 switch (prefs.hinting) { |
| 19 case RENDERER_PREFERENCES_HINTING_NONE: | 19 case content::RENDERER_PREFERENCES_HINTING_NONE: |
| 20 return SkPaint::kNo_Hinting; | 20 return SkPaint::kNo_Hinting; |
| 21 case RENDERER_PREFERENCES_HINTING_SYSTEM_DEFAULT: | 21 case content::RENDERER_PREFERENCES_HINTING_SYSTEM_DEFAULT: |
| 22 case RENDERER_PREFERENCES_HINTING_SLIGHT: | 22 case content::RENDERER_PREFERENCES_HINTING_SLIGHT: |
| 23 case RENDERER_PREFERENCES_HINTING_MEDIUM: | 23 case content::RENDERER_PREFERENCES_HINTING_MEDIUM: |
| 24 case RENDERER_PREFERENCES_HINTING_FULL: | 24 case content::RENDERER_PREFERENCES_HINTING_FULL: |
| 25 return SkPaint::kNormal_Hinting; | 25 return SkPaint::kNormal_Hinting; |
| 26 default: | 26 default: |
| 27 NOTREACHED(); | 27 NOTREACHED(); |
| 28 return SkPaint::kNormal_Hinting; | 28 return SkPaint::kNormal_Hinting; |
| 29 } | 29 } |
| 30 } | 30 } |
| 31 | 31 |
| 32 switch (prefs.hinting) { | 32 switch (prefs.hinting) { |
| 33 case RENDERER_PREFERENCES_HINTING_SYSTEM_DEFAULT: | 33 case content::RENDERER_PREFERENCES_HINTING_SYSTEM_DEFAULT: |
| 34 return SkPaint::kNormal_Hinting; | 34 return SkPaint::kNormal_Hinting; |
| 35 case RENDERER_PREFERENCES_HINTING_NONE: | 35 case content::RENDERER_PREFERENCES_HINTING_NONE: |
| 36 return SkPaint::kNo_Hinting; | 36 return SkPaint::kNo_Hinting; |
| 37 case RENDERER_PREFERENCES_HINTING_SLIGHT: | 37 case content::RENDERER_PREFERENCES_HINTING_SLIGHT: |
| 38 return SkPaint::kSlight_Hinting; | 38 return SkPaint::kSlight_Hinting; |
| 39 case RENDERER_PREFERENCES_HINTING_MEDIUM: | 39 case content::RENDERER_PREFERENCES_HINTING_MEDIUM: |
| 40 return SkPaint::kNormal_Hinting; | 40 return SkPaint::kNormal_Hinting; |
| 41 case RENDERER_PREFERENCES_HINTING_FULL: | 41 case content::RENDERER_PREFERENCES_HINTING_FULL: |
| 42 return SkPaint::kFull_Hinting; | 42 return SkPaint::kFull_Hinting; |
| 43 default: | 43 default: |
| 44 NOTREACHED(); | 44 NOTREACHED(); |
| 45 return SkPaint::kNormal_Hinting; | 45 return SkPaint::kNormal_Hinting; |
| 46 } | 46 } |
| 47 } | 47 } |
| 48 | 48 |
| 49 static SkFontHost::LCDOrder RendererPreferencesToSkiaLCDOrder( | 49 static SkFontHost::LCDOrder RendererPreferencesToSkiaLCDOrder( |
| 50 RendererPreferencesSubpixelRenderingEnum subpixel) { | 50 content::RendererPreferencesSubpixelRenderingEnum subpixel) { |
| 51 switch (subpixel) { | 51 switch (subpixel) { |
| 52 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_SYSTEM_DEFAULT: | 52 case content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_SYSTEM_DEFAULT: |
| 53 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_NONE: | 53 case content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_NONE: |
| 54 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_RGB: | 54 case content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_RGB: |
| 55 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VRGB: | 55 case content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VRGB: |
| 56 return SkFontHost::kRGB_LCDOrder; | 56 return SkFontHost::kRGB_LCDOrder; |
| 57 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_BGR: | 57 case content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_BGR: |
| 58 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VBGR: | 58 case content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VBGR: |
| 59 return SkFontHost::kBGR_LCDOrder; | 59 return SkFontHost::kBGR_LCDOrder; |
| 60 default: | 60 default: |
| 61 NOTREACHED(); | 61 NOTREACHED(); |
| 62 return SkFontHost::kRGB_LCDOrder; | 62 return SkFontHost::kRGB_LCDOrder; |
| 63 } | 63 } |
| 64 } | 64 } |
| 65 | 65 |
| 66 static SkFontHost::LCDOrientation | 66 static SkFontHost::LCDOrientation |
| 67 RendererPreferencesToSkiaLCDOrientation( | 67 RendererPreferencesToSkiaLCDOrientation( |
| 68 RendererPreferencesSubpixelRenderingEnum subpixel) { | 68 content::RendererPreferencesSubpixelRenderingEnum subpixel) { |
| 69 switch (subpixel) { | 69 switch (subpixel) { |
| 70 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_SYSTEM_DEFAULT: | 70 case content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_SYSTEM_DEFAULT: |
| 71 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_NONE: | 71 case content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_NONE: |
| 72 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_RGB: | 72 case content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_RGB: |
| 73 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_BGR: | 73 case content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_BGR: |
| 74 return SkFontHost::kHorizontal_LCDOrientation; | 74 return SkFontHost::kHorizontal_LCDOrientation; |
| 75 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VRGB: | 75 case content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VRGB: |
| 76 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VBGR: | 76 case content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VBGR: |
| 77 return SkFontHost::kVertical_LCDOrientation; | 77 return SkFontHost::kVertical_LCDOrientation; |
| 78 default: | 78 default: |
| 79 NOTREACHED(); | 79 NOTREACHED(); |
| 80 return SkFontHost::kHorizontal_LCDOrientation; | 80 return SkFontHost::kHorizontal_LCDOrientation; |
| 81 } | 81 } |
| 82 } | 82 } |
| 83 | 83 |
| 84 static bool RendererPreferencesToAntiAliasFlag( | 84 static bool RendererPreferencesToAntiAliasFlag( |
| 85 const RendererPreferences& prefs) { | 85 const content::RendererPreferences& prefs) { |
| 86 return prefs.should_antialias_text; | 86 return prefs.should_antialias_text; |
| 87 } | 87 } |
| 88 | 88 |
| 89 static bool RendererPreferencesToSubpixelGlyphsFlag( | 89 static bool RendererPreferencesToSubpixelGlyphsFlag( |
| 90 const RendererPreferences& prefs) { | 90 const content::RendererPreferences& prefs) { |
| 91 if (prefs.subpixel_rendering != | 91 if (prefs.subpixel_rendering != |
| 92 RENDERER_PREFERENCES_SUBPIXEL_RENDERING_SYSTEM_DEFAULT && | 92 content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_SYSTEM_DEFAULT && |
| 93 prefs.subpixel_rendering != | 93 prefs.subpixel_rendering != |
| 94 RENDERER_PREFERENCES_SUBPIXEL_RENDERING_NONE) { | 94 content::RENDERER_PREFERENCES_SUBPIXEL_RENDERING_NONE) { |
| 95 return true; | 95 return true; |
| 96 } | 96 } |
| 97 | 97 |
| 98 return false; | 98 return false; |
| 99 } | 99 } |
| 100 | 100 |
| 101 void RenderViewImpl::UpdateFontRenderingFromRendererPrefs() { | 101 void RenderViewImpl::UpdateFontRenderingFromRendererPrefs() { |
| 102 const RendererPreferences& prefs = renderer_preferences_; | 102 const content::RendererPreferences& prefs = renderer_preferences_; |
| 103 WebFontRendering::setHinting( | 103 WebFontRendering::setHinting(RendererPreferencesToSkiaHinting(prefs)); |
| 104 RendererPreferencesToSkiaHinting(prefs)); | 104 WebFontRendering::setLCDOrder(RendererPreferencesToSkiaLCDOrder( |
| 105 WebFontRendering::setLCDOrder( | 105 prefs.subpixel_rendering)); |
| 106 RendererPreferencesToSkiaLCDOrder(prefs.subpixel_rendering)); | 106 WebFontRendering::setLCDOrientation(RendererPreferencesToSkiaLCDOrientation( |
| 107 WebFontRendering::setLCDOrientation( | 107 prefs.subpixel_rendering)); |
| 108 RendererPreferencesToSkiaLCDOrientation(prefs.subpixel_rendering)); | |
| 109 WebFontRendering::setAntiAlias(RendererPreferencesToAntiAliasFlag(prefs)); | 108 WebFontRendering::setAntiAlias(RendererPreferencesToAntiAliasFlag(prefs)); |
| 110 WebFontRendering::setSubpixelGlyphs( | 109 WebFontRendering::setSubpixelGlyphs(RendererPreferencesToSubpixelGlyphsFlag( |
| 111 RendererPreferencesToSubpixelGlyphsFlag(prefs)); | 110 prefs)); |
| 112 } | 111 } |
| OLD | NEW |