d0e95a524c
This goes well with our existing `typedef int32_t SkUnichar`. GOLD_TRYBOT_URL= https://gold.skia.org/search?issue=2095263003 Review-Url: https://codereview.chromium.org/2095263003
177 lines
6.7 KiB
C++
177 lines
6.7 KiB
C++
/*
|
|
* Copyright 2014 Google Inc.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
#ifndef SkFont_DEFINED
|
|
#define SkFont_DEFINED
|
|
|
|
#include "SkRefCnt.h"
|
|
#include "SkScalar.h"
|
|
|
|
class SkPaint;
|
|
class SkTypeface;
|
|
|
|
enum SkTextEncoding {
|
|
kUTF8_SkTextEncoding,
|
|
kUTF16_SkTextEncoding,
|
|
kUTF32_SkTextEncoding,
|
|
kGlyphID_SkTextEncoding,
|
|
};
|
|
|
|
/*
|
|
1. The Hinting enum in SkPaint is gone entirely, absorbed into SkFont's flags.
|
|
|
|
2. SkPaint Flags look like this today
|
|
|
|
enum Flags {
|
|
kAntiAlias_Flag = 0x01, //!< mask to enable antialiasing
|
|
kDither_Flag = 0x04, //!< mask to enable dithering
|
|
kUnderlineText_Flag = 0x08, //!< mask to enable underline text
|
|
kStrikeThruText_Flag = 0x10, //!< mask to enable strike-thru text
|
|
kFakeBoldText_Flag = 0x20, //!< mask to enable fake-bold text
|
|
kLinearText_Flag = 0x40, //!< mask to enable linear-text
|
|
kSubpixelText_Flag = 0x80, //!< mask to enable subpixel text positioning
|
|
kDevKernText_Flag = 0x100, //!< mask to enable device kerning text
|
|
kLCDRenderText_Flag = 0x200, //!< mask to enable subpixel glyph renderering
|
|
kEmbeddedBitmapText_Flag = 0x400, //!< mask to enable embedded bitmap strikes
|
|
kAutoHinting_Flag = 0x800, //!< mask to force Freetype's autohinter
|
|
kVerticalText_Flag = 0x1000,
|
|
kGenA8FromLCD_Flag = 0x2000, // hack for GDI -- do not use if you can help it
|
|
};
|
|
|
|
SkFont would absorb these:
|
|
|
|
kFakeBoldText_Flag = 0x20, //!< mask to enable fake-bold text
|
|
kLinearText_Flag = 0x40, //!< mask to enable linear-text
|
|
kSubpixelText_Flag = 0x80, //!< mask to enable subpixel text positioning
|
|
kDevKernText_Flag = 0x100, //!< mask to enable device kerning text
|
|
kLCDRenderText_Flag = 0x200, //!< mask to enable subpixel glyph renderering
|
|
kEmbeddedBitmapText_Flag = 0x400, //!< mask to enable embedded bitmap strikes
|
|
kAutoHinting_Flag = 0x800, //!< mask to force Freetype's autohinter
|
|
kVerticalText_Flag = 0x1000,
|
|
kGenA8FromLCD_Flag = 0x2000, // hack for GDI -- do not use if you can help it
|
|
|
|
leaving these still in paint
|
|
|
|
kAntiAlias_Flag = 0x01, //!< mask to enable antialiasing
|
|
kDither_Flag = 0x04, //!< mask to enable dithering
|
|
kUnderlineText_Flag = 0x08, //!< mask to enable underline text
|
|
kStrikeThruText_Flag = 0x10, //!< mask to enable strike-thru text
|
|
|
|
3. Antialiasing
|
|
|
|
SkFont has a mask-type: BW, AA, LCD
|
|
SkPaint has antialias boolean
|
|
|
|
What to do if the font's mask-type disagrees with the paint?
|
|
|
|
*/
|
|
|
|
class SkFont : public SkRefCnt {
|
|
public:
|
|
enum Flags {
|
|
/**
|
|
* Use the system's automatic hinting mechanism to hint the typeface.
|
|
* This is a last resort hinting method applied only if other hinting methods do not apply.
|
|
* TODO: where to put auto-normal vs auto-light?
|
|
*/
|
|
kEnableAutoHints_Flag = 1 << 0,
|
|
|
|
/**
|
|
* If the typeface contains explicit bytecodes for hinting, use them.
|
|
* If both bytecode and auto hints are specified, attempt to use the bytecodes first;
|
|
* if that fails (e.g. there are no codes), then attempt to autohint.
|
|
*/
|
|
kEnableByteCodeHints_Flag = 1 << 1,
|
|
|
|
/**
|
|
* If the typeface contains explicit bitmaps for hinting, use them.
|
|
* If both bytecode and auto hints are also specified, attempt to use the bitmaps first;
|
|
* if that fails (e.g. there are no bitmaps), then attempt to bytecode or autohint.
|
|
*/
|
|
kEmbeddedBitmaps_Flag = 1 << 2,
|
|
|
|
/**
|
|
* Use rounded metric values (e.g. advance).
|
|
* If either auto or bytecode hinting was used, apply those results to the metrics of the
|
|
* glyphs as well. If no hinting was applied, the metrics will just be rounded to the
|
|
* nearest integer.
|
|
*
|
|
* This applies to calls that return metrics (e.g. measureText) and to drawing the glyphs
|
|
* (see SkCanvas drawText and drawPosText).
|
|
*/
|
|
kUseNonlinearMetrics_Flag = 1 << 3,
|
|
|
|
kVertical_Flag = 1 << 4,
|
|
kGenA8FromLCD_Flag = 1 << 5,
|
|
kEmbolden_Flag = 1 << 6,
|
|
kDevKern_Flag = 1 << 7, // ifdef ANDROID ?
|
|
};
|
|
|
|
enum MaskType {
|
|
kBW_MaskType,
|
|
kA8_MaskType,
|
|
kLCD_MaskType,
|
|
};
|
|
|
|
static sk_sp<SkFont> Make(sk_sp<SkTypeface>, SkScalar size, MaskType, uint32_t flags);
|
|
static sk_sp<SkFont> Make(sk_sp<SkTypeface>, SkScalar size, SkScalar scaleX, SkScalar skewX,
|
|
MaskType, uint32_t flags);
|
|
|
|
/**
|
|
* Return a font with the same attributes of this font, but with the specified size.
|
|
* If size is not supported (e.g. <= 0 or non-finite) NULL will be returned.
|
|
*/
|
|
sk_sp<SkFont> makeWithSize(SkScalar size) const;
|
|
/**
|
|
* Return a font with the same attributes of this font, but with the flags.
|
|
*/
|
|
sk_sp<SkFont> makeWithFlags(uint32_t newFlags) const;
|
|
|
|
SkTypeface* getTypeface() const { return fTypeface.get(); }
|
|
SkScalar getSize() const { return fSize; }
|
|
SkScalar getScaleX() const { return fScaleX; }
|
|
SkScalar getSkewX() const { return fSkewX; }
|
|
uint32_t getFlags() const { return fFlags; }
|
|
MaskType getMaskType() const { return (MaskType)fMaskType; }
|
|
|
|
bool isVertical() const { return SkToBool(fFlags & kVertical_Flag); }
|
|
bool isEmbolden() const { return SkToBool(fFlags & kEmbolden_Flag); }
|
|
bool isEnableAutoHints() const { return SkToBool(fFlags & kEnableAutoHints_Flag); }
|
|
bool isEnableByteCodeHints() const { return SkToBool(fFlags & kEnableByteCodeHints_Flag); }
|
|
bool isUseNonLinearMetrics() const { return SkToBool(fFlags & kUseNonlinearMetrics_Flag); }
|
|
bool isDevKern() const { return SkToBool(fFlags & kDevKern_Flag); }
|
|
|
|
int textToGlyphs(const void* text, size_t byteLength, SkTextEncoding,
|
|
SkGlyphID glyphs[], int maxGlyphCount) const;
|
|
|
|
int countText(const void* text, size_t byteLength, SkTextEncoding encoding) {
|
|
return this->textToGlyphs(text, byteLength, encoding, nullptr, 0);
|
|
}
|
|
|
|
SkScalar measureText(const void* text, size_t byteLength, SkTextEncoding) const;
|
|
|
|
static sk_sp<SkFont> Testing_CreateFromPaint(const SkPaint&);
|
|
|
|
private:
|
|
enum {
|
|
kAllFlags = 0xFF,
|
|
};
|
|
|
|
SkFont(sk_sp<SkTypeface>, SkScalar size, SkScalar scaleX, SkScalar skewX, MaskType,
|
|
uint32_t flags);
|
|
|
|
sk_sp<SkTypeface> fTypeface;
|
|
SkScalar fSize;
|
|
SkScalar fScaleX;
|
|
SkScalar fSkewX;
|
|
uint16_t fFlags;
|
|
uint8_t fMaskType;
|
|
// uint8_t fPad;
|
|
};
|
|
|
|
#endif
|