Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(69)

Side by Side Diff: content/renderer/render_view_linux.cc

Issue 410413008: Revert of content: Remove RendererPreferences font-rendering enums. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 6 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « content/public/common/renderer_preferences.cc ('k') | ui/gfx/font_render_params.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 namespace { 14 static SkPaint::Hinting RendererPreferencesToSkiaHinting(
15
16 SkPaint::Hinting RendererPreferencesToSkiaHinting(
17 const RendererPreferences& prefs) { 15 const RendererPreferences& prefs) {
18 if (!prefs.should_antialias_text) { 16 if (!prefs.should_antialias_text) {
19 // When anti-aliasing is off, GTK maps all non-zero hinting settings to 17 // When anti-aliasing is off, GTK maps all non-zero hinting settings to
20 // 'Normal' hinting so we do the same. Otherwise, folks who have 'Slight' 18 // 'Normal' hinting so we do the same. Otherwise, folks who have 'Slight'
21 // hinting selected will see readable text in everything expect Chromium. 19 // hinting selected will see readable text in everything expect Chromium.
22 switch (prefs.hinting) { 20 switch (prefs.hinting) {
23 case gfx::FontRenderParams::HINTING_NONE: 21 case RENDERER_PREFERENCES_HINTING_NONE:
24 return SkPaint::kNo_Hinting; 22 return SkPaint::kNo_Hinting;
25 case gfx::FontRenderParams::HINTING_SLIGHT: 23 case RENDERER_PREFERENCES_HINTING_SYSTEM_DEFAULT:
26 case gfx::FontRenderParams::HINTING_MEDIUM: 24 case RENDERER_PREFERENCES_HINTING_SLIGHT:
27 case gfx::FontRenderParams::HINTING_FULL: 25 case RENDERER_PREFERENCES_HINTING_MEDIUM:
26 case RENDERER_PREFERENCES_HINTING_FULL:
28 return SkPaint::kNormal_Hinting; 27 return SkPaint::kNormal_Hinting;
29 default: 28 default:
30 NOTREACHED(); 29 NOTREACHED();
31 return SkPaint::kNormal_Hinting; 30 return SkPaint::kNormal_Hinting;
32 } 31 }
33 } 32 }
34 33
35 switch (prefs.hinting) { 34 switch (prefs.hinting) {
36 case gfx::FontRenderParams::HINTING_NONE: return SkPaint::kNo_Hinting; 35 case RENDERER_PREFERENCES_HINTING_SYSTEM_DEFAULT:
37 case gfx::FontRenderParams::HINTING_SLIGHT: return SkPaint::kSlight_Hinting; 36 return SkPaint::kNormal_Hinting;
38 case gfx::FontRenderParams::HINTING_MEDIUM: return SkPaint::kNormal_Hinting; 37 case RENDERER_PREFERENCES_HINTING_NONE:
39 case gfx::FontRenderParams::HINTING_FULL: return SkPaint::kFull_Hinting; 38 return SkPaint::kNo_Hinting;
40 default: 39 case RENDERER_PREFERENCES_HINTING_SLIGHT:
41 NOTREACHED(); 40 return SkPaint::kSlight_Hinting;
42 return SkPaint::kNormal_Hinting; 41 case RENDERER_PREFERENCES_HINTING_MEDIUM:
43 } 42 return SkPaint::kNormal_Hinting;
44 } 43 case RENDERER_PREFERENCES_HINTING_FULL:
45 44 return SkPaint::kFull_Hinting;
46 SkFontHost::LCDOrder RendererPreferencesToSkiaLCDOrder( 45 default:
47 const RendererPreferences& prefs) { 46 NOTREACHED();
48 switch (prefs.subpixel_rendering) { 47 return SkPaint::kNormal_Hinting;
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;
59 } 48 }
60 } 49 }
61 50
62 SkFontHost::LCDOrientation RendererPreferencesToSkiaLCDOrientation( 51 static SkFontHost::LCDOrder RendererPreferencesToSkiaLCDOrder(
63 const RendererPreferences& prefs) { 52 RendererPreferencesSubpixelRenderingEnum subpixel) {
64 switch (prefs.subpixel_rendering) { 53 switch (subpixel) {
65 case gfx::FontRenderParams::SUBPIXEL_RENDERING_NONE: 54 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_SYSTEM_DEFAULT:
66 case gfx::FontRenderParams::SUBPIXEL_RENDERING_RGB: 55 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_NONE:
67 case gfx::FontRenderParams::SUBPIXEL_RENDERING_BGR: 56 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_RGB:
68 return SkFontHost::kHorizontal_LCDOrientation; 57 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VRGB:
69 case gfx::FontRenderParams::SUBPIXEL_RENDERING_VRGB: 58 return SkFontHost::kRGB_LCDOrder;
70 case gfx::FontRenderParams::SUBPIXEL_RENDERING_VBGR: 59 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_BGR:
71 return SkFontHost::kVertical_LCDOrientation; 60 case RENDERER_PREFERENCES_SUBPIXEL_RENDERING_VBGR:
72 default: 61 return SkFontHost::kBGR_LCDOrder;
73 NOTREACHED(); 62 default:
74 return SkFontHost::kHorizontal_LCDOrientation; 63 NOTREACHED();
64 return SkFontHost::kRGB_LCDOrder;
75 } 65 }
76 } 66 }
77 67
78 } // namespace 68 static SkFontHost::LCDOrientation
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 }
79 101
80 void RenderViewImpl::UpdateFontRenderingFromRendererPrefs() { 102 void RenderViewImpl::UpdateFontRenderingFromRendererPrefs() {
81 const RendererPreferences& prefs = renderer_preferences_; 103 const RendererPreferences& prefs = renderer_preferences_;
82 WebFontRendering::setHinting(RendererPreferencesToSkiaHinting(prefs)); 104 WebFontRendering::setHinting(RendererPreferencesToSkiaHinting(prefs));
83 WebFontRendering::setAutoHint(prefs.use_autohinter); 105 WebFontRendering::setAutoHint(prefs.use_autohinter);
84 WebFontRendering::setUseBitmaps(prefs.use_bitmaps); 106 WebFontRendering::setUseBitmaps(prefs.use_bitmaps);
85 WebFontRendering::setLCDOrder(RendererPreferencesToSkiaLCDOrder(prefs)); 107 WebFontRendering::setLCDOrder(
108 RendererPreferencesToSkiaLCDOrder(prefs.subpixel_rendering));
86 WebFontRendering::setLCDOrientation( 109 WebFontRendering::setLCDOrientation(
87 RendererPreferencesToSkiaLCDOrientation(prefs)); 110 RendererPreferencesToSkiaLCDOrientation(prefs.subpixel_rendering));
88 WebFontRendering::setAntiAlias(prefs.should_antialias_text); 111 WebFontRendering::setAntiAlias(RendererPreferencesToAntiAliasFlag(prefs));
89 WebFontRendering::setSubpixelRendering( 112 WebFontRendering::setSubpixelRendering(
90 prefs.subpixel_rendering != 113 RendererPreferencesToSubpixelRenderingFlag(prefs));
91 gfx::FontRenderParams::SUBPIXEL_RENDERING_NONE);
92 WebFontRendering::setSubpixelPositioning(prefs.use_subpixel_positioning); 114 WebFontRendering::setSubpixelPositioning(prefs.use_subpixel_positioning);
93 } 115 }
94 116
95 } // namespace content 117 } // namespace content
OLDNEW
« no previous file with comments | « content/public/common/renderer_preferences.cc ('k') | ui/gfx/font_render_params.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698