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

Side by Side Diff: gfx/font_skia.cc

Issue 2825018: Canvas refactoring part 3.... (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: '' Created 10 years, 6 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
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2010 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 "gfx/font.h" 5 #include "gfx/font.h"
6 6
7 #include <gdk/gdk.h> 7 #include <gdk/gdk.h>
8 #include <map> 8 #include <map>
9 #include <pango/pango.h> 9 #include <pango/pango.h>
10 10
11 #include "base/logging.h" 11 #include "base/logging.h"
12 #include "base/string_piece.h" 12 #include "base/string_piece.h"
13 #include "base/sys_string_conversions.h" 13 #include "base/sys_string_conversions.h"
14 #include "gfx/canvas.h" 14 #include "gfx/canvas_skia.h"
15 #include "third_party/skia/include/core/SkTypeface.h" 15 #include "third_party/skia/include/core/SkTypeface.h"
16 #include "third_party/skia/include/core/SkPaint.h" 16 #include "third_party/skia/include/core/SkPaint.h"
17 17
18 namespace { 18 namespace {
19 19
20 // The font family name which is used when a user's application font for 20 // The font family name which is used when a user's application font for
21 // GNOME/KDE is a non-scalable one. The name should be listed in the 21 // GNOME/KDE is a non-scalable one. The name should be listed in the
22 // IsFallbackFontAllowed function in skia/ext/SkFontHost_fontconfig_direct.cpp. 22 // IsFallbackFontAllowed function in skia/ext/SkFontHost_fontconfig_direct.cpp.
23 const char* kFallbackFontFamilyName = "sans"; 23 const char* kFallbackFontFamilyName = "sans";
24 24
(...skipping 145 matching lines...) Expand 10 before | Expand all | Expand 10 after
170 paint->setSubpixelText(false); 170 paint->setSubpixelText(false);
171 paint->setTextSize(SkFloatToScalar(font_size_ * Font::GetPangoScaleFactor())); 171 paint->setTextSize(SkFloatToScalar(font_size_ * Font::GetPangoScaleFactor()));
172 paint->setTypeface(typeface_); 172 paint->setTypeface(typeface_);
173 paint->setFakeBoldText((BOLD & style_) && !typeface_->isBold()); 173 paint->setFakeBoldText((BOLD & style_) && !typeface_->isBold());
174 paint->setTextSkewX((ITALIC & style_) && !typeface_->isItalic() ? 174 paint->setTextSkewX((ITALIC & style_) && !typeface_->isItalic() ?
175 -SK_Scalar1/4 : 0); 175 -SK_Scalar1/4 : 0);
176 } 176 }
177 177
178 int Font::GetStringWidth(const std::wstring& text) const { 178 int Font::GetStringWidth(const std::wstring& text) const {
179 int width = 0, height = 0; 179 int width = 0, height = 0;
180 Canvas::SizeStringInt(text, *this, &width, &height, gfx::Canvas::NO_ELLIPSIS); 180 CanvasSkia::SizeStringInt(text, *this, &width, &height,
181 gfx::Canvas::NO_ELLIPSIS);
181 return width; 182 return width;
182 } 183 }
183 184
184 void Font::InitPangoMetrics() { 185 void Font::InitPangoMetrics() {
185 if (!pango_metrics_inited_) { 186 if (!pango_metrics_inited_) {
186 pango_metrics_inited_ = true; 187 pango_metrics_inited_ = true;
187 PangoFontDescription* pango_desc = PangoFontFromGfxFont(*this); 188 PangoFontDescription* pango_desc = PangoFontFromGfxFont(*this);
188 PangoFontMetrics* pango_metrics = GetPangoFontMetrics(pango_desc); 189 PangoFontMetrics* pango_metrics = GetPangoFontMetrics(pango_desc);
189 190
190 underline_position_ = 191 underline_position_ =
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after
245 246
246 int Font::FontSize() { 247 int Font::FontSize() {
247 return font_size_; 248 return font_size_;
248 } 249 }
249 250
250 NativeFont Font::nativeFont() const { 251 NativeFont Font::nativeFont() const {
251 return typeface_; 252 return typeface_;
252 } 253 }
253 254
254 } // namespace gfx 255 } // namespace gfx
OLDNEW
« gfx/canvas.h ('K') | « gfx/font_mac.mm ('k') | gfx/font_win.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698