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

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

Issue 417953006: Reland r285145: Remove RendererPreferences font-rendering enums. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: merge again (cleanly... not sure why cq patch step is failing) Created 6 years, 4 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 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
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
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