diff -r 000000000000 -r 6474c204b198 gfx/2d/ScaledFontCairo.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/gfx/2d/ScaledFontCairo.h Wed Dec 31 06:09:35 2014 +0100 @@ -0,0 +1,56 @@ +/* -*- Mode: C++; tab-width: 20; indent-tabs-mode: nil; c-basic-offset: 2 -*- + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ + +#ifndef MOZILLA_GFX_SCALEDFONTCAIRO_H_ +#define MOZILLA_GFX_SCALEDFONTCAIRO_H_ + +#include "ScaledFontBase.h" + +#include "cairo.h" + +namespace mozilla { +namespace gfx { + +class ScaledFontCairo : public ScaledFontBase +{ +public: + MOZ_DECLARE_REFCOUNTED_VIRTUAL_TYPENAME(ScaledFontCairo) + + ScaledFontCairo(cairo_scaled_font_t* aScaledFont, Float aSize); + +#if defined(USE_SKIA) && defined(MOZ_ENABLE_FREETYPE) + virtual SkTypeface* GetSkTypeface(); +#endif +}; + +// We need to be able to tell Skia whether or not to use +// hinting when rendering text, so that the glyphs it renders +// are the same as what layout is expecting. At the moment, only +// Skia uses this class when rendering with FreeType, as gfxFT2Font +// is the only gfxFont that honours gfxPlatform::FontHintingEnabled(). +class GlyphRenderingOptionsCairo : public GlyphRenderingOptions +{ +public: + MOZ_DECLARE_REFCOUNTED_VIRTUAL_TYPENAME(GlyphRenderingOptionsCairo) + GlyphRenderingOptionsCairo() + : mHinting(FontHinting::NORMAL) + , mAutoHinting(false) + { + } + + void SetHinting(FontHinting aHinting) { mHinting = aHinting; } + void SetAutoHinting(bool aAutoHinting) { mAutoHinting = aAutoHinting; } + FontHinting GetHinting() const { return mHinting; } + bool GetAutoHinting() const { return mAutoHinting; } + virtual FontType GetType() const { return FontType::CAIRO; } +private: + FontHinting mHinting; + bool mAutoHinting; +}; + +} +} + +#endif /* MOZILLA_GFX_SCALEDFONTCAIRO_H_ */