2009-10-07 17:16:52 +00:00
|
|
|
/* -*- Mode: C++; tab-width: 20; indent-tabs-mode: nil; c-basic-offset: 4 -*-
|
2012-05-21 11:12:37 +00:00
|
|
|
* 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/. */
|
2009-10-07 17:16:52 +00:00
|
|
|
|
|
|
|
#ifndef GFX_HARFBUZZSHAPER_H
|
|
|
|
#define GFX_HARFBUZZSHAPER_H
|
|
|
|
|
|
|
|
#include "gfxFont.h"
|
|
|
|
|
|
|
|
#include "harfbuzz/hb.h"
|
|
|
|
|
|
|
|
class gfxHarfBuzzShaper : public gfxFontShaper {
|
|
|
|
public:
|
|
|
|
gfxHarfBuzzShaper(gfxFont *aFont);
|
|
|
|
virtual ~gfxHarfBuzzShaper();
|
|
|
|
|
2013-05-16 16:29:20 +00:00
|
|
|
/*
|
|
|
|
* For HarfBuzz font callback functions, font_data is a ptr to a
|
|
|
|
* FontCallbackData struct
|
|
|
|
*/
|
|
|
|
struct FontCallbackData {
|
|
|
|
gfxHarfBuzzShaper *mShaper;
|
|
|
|
gfxContext *mContext;
|
|
|
|
};
|
|
|
|
|
2014-04-23 13:57:42 +00:00
|
|
|
bool Initialize();
|
2013-01-04 18:35:37 +00:00
|
|
|
virtual bool ShapeText(gfxContext *aContext,
|
2014-01-04 15:02:17 +00:00
|
|
|
const char16_t *aText,
|
2013-01-04 18:35:37 +00:00
|
|
|
uint32_t aOffset,
|
|
|
|
uint32_t aLength,
|
|
|
|
int32_t aScript,
|
|
|
|
gfxShapedText *aShapedText);
|
2009-10-07 17:16:52 +00:00
|
|
|
|
|
|
|
// get a given font table in harfbuzz blob form
|
|
|
|
hb_blob_t * GetFontTable(hb_tag_t aTag) const;
|
|
|
|
|
|
|
|
// map unicode character to glyph ID
|
|
|
|
hb_codepoint_t GetGlyph(hb_codepoint_t unicode,
|
|
|
|
hb_codepoint_t variation_selector) const;
|
|
|
|
|
2010-11-20 17:49:12 +00:00
|
|
|
// get harfbuzz glyph advance, in font design units
|
2012-02-14 08:03:01 +00:00
|
|
|
hb_position_t GetGlyphHAdvance(gfxContext *aContext,
|
|
|
|
hb_codepoint_t glyph) const;
|
2009-10-07 17:16:52 +00:00
|
|
|
|
2014-04-23 13:57:42 +00:00
|
|
|
// get harfbuzz horizontal advance in 16.16 fixed point format.
|
|
|
|
static hb_position_t
|
|
|
|
HBGetGlyphHAdvance(hb_font_t *font, void *font_data,
|
|
|
|
hb_codepoint_t glyph, void *user_data);
|
|
|
|
|
2012-08-22 15:56:38 +00:00
|
|
|
hb_position_t GetHKerning(uint16_t aFirstGlyph,
|
|
|
|
uint16_t aSecondGlyph) const;
|
2010-07-28 13:36:07 +00:00
|
|
|
|
2009-10-07 17:16:52 +00:00
|
|
|
protected:
|
2013-01-04 18:35:37 +00:00
|
|
|
nsresult SetGlyphsFromRun(gfxContext *aContext,
|
|
|
|
gfxShapedText *aShapedText,
|
|
|
|
uint32_t aOffset,
|
|
|
|
uint32_t aLength,
|
2014-01-04 15:02:17 +00:00
|
|
|
const char16_t *aText,
|
2013-01-04 18:35:37 +00:00
|
|
|
hb_buffer_t *aBuffer);
|
2009-10-07 17:16:52 +00:00
|
|
|
|
|
|
|
// retrieve glyph positions, applying advance adjustments and attachments
|
|
|
|
// returns results in appUnits
|
|
|
|
nscoord GetGlyphPositions(gfxContext *aContext,
|
|
|
|
hb_buffer_t *aBuffer,
|
|
|
|
nsTArray<nsPoint>& aPositions,
|
2012-08-22 15:56:38 +00:00
|
|
|
uint32_t aAppUnitsPerDevUnit);
|
2009-10-07 17:16:52 +00:00
|
|
|
|
2013-05-16 16:29:20 +00:00
|
|
|
// harfbuzz face object: we acquire a reference from the font entry
|
|
|
|
// on shaper creation, and release it in our destructor
|
2009-10-07 17:16:52 +00:00
|
|
|
hb_face_t *mHBFace;
|
|
|
|
|
2013-05-16 16:29:20 +00:00
|
|
|
// size-specific font object, owned by the gfxHarfBuzzShaper
|
|
|
|
hb_font_t *mHBFont;
|
|
|
|
|
|
|
|
FontCallbackData mCallbackData;
|
|
|
|
|
2010-07-28 13:36:07 +00:00
|
|
|
// Following table references etc are declared "mutable" because the
|
|
|
|
// harfbuzz callback functions take a const ptr to the shaper, but
|
|
|
|
// wish to cache tables here to avoid repeatedly looking them up
|
|
|
|
// in the font.
|
|
|
|
|
|
|
|
// Old-style TrueType kern table, if we're not doing GPOS kerning
|
|
|
|
mutable hb_blob_t *mKernTable;
|
|
|
|
|
2009-10-07 17:16:52 +00:00
|
|
|
// Cached copy of the hmtx table and numLongMetrics field from hhea,
|
|
|
|
// for use when looking up glyph metrics; initialized to 0 by the
|
|
|
|
// constructor so we can tell it hasn't been set yet.
|
|
|
|
// This is a signed value so that we can use -1 to indicate
|
|
|
|
// an error (if the hhea table was not available).
|
|
|
|
mutable hb_blob_t *mHmtxTable;
|
2012-08-22 15:56:38 +00:00
|
|
|
mutable int32_t mNumLongMetrics;
|
2009-10-07 17:16:52 +00:00
|
|
|
|
|
|
|
// Cached pointer to cmap subtable to be used for char-to-glyph mapping.
|
|
|
|
// This comes from GetFontTablePtr; if it is non-null, our destructor
|
|
|
|
// must call ReleaseFontTablePtr to avoid permanently caching the table.
|
|
|
|
mutable hb_blob_t *mCmapTable;
|
2012-08-22 15:56:38 +00:00
|
|
|
mutable int32_t mCmapFormat;
|
|
|
|
mutable uint32_t mSubtableOffset;
|
|
|
|
mutable uint32_t mUVSTableOffset;
|
2009-10-07 17:16:52 +00:00
|
|
|
|
2010-12-09 07:28:51 +00:00
|
|
|
// Whether the font implements GetGlyph, or we should read tables
|
|
|
|
// directly
|
2011-09-29 06:19:26 +00:00
|
|
|
bool mUseFontGetGlyph;
|
2011-01-21 10:35:21 +00:00
|
|
|
// Whether the font implements GetGlyphWidth, or we should read tables
|
2009-10-07 17:16:52 +00:00
|
|
|
// directly to get ideal widths
|
2011-09-29 06:19:26 +00:00
|
|
|
bool mUseFontGlyphWidths;
|
2013-05-16 16:29:20 +00:00
|
|
|
|
|
|
|
bool mInitialized;
|
2009-10-07 17:16:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif /* GFX_HARFBUZZSHAPER_H */
|