Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/public/common/renderer_preferences.h" | 7 #include "content/public/common/renderer_preferences.h" |
| 8 #include "third_party/WebKit/public/web/linux/WebFontRendering.h" | 8 #include "third_party/WebKit/public/web/linux/WebFontRendering.h" |
| 9 | 9 |
| 10 using blink::WebFontRendering; | 10 using blink::WebFontRendering; |
| 11 | 11 |
| 12 namespace content { | 12 namespace content { |
| 13 | 13 |
| 14 static SkPaint::Hinting RendererPreferencesToSkiaHinting( | 14 namespace { |
| 15 | |
| 16 SkPaint::Hinting RendererPreferencesToSkiaHinting( | |
| 15 const RendererPreferences& prefs) { | 17 const RendererPreferences& prefs) { |
| 16 if (!prefs.should_antialias_text) { | 18 if (!prefs.should_antialias_text) { |
| 17 // When anti-aliasing is off, GTK maps all non-zero hinting settings to | 19 // When anti-aliasing is off, GTK maps all non-zero hinting settings to |
|
Daniel Erat
2014/07/22 19:58:56
perhaps FontRenderParams should also be doing this
msw
2014/07/22 20:58:35
It'd be good to file a bug if we can repro such a
Daniel Erat
2014/07/22 21:15:50
sure, http://crbug.com/396239
| |
| 18 // 'Normal' hinting so we do the same. Otherwise, folks who have 'Slight' | 20 // 'Normal' hinting so we do the same. Otherwise, folks who have 'Slight' |
| 19 // hinting selected will see readable text in everything expect Chromium. | 21 // hinting selected will see readable text in everything expect Chromium. |
| 20 switch (prefs.hinting) { | 22 switch (prefs.hinting) { |
| 21 case RENDERER_PREFERENCES_HINTING_NONE: | 23 case gfx::FontRenderParams::HINTING_NONE: |
| 22 return SkPaint::kNo_Hinting; | 24 return SkPaint::kNo_Hinting; |
| 23 case RENDERER_PREFERENCES_HINTING_SYSTEM_DEFAULT: | 25 case gfx::FontRenderParams::HINTING_SLIGHT: |
| 24 case RENDERER_PREFERENCES_HINTING_SLIGHT: | 26 case gfx::FontRenderParams::HINTING_MEDIUM: |
| 25 case RENDERER_PREFERENCES_HINTING_MEDIUM: | 27 case gfx::FontRenderParams::HINTING_FULL: |
| 26 case RENDERER_PREFERENCES_HINTING_FULL: | |
| 27 return SkPaint::kNormal_Hinting; | 28 return SkPaint::kNormal_Hinting; |
| 28 default: | 29 default: |
| 29 NOTREACHED(); | 30 NOTREACHED(); |
| 30 return SkPaint::kNormal_Hinting; | 31 return SkPaint::kNormal_Hinting; |
| 31 } | 32 } |
| 32 } | 33 } |
| 33 | 34 |
| 34 switch (prefs.hinting) { | 35 switch (prefs.hinting) { |
| 35 case RENDERER_PREFERENCES_HINTING_SYSTEM_DEFAULT: | 36 case gfx::FontRenderParams::HINTING_NONE: return SkPaint::kNo_Hinting; |
| 36 return SkPaint::kNormal_Hinting; | 37 case gfx::FontRenderParams::HINTING_SLIGHT: return SkPaint::kSlight_Hinting; |
| 37 case RENDERER_PREFERENCES_HINTING_NONE: | 38 case gfx::FontRenderParams::HINTING_MEDIUM: return SkPaint::kNormal_Hinting; |
| 38 return SkPaint::kNo_Hinting; | 39 case gfx::FontRenderParams::HINTING_FULL: return SkPaint::kFull_Hinting; |
| 39 case RENDERER_PREFERENCES_HINTING_SLIGHT: | 40 default: |
| 40 return SkPaint::kSlight_Hinting; | 41 NOTREACHED(); |
| 41 case RENDERER_PREFERENCES_HINTING_MEDIUM: | 42 return SkPaint::kNormal_Hinting; |
| 42 return SkPaint::kNormal_Hinting; | 43 } |
| 43 case RENDERER_PREFERENCES_HINTING_FULL: | 44 } |
| 44 return SkPaint::kFull_Hinting; | 45 |
| 45 default: | 46 SkFontHost::LCDOrder RendererPreferencesToSkiaLCDOrder( |
| 46 NOTREACHED(); | 47 const RendererPreferences& prefs) { |
| 47 return SkPaint::kNormal_Hinting; | 48 switch (prefs.subpixel_rendering) { |
| 49 case gfx::FontRenderParams::SUBPIXEL_RENDERING_NONE: | |
| 50 case gfx::FontRenderParams::SUBPIXEL_RENDERING_RGB: | |
| 51 case gfx::FontRenderParams::SUBPIXEL_RENDERING_VRGB: | |
| 52 return SkFontHost::kRGB_LCDOrder; | |
| 53 case gfx::FontRenderParams::SUBPIXEL_RENDERING_BGR: | |
| 54 case gfx::FontRenderParams::SUBPIXEL_RENDERING_VBGR: | |
| 55 return SkFontHost::kBGR_LCDOrder; | |
| 56 default: | |
| 57 NOTREACHED(); | |
| 58 return SkFontHost::kRGB_LCDOrder; | |
| 48 } | 59 } |
| 49 } | 60 } |
| 50 | 61 |
| 51 static SkFontHost::LCDOrder RendererPreferencesToSkiaLCDOrder( | 62 SkFontHost::LCDOrientation RendererPreferencesToSkiaLCDOrientation( |
| 52 RendererPreferencesSubpixelRenderingEnum subpixel) { | 63 const RendererPreferences& prefs) { |
| 53 switch (subpixel) { | 64 switch (prefs.subpixel_rendering) { |
| 54 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_SYSTEM_DEFAULT: | 65 case gfx::FontRenderParams::SUBPIXEL_RENDERING_NONE: |
| 55 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_NONE: | 66 case gfx::FontRenderParams::SUBPIXEL_RENDERING_RGB: |
| 56 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_RGB: | 67 case gfx::FontRenderParams::SUBPIXEL_RENDERING_BGR: |
| 57 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VRGB: | 68 return SkFontHost::kHorizontal_LCDOrientation; |
| 58 return SkFontHost::kRGB_LCDOrder; | 69 case gfx::FontRenderParams::SUBPIXEL_RENDERING_VRGB: |
| 59 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_BGR: | 70 case gfx::FontRenderParams::SUBPIXEL_RENDERING_VBGR: |
| 60 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VBGR: | 71 return SkFontHost::kVertical_LCDOrientation; |
| 61 return SkFontHost::kBGR_LCDOrder; | 72 default: |
| 62 default: | 73 NOTREACHED(); |
| 63 NOTREACHED(); | 74 return SkFontHost::kHorizontal_LCDOrientation; |
| 64 return SkFontHost::kRGB_LCDOrder; | |
| 65 } | 75 } |
| 66 } | 76 } |
| 67 | 77 |
| 68 static SkFontHost::LCDOrientation | 78 } // namespace |
| 69 RendererPreferencesToSkiaLCDOrientation( | |
| 70 RendererPreferencesSubpixelRenderingEnum subpixel) { | |
| 71 switch (subpixel) { | |
| 72 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_SYSTEM_DEFAULT: | |
| 73 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_NONE: | |
| 74 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_RGB: | |
| 75 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_BGR: | |
| 76 return SkFontHost::kHorizontal_LCDOrientation; | |
| 77 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VRGB: | |
| 78 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VBGR: | |
| 79 return SkFontHost::kVertical_LCDOrientation; | |
| 80 default: | |
| 81 NOTREACHED(); | |
| 82 return SkFontHost::kHorizontal_LCDOrientation; | |
| 83 } | |
| 84 } | |
| 85 | |
| 86 static bool RendererPreferencesToAntiAliasFlag( | |
| 87 const RendererPreferences& prefs) { | |
| 88 return prefs.should_antialias_text; | |
| 89 } | |
| 90 | |
| 91 static bool RendererPreferencesToSubpixelRenderingFlag( | |
| 92 const RendererPreferences& prefs) { | |
| 93 if (prefs.subpixel_rendering != | |
| 94 RENDERER_PREFERENCES_SUBPIXEL_RENDERING_SYSTEM_DEFAULT && | |
| 95 prefs.subpixel_rendering != | |
| 96 RENDERER_PREFERENCES_SUBPIXEL_RENDERING_NONE) { | |
| 97 return true; | |
| 98 } | |
| 99 return false; | |
| 100 } | |
| 101 | 79 |
| 102 void RenderViewImpl::UpdateFontRenderingFromRendererPrefs() { | 80 void RenderViewImpl::UpdateFontRenderingFromRendererPrefs() { |
| 103 const RendererPreferences& prefs = renderer_preferences_; | 81 const RendererPreferences& prefs = renderer_preferences_; |
| 104 WebFontRendering::setHinting(RendererPreferencesToSkiaHinting(prefs)); | 82 WebFontRendering::setHinting(RendererPreferencesToSkiaHinting(prefs)); |
| 105 WebFontRendering::setAutoHint(prefs.use_autohinter); | 83 WebFontRendering::setAutoHint(prefs.use_autohinter); |
| 106 WebFontRendering::setUseBitmaps(prefs.use_bitmaps); | 84 WebFontRendering::setUseBitmaps(prefs.use_bitmaps); |
| 107 WebFontRendering::setLCDOrder( | 85 WebFontRendering::setLCDOrder(RendererPreferencesToSkiaLCDOrder(prefs)); |
| 108 RendererPreferencesToSkiaLCDOrder(prefs.subpixel_rendering)); | |
| 109 WebFontRendering::setLCDOrientation( | 86 WebFontRendering::setLCDOrientation( |
| 110 RendererPreferencesToSkiaLCDOrientation(prefs.subpixel_rendering)); | 87 RendererPreferencesToSkiaLCDOrientation(prefs)); |
| 111 WebFontRendering::setAntiAlias(RendererPreferencesToAntiAliasFlag(prefs)); | 88 WebFontRendering::setAntiAlias(prefs.should_antialias_text); |
| 112 WebFontRendering::setSubpixelRendering( | 89 WebFontRendering::setSubpixelRendering( |
| 113 RendererPreferencesToSubpixelRenderingFlag(prefs)); | 90 prefs.subpixel_rendering != |
| 91 gfx::FontRenderParams::SUBPIXEL_RENDERING_NONE); | |
| 114 WebFontRendering::setSubpixelPositioning(prefs.use_subpixel_positioning); | 92 WebFontRendering::setSubpixelPositioning(prefs.use_subpixel_positioning); |
| 115 } | 93 } |
| 116 | 94 |
| 117 } // namespace content | 95 } // namespace content |
| OLD | NEW |