blob: c31f2491bf8bb518329dec87b98ddbe8fa5657de [file] [log] [blame]
// Copyright (c) 2012 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <string>
#include "base/compiler_specific.h"
#include "base/memory/scoped_ptr.h"
#include "skia/ext/refptr.h"
#include "third_party/skia/include/core/SkRefCnt.h"
#include "ui/gfx/font_render_params.h"
#include "ui/gfx/platform_font.h"
class SkTypeface;
class SkPaint;
namespace gfx {
class GFX_EXPORT PlatformFontLinux : public PlatformFont {
// TODO(derat): Get rid of the default constructor in favor of using
// gfx::FontList (which also has the concept of a default font but may contain
// multiple font families) everywhere. See
PlatformFontLinux(const std::string& font_name, int font_size_pixels);
// Resets and reloads the cached system font used by the default constructor.
// This function is useful when the system font has changed, for example, when
// the locale has changed.
static void ReloadDefaultFont();
#if defined(OS_CHROMEOS)
// Sets the default font. |font_description| is a gfx::FontList font
// description; only the first family will be used.
static void SetDefaultFontDescription(const std::string& font_description);
// Overridden from PlatformFont:
Font DeriveFont(int size_delta, int style) const override;
int GetHeight() const override;
int GetBaseline() const override;
int GetCapHeight() const override;
int GetExpectedTextWidth(int length) const override;
int GetStyle() const override;
std::string GetFontName() const override;
std::string GetActualFontNameForTesting() const override;
int GetFontSize() const override;
const FontRenderParams& GetFontRenderParams() override;
// Create a new instance of this object with the specified properties. Called
// from DeriveFont.
PlatformFontLinux(const skia::RefPtr<SkTypeface>& typeface,
const std::string& family,
int size_pixels,
int style,
const FontRenderParams& params);
~PlatformFontLinux() override;
// Initializes this object based on the passed-in details. If |typeface| is
// empty, a new typeface will be loaded.
void InitFromDetails(
const skia::RefPtr<SkTypeface>& typeface,
const std::string& font_family,
int font_size_pixels,
int style,
const FontRenderParams& params);
// Initializes this object as a copy of another PlatformFontLinux.
void InitFromPlatformFont(const PlatformFontLinux* other);
skia::RefPtr<SkTypeface> typeface_;
// Additional information about the face.
// Skia actually expects a family name and not a font name.
std::string font_family_;
int font_size_pixels_;
int style_;
#if defined(OS_CHROMEOS)
float device_scale_factor_;
// Information describing how the font should be rendered.
FontRenderParams font_render_params_;
// Cached metrics, generated at construction.
int ascent_pixels_;
int height_pixels_;
int cap_height_pixels_;
double average_width_pixels_;
#if defined(OS_CHROMEOS)
// A font description string of the format used by gfx::FontList.
static std::string* default_font_description_;
} // namespace gfx