Remove unique glyph IDs from glyph runs
The unique calculation is to costly to do for SkTextBlobs every time because there may be a cache hit in the GrTextBlob cache. In the future I will move the unique ID calculation to the GrTextBlob creation. Change-Id: I7e10e8f22a3bc729fab12b2cf7e9732441be7f31 Reviewed-on: https://skia-review.googlesource.com/c/164623 Reviewed-by: Mike Klein <mtklein@google.com> Commit-Queue: Herb Derby <herb@google.com>
This commit is contained in:
parent
f9f073553c
commit
2d123ad73f
@ -30,16 +30,12 @@ static SkTypeface::Encoding convert_encoding(SkPaint::TextEncoding encoding) {
|
||||
// -- SkGlyphRun -----------------------------------------------------------------------------------
|
||||
SkGlyphRun::SkGlyphRun(const SkPaint& basePaint,
|
||||
const SkRunFont& runFont,
|
||||
SkSpan<const uint16_t> denseIndices,
|
||||
SkSpan<const SkPoint> positions,
|
||||
SkSpan<const SkGlyphID> glyphIDs,
|
||||
SkSpan<const SkGlyphID> uniqueGlyphIDs,
|
||||
SkSpan<const char> text,
|
||||
SkSpan<const uint32_t> clusters)
|
||||
: fUniqueGlyphIDIndices{denseIndices}
|
||||
, fPositions{positions}
|
||||
: fPositions{positions}
|
||||
, fGlyphIDs{glyphIDs}
|
||||
, fUniqueGlyphIDs{uniqueGlyphIDs}
|
||||
, fText{text}
|
||||
, fClusters{clusters}
|
||||
, fRunPaint{basePaint, runFont} {}
|
||||
@ -50,10 +46,8 @@ void SkGlyphRun::eachGlyphToGlyphRun(SkGlyphRun::PerGlyph perGlyph) {
|
||||
SkGlyphRun run{
|
||||
fRunPaint,
|
||||
SkRunFont{fRunPaint},
|
||||
SkSpan<const uint16_t>{}, // No dense indices for now.
|
||||
SkSpan<const SkPoint>{&point, 1},
|
||||
SkSpan<const SkGlyphID>{&glyphID, 1},
|
||||
SkSpan<const SkGlyphID>{},
|
||||
SkSpan<const char>{},
|
||||
SkSpan<const uint32_t>{}
|
||||
};
|
||||
@ -198,8 +192,6 @@ void SkGlyphRunBuilder::drawTextAtOrigin(
|
||||
SkRunFont{paint},
|
||||
glyphIDs,
|
||||
positions,
|
||||
SkSpan<const uint16_t>{}, // no dense indices for now.,
|
||||
SkSpan<const SkGlyphID>{},
|
||||
SkSpan<const char>{},
|
||||
SkSpan<const uint32_t>{});
|
||||
this->makeGlyphRunList(paint, nullptr, SkPoint::Make(0, 0));
|
||||
@ -210,8 +202,7 @@ void SkGlyphRunBuilder::drawText(
|
||||
auto glyphIDs = textToGlyphIDs(paint, bytes, byteLength);
|
||||
if (!glyphIDs.empty()) {
|
||||
this->initialize(glyphIDs.size());
|
||||
this->simplifyDrawText(paint, SkRunFont{paint}, glyphIDs, origin,
|
||||
fUniqueGlyphIDIndices, fUniqueGlyphIDs, fPositions);
|
||||
this->simplifyDrawText(paint, SkRunFont{paint}, glyphIDs, origin, fPositions);
|
||||
}
|
||||
|
||||
this->makeGlyphRunList(paint, nullptr, SkPoint::Make(0, 0));
|
||||
@ -224,8 +215,7 @@ void SkGlyphRunBuilder::drawPosTextH(const SkPaint& paint, const void* bytes,
|
||||
if (!glyphIDs.empty()) {
|
||||
this->initialize(glyphIDs.size());
|
||||
this->simplifyDrawPosTextH(
|
||||
paint, SkRunFont{paint}, glyphIDs, xpos, constY,
|
||||
fUniqueGlyphIDIndices, fUniqueGlyphIDs, fPositions);
|
||||
paint, SkRunFont{paint}, glyphIDs, xpos, constY, fPositions);
|
||||
}
|
||||
|
||||
this->makeGlyphRunList(paint, nullptr, SkPoint::Make(0, 0));
|
||||
@ -236,8 +226,7 @@ void SkGlyphRunBuilder::drawPosText(const SkPaint& paint, const void* bytes,
|
||||
auto glyphIDs = textToGlyphIDs(paint, bytes, byteLength);
|
||||
if (!glyphIDs.empty()) {
|
||||
this->initialize(glyphIDs.size());
|
||||
this->simplifyDrawPosText(paint, SkRunFont{paint}, glyphIDs, pos,
|
||||
fUniqueGlyphIDIndices, fUniqueGlyphIDs);
|
||||
this->simplifyDrawPosText(paint, SkRunFont{paint}, glyphIDs, pos);
|
||||
}
|
||||
|
||||
this->makeGlyphRunList(paint, nullptr, SkPoint::Make(0, 0));
|
||||
@ -253,9 +242,7 @@ void SkGlyphRunBuilder::drawTextBlob(const SkPaint& paint, const SkTextBlob& blo
|
||||
// Pre-size all the buffers so they don't move during processing.
|
||||
this->initialize(totalGlyphs);
|
||||
|
||||
uint16_t* currentDenseIndices = fUniqueGlyphIDIndices;
|
||||
SkPoint* currentPositions = fPositions;
|
||||
SkGlyphID* currentUniqueGlyphIDs = fUniqueGlyphIDs;
|
||||
|
||||
for (SkTextBlobRunIterator it(&blob); !it.done(); it.next()) {
|
||||
// applyFontToPaint() always overwrites the exact same attributes,
|
||||
@ -267,34 +254,28 @@ void SkGlyphRunBuilder::drawTextBlob(const SkPaint& paint, const SkTextBlob& blo
|
||||
const SkPoint& offset = it.offset();
|
||||
auto glyphIDs = SkSpan<const SkGlyphID>{it.glyphs(), runSize};
|
||||
|
||||
size_t uniqueGlyphIDsSize = 0;
|
||||
switch (it.positioning()) {
|
||||
case SkTextBlobRunIterator::kDefault_Positioning: {
|
||||
uniqueGlyphIDsSize = this->simplifyDrawText(
|
||||
paint, it.runFont(), glyphIDs, offset,
|
||||
currentDenseIndices, currentUniqueGlyphIDs, currentPositions,
|
||||
this->simplifyDrawText(
|
||||
paint, it.runFont(), glyphIDs, offset, currentPositions,
|
||||
text, clusters);
|
||||
}
|
||||
break;
|
||||
case SkTextBlobRunIterator::kHorizontal_Positioning: {
|
||||
auto constY = offset.y();
|
||||
uniqueGlyphIDsSize = this->simplifyDrawPosTextH(
|
||||
paint, it.runFont(), glyphIDs, it.pos(), constY,
|
||||
currentDenseIndices, currentUniqueGlyphIDs, currentPositions,
|
||||
this->simplifyDrawPosTextH(
|
||||
paint, it.runFont(), glyphIDs, it.pos(), constY, currentPositions,
|
||||
text, clusters);
|
||||
}
|
||||
break;
|
||||
case SkTextBlobRunIterator::kFull_Positioning:
|
||||
uniqueGlyphIDsSize = this->simplifyDrawPosText(
|
||||
this->simplifyDrawPosText(
|
||||
paint, it.runFont(), glyphIDs, (const SkPoint*)it.pos(),
|
||||
currentDenseIndices, currentUniqueGlyphIDs,
|
||||
text, clusters);
|
||||
break;
|
||||
}
|
||||
|
||||
currentDenseIndices += runSize;
|
||||
currentPositions += runSize;
|
||||
currentUniqueGlyphIDs += uniqueGlyphIDsSize;
|
||||
}
|
||||
|
||||
this->makeGlyphRunList(paint, &blob, origin);
|
||||
@ -304,8 +285,7 @@ void SkGlyphRunBuilder::drawGlyphPos(
|
||||
const SkPaint& paint, SkSpan<const SkGlyphID> glyphIDs, const SkPoint* pos) {
|
||||
if (!glyphIDs.empty()) {
|
||||
this->initialize(glyphIDs.size());
|
||||
this->simplifyDrawPosText(paint, SkRunFont{paint}, glyphIDs, pos,
|
||||
fUniqueGlyphIDIndices, fUniqueGlyphIDs);
|
||||
this->simplifyDrawPosText(paint, SkRunFont{paint}, glyphIDs, pos);
|
||||
this->makeGlyphRunList(paint, nullptr, SkPoint::Make(0, 0));
|
||||
}
|
||||
}
|
||||
@ -318,9 +298,7 @@ void SkGlyphRunBuilder::initialize(size_t totalRunSize) {
|
||||
|
||||
if (totalRunSize > fMaxTotalRunSize) {
|
||||
fMaxTotalRunSize = totalRunSize;
|
||||
fUniqueGlyphIDIndices.reset(fMaxTotalRunSize);
|
||||
fPositions.reset(fMaxTotalRunSize);
|
||||
fUniqueGlyphIDs.reset(fMaxTotalRunSize);
|
||||
}
|
||||
|
||||
fGlyphRunListStorage.clear();
|
||||
@ -346,33 +324,11 @@ SkSpan<const SkGlyphID> SkGlyphRunBuilder::textToGlyphIDs(
|
||||
}
|
||||
}
|
||||
|
||||
SkSpan<const SkGlyphID> SkGlyphRunBuilder::addDenseAndUnique(
|
||||
const SkPaint& paint,
|
||||
SkSpan<const SkGlyphID> glyphIDs,
|
||||
uint16_t* uniqueGlyphIDIndices,
|
||||
SkGlyphID* uniqueGlyphIDs) {
|
||||
SkSpan<const SkGlyphID> uniquifiedGlyphIDs;
|
||||
if (!glyphIDs.empty()) {
|
||||
auto typeface = SkPaintPriv::GetTypefaceOrDefault(paint);
|
||||
auto glyphUniverseSize = typeface->countGlyphs();
|
||||
|
||||
// There better be glyphs in the font if we want to uniqify.
|
||||
if (glyphUniverseSize > 0) {
|
||||
uniquifiedGlyphIDs = fGlyphIDSet.uniquifyGlyphIDs(
|
||||
glyphUniverseSize, glyphIDs, uniqueGlyphIDs, uniqueGlyphIDIndices);
|
||||
}
|
||||
}
|
||||
|
||||
return uniquifiedGlyphIDs;
|
||||
}
|
||||
|
||||
void SkGlyphRunBuilder::makeGlyphRun(
|
||||
const SkPaint& basePaint,
|
||||
const SkRunFont& runFont,
|
||||
SkSpan<const SkGlyphID> glyphIDs,
|
||||
SkSpan<const SkPoint> positions,
|
||||
SkSpan<const uint16_t> uniqueGlyphIDIndices,
|
||||
SkSpan<const SkGlyphID> uniqueGlyphIDs,
|
||||
SkSpan<const char> text,
|
||||
SkSpan<const uint32_t> clusters) {
|
||||
|
||||
@ -381,10 +337,8 @@ void SkGlyphRunBuilder::makeGlyphRun(
|
||||
fGlyphRunListStorage.emplace_back(
|
||||
basePaint,
|
||||
runFont,
|
||||
uniqueGlyphIDIndices,
|
||||
positions,
|
||||
glyphIDs,
|
||||
uniqueGlyphIDs,
|
||||
text,
|
||||
clusters);
|
||||
}
|
||||
@ -398,62 +352,53 @@ void SkGlyphRunBuilder::makeGlyphRunList(
|
||||
paint, blob, origin, SkSpan<SkGlyphRun>{fGlyphRunListStorage}};
|
||||
}
|
||||
|
||||
size_t SkGlyphRunBuilder::simplifyDrawText(
|
||||
SkPoint SkGlyphRunBuilder::simplifyDrawText(
|
||||
const SkPaint& paint, const SkRunFont& runFont, SkSpan<const SkGlyphID> glyphIDs,
|
||||
SkPoint origin, uint16_t* uniqueGlyphIDIndicesBuffer, SkGlyphID* uniqueGlyphIDsBuffer,
|
||||
SkPoint* positions, SkSpan<const char> text, SkSpan<const uint32_t> clusters) {
|
||||
SkPoint origin, SkPoint* positions,
|
||||
SkSpan<const char> text, SkSpan<const uint32_t> clusters) {
|
||||
SkASSERT(!glyphIDs.empty());
|
||||
|
||||
auto runSize = glyphIDs.size();
|
||||
|
||||
SkPaint runPaint{paint, runFont};
|
||||
|
||||
auto unqiueGlyphIDs = this->addDenseAndUnique(
|
||||
runPaint, glyphIDs, uniqueGlyphIDIndicesBuffer, uniqueGlyphIDsBuffer);
|
||||
|
||||
if (!unqiueGlyphIDs.empty()) {
|
||||
fScratchAdvances.resize(runSize);
|
||||
{
|
||||
auto cache = SkStrikeCache::FindOrCreateStrikeExclusive(runPaint);
|
||||
cache->getAdvances(unqiueGlyphIDs, fScratchAdvances.data());
|
||||
}
|
||||
|
||||
SkPoint endOfLastGlyph = origin;
|
||||
|
||||
for (size_t i = 0; i < runSize; i++) {
|
||||
positions[i] = endOfLastGlyph;
|
||||
endOfLastGlyph += fScratchAdvances[uniqueGlyphIDIndicesBuffer[i]];
|
||||
}
|
||||
|
||||
if (paint.getTextAlign() != SkPaint::kLeft_Align) {
|
||||
SkVector len = endOfLastGlyph - origin;
|
||||
if (paint.getTextAlign() == SkPaint::kCenter_Align) {
|
||||
len.scale(SK_ScalarHalf);
|
||||
}
|
||||
for (auto& pt : SkSpan<SkPoint>{positions, runSize}) {
|
||||
pt -= len;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
this->makeGlyphRun(
|
||||
paint,
|
||||
runFont,
|
||||
glyphIDs,
|
||||
SkSpan<const SkPoint>{positions, runSize},
|
||||
SkSpan<const uint16_t>{uniqueGlyphIDIndicesBuffer, runSize},
|
||||
unqiueGlyphIDs,
|
||||
text,
|
||||
clusters);
|
||||
fScratchAdvances.resize(runSize);
|
||||
{
|
||||
auto cache = SkStrikeCache::FindOrCreateStrikeExclusive(runPaint);
|
||||
cache->getAdvances(glyphIDs, fScratchAdvances.data());
|
||||
}
|
||||
|
||||
return unqiueGlyphIDs.size();
|
||||
SkPoint endOfLastGlyph = origin;
|
||||
|
||||
for (size_t i = 0; i < runSize; i++) {
|
||||
positions[i] = endOfLastGlyph;
|
||||
endOfLastGlyph += fScratchAdvances[i];
|
||||
}
|
||||
|
||||
if (paint.getTextAlign() != SkPaint::kLeft_Align) {
|
||||
SkVector len = endOfLastGlyph - origin;
|
||||
if (paint.getTextAlign() == SkPaint::kCenter_Align) {
|
||||
len.scale(SK_ScalarHalf);
|
||||
}
|
||||
for (auto& pt : SkSpan<SkPoint>{positions, runSize}) {
|
||||
pt -= len;
|
||||
}
|
||||
}
|
||||
|
||||
this->makeGlyphRun(
|
||||
paint,
|
||||
runFont,
|
||||
glyphIDs,
|
||||
SkSpan<const SkPoint>{positions, runSize},
|
||||
text,
|
||||
clusters);
|
||||
|
||||
return endOfLastGlyph;
|
||||
}
|
||||
|
||||
size_t SkGlyphRunBuilder::simplifyDrawPosTextH(
|
||||
void SkGlyphRunBuilder::simplifyDrawPosTextH(
|
||||
const SkPaint& paint, const SkRunFont& runFont, SkSpan<const SkGlyphID> glyphIDs,
|
||||
const SkScalar* xpos, SkScalar constY,
|
||||
uint16_t* uniqueGlyphIDIndicesBuffer, SkGlyphID* uniqueGlyphIDsBuffer, SkPoint* positions,
|
||||
const SkScalar* xpos, SkScalar constY, SkPoint* positions,
|
||||
SkSpan<const char> text, SkSpan<const uint32_t> clusters) {
|
||||
|
||||
auto posCursor = positions;
|
||||
@ -461,34 +406,19 @@ size_t SkGlyphRunBuilder::simplifyDrawPosTextH(
|
||||
*posCursor++ = SkPoint::Make(x, constY);
|
||||
}
|
||||
|
||||
return simplifyDrawPosText(paint, runFont, glyphIDs, positions,
|
||||
uniqueGlyphIDIndicesBuffer, uniqueGlyphIDsBuffer,
|
||||
text, clusters);
|
||||
simplifyDrawPosText(paint, runFont, glyphIDs, positions, text, clusters);
|
||||
}
|
||||
|
||||
size_t SkGlyphRunBuilder::simplifyDrawPosText(
|
||||
void SkGlyphRunBuilder::simplifyDrawPosText(
|
||||
const SkPaint& paint, const SkRunFont& runFont, SkSpan<const SkGlyphID> glyphIDs,
|
||||
const SkPoint* pos, uint16_t* uniqueGlyphIDIndicesBuffer, SkGlyphID* uniqueGlyphIDsBuffer,
|
||||
SkSpan<const char> text, SkSpan<const uint32_t> clusters) {
|
||||
const SkPoint* pos, SkSpan<const char> text, SkSpan<const uint32_t> clusters) {
|
||||
auto runSize = glyphIDs.size();
|
||||
|
||||
// The dense indices are not used by the rest of the stack yet.
|
||||
SkSpan<const SkGlyphID> uniqueGlyphIDs;
|
||||
#ifdef SK_DEBUG
|
||||
uniqueGlyphIDs = this->addDenseAndUnique(
|
||||
paint, glyphIDs, uniqueGlyphIDIndicesBuffer, uniqueGlyphIDsBuffer);
|
||||
#endif
|
||||
|
||||
// TODO: when using the unique glyph system have a guard that there are actually glyphs like
|
||||
// drawText above.
|
||||
this->makeGlyphRun(
|
||||
paint,
|
||||
runFont,
|
||||
glyphIDs,
|
||||
SkSpan<const SkPoint>{pos, runSize},
|
||||
SkSpan<const SkGlyphID>{uniqueGlyphIDIndicesBuffer, runSize},
|
||||
uniqueGlyphIDs,
|
||||
text,
|
||||
clusters);
|
||||
return uniqueGlyphIDs.size();
|
||||
}
|
||||
|
@ -87,10 +87,8 @@ public:
|
||||
SkGlyphRun() = default;
|
||||
SkGlyphRun(const SkPaint& basePaint,
|
||||
const SkRunFont& runFont,
|
||||
SkSpan<const uint16_t> denseIndices,
|
||||
SkSpan<const SkPoint> positions,
|
||||
SkSpan<const SkGlyphID> glyphIDs,
|
||||
SkSpan<const SkGlyphID> uniqueGlyphIDs,
|
||||
SkSpan<const char> text,
|
||||
SkSpan<const uint32_t> clusters);
|
||||
|
||||
@ -107,21 +105,17 @@ public:
|
||||
|
||||
size_t runSize() const { return fGlyphIDs.size(); }
|
||||
SkSpan<const SkPoint> positions() const { return fPositions.toConst(); }
|
||||
SkSpan<const SkGlyphID> shuntGlyphsIDs() const { return fGlyphIDs; }
|
||||
SkSpan<const SkGlyphID> glyphsIDs() const { return fGlyphIDs; }
|
||||
const SkPaint& paint() const { return fRunPaint; }
|
||||
SkPaint* mutablePaint() { return &fRunPaint; }
|
||||
SkSpan<const uint32_t> clusters() const { return fClusters; }
|
||||
SkSpan<const char> text() const { return fText; }
|
||||
|
||||
private:
|
||||
//
|
||||
const SkSpan<const uint16_t> fUniqueGlyphIDIndices;
|
||||
//
|
||||
// Positions relative to the list's origin.
|
||||
const SkSpan<const SkPoint> fPositions;
|
||||
// This is temporary while converting from the old per glyph code to the bulk code.
|
||||
const SkSpan<const SkGlyphID> fGlyphIDs;
|
||||
// The unique glyphs from fGlyphIDs.
|
||||
const SkSpan<const SkGlyphID> fUniqueGlyphIDs;
|
||||
// Original text from SkTextBlob if present. Will be empty of not present.
|
||||
const SkSpan<const char> fText;
|
||||
// Original clusters from SkTextBlob if present. Will be empty if not present.
|
||||
@ -140,6 +134,7 @@ class SkGlyphRunList {
|
||||
|
||||
public:
|
||||
SkGlyphRunList();
|
||||
|
||||
// Blob maybe null.
|
||||
SkGlyphRunList(
|
||||
const SkPaint& paint,
|
||||
@ -208,61 +203,45 @@ private:
|
||||
SkSpan<const SkGlyphID> textToGlyphIDs(
|
||||
const SkPaint& paint, const void* bytes, size_t byteLength);
|
||||
|
||||
// Returns the span of unique glyph IDs.
|
||||
SkSpan<const SkGlyphID> addDenseAndUnique(
|
||||
const SkPaint& paint,
|
||||
SkSpan<const SkGlyphID> glyphIDs,
|
||||
uint16_t* uniqueGlyphIDIndices,
|
||||
SkGlyphID* uniqueGlyphIDs);
|
||||
|
||||
void makeGlyphRun(
|
||||
const SkPaint& basePaint,
|
||||
const SkRunFont& runFont,
|
||||
SkSpan<const SkGlyphID> glyphIDs,
|
||||
SkSpan<const SkPoint> positions,
|
||||
SkSpan<const uint16_t> uniqueGlyphIDIndices,
|
||||
SkSpan<const SkGlyphID> uniqueGlyphIDs,
|
||||
SkSpan<const char> text,
|
||||
SkSpan<const uint32_t> clusters);
|
||||
|
||||
void makeGlyphRunList(const SkPaint& paint, const SkTextBlob* blob, SkPoint origin);
|
||||
|
||||
size_t simplifyDrawText(
|
||||
// Return the end of the last glyph for measurement.
|
||||
SkPoint simplifyDrawText(
|
||||
const SkPaint& paint, const SkRunFont& runFont, SkSpan<const SkGlyphID> glyphIDs,
|
||||
SkPoint origin,uint16_t* uniqueGlyphIDIndices, SkGlyphID* uniqueGlyphIDs,
|
||||
SkPoint* positions,
|
||||
SkPoint origin, SkPoint* positions,
|
||||
SkSpan<const char> text = SkSpan<const char>{},
|
||||
SkSpan<const uint32_t> clusters = SkSpan<const uint32_t>{});
|
||||
size_t simplifyDrawPosTextH(
|
||||
void simplifyDrawPosTextH(
|
||||
const SkPaint& paint, const SkRunFont& runFont, SkSpan<const SkGlyphID> glyphIDs,
|
||||
const SkScalar* xpos, SkScalar constY,
|
||||
uint16_t* uniqueGlyphIDIndices, SkGlyphID* uniqueGlyphIDs, SkPoint* positions,
|
||||
const SkScalar* xpos, SkScalar constY, SkPoint* positions,
|
||||
SkSpan<const char> text = SkSpan<const char>{},
|
||||
SkSpan<const uint32_t> clusters = SkSpan<const uint32_t>{});
|
||||
size_t simplifyDrawPosText(
|
||||
void simplifyDrawPosText(
|
||||
const SkPaint& paint, const SkRunFont& runFont, SkSpan<const SkGlyphID> glyphIDs,
|
||||
const SkPoint* pos, uint16_t* uniqueGlyphIDIndices, SkGlyphID* uniqueGlyphIDs,
|
||||
const SkPoint* pos,
|
||||
SkSpan<const char> text = SkSpan<const char>{},
|
||||
SkSpan<const uint32_t> clusters = SkSpan<const uint32_t>{});
|
||||
|
||||
size_t fMaxTotalRunSize{0};
|
||||
SkAutoTMalloc<uint16_t> fUniqueGlyphIDIndices;
|
||||
SkAutoTMalloc<SkPoint> fPositions;
|
||||
SkAutoTMalloc<SkGlyphID> fUniqueGlyphIDs;
|
||||
|
||||
std::vector<SkGlyphRun> fGlyphRunListStorage;
|
||||
SkGlyphRunList fGlyphRunList;
|
||||
|
||||
|
||||
// Used as a temporary for preparing using utfN text. This implies that only one run of
|
||||
// glyph ids will ever be needed because blobs are already glyph based.
|
||||
std::vector<SkGlyphID> fScratchGlyphIDs;
|
||||
|
||||
// Used as temporary storage for calculating positions for drawText.
|
||||
std::vector<SkPoint> fScratchAdvances;
|
||||
|
||||
// Used for collecting the set of unique glyphs.
|
||||
SkGlyphIDSet fGlyphIDSet;
|
||||
};
|
||||
|
||||
template <typename PerGlyphPos>
|
||||
|
@ -153,7 +153,7 @@ void SkGlyphRunListPainter::drawGlyphRunAsSubpixelMask(
|
||||
matrix.mapPoints(fPositions, glyphRun.positions().data(), runSize);
|
||||
|
||||
const SkPoint* positionCursor = fPositions;
|
||||
for (auto glyphID : glyphRun.shuntGlyphsIDs()) {
|
||||
for (auto glyphID : glyphRun.glyphsIDs()) {
|
||||
auto position = *positionCursor++;
|
||||
if (SkScalarsAreFinite(position.fX, position.fY)) {
|
||||
const SkGlyph& glyph = cache->getGlyphMetrics(glyphID, position);
|
||||
@ -181,7 +181,7 @@ void SkGlyphRunListPainter::drawGlyphRunAsFullpixelMask(
|
||||
matrix.mapPoints(fPositions, glyphRun.positions().data(), runSize);
|
||||
|
||||
const SkPoint* positionCursor = fPositions;
|
||||
for (auto glyphID : glyphRun.shuntGlyphsIDs()) {
|
||||
for (auto glyphID : glyphRun.glyphsIDs()) {
|
||||
auto position = *positionCursor++;
|
||||
if (SkScalarsAreFinite(position.fX, position.fY)) {
|
||||
const SkGlyph& glyph = cache->getGlyphIDMetrics(glyphID);
|
||||
|
@ -150,7 +150,7 @@ void SkGlyphRunListPainter::forEachMappedDrawableGlyph(
|
||||
mapping.mapPoints(fPositions, glyphRun.positions().data(), runSize);
|
||||
const SkPoint* mappedPtCursor = fPositions;
|
||||
const SkPoint* ptCursor = glyphRun.positions().data();
|
||||
for (auto glyphID : glyphRun.shuntGlyphsIDs()) {
|
||||
for (auto glyphID : glyphRun.glyphsIDs()) {
|
||||
auto mappedPt = *mappedPtCursor++;
|
||||
auto pt = origin + *ptCursor++;
|
||||
if (SkScalarsAreFinite(mappedPt.x(), mappedPt.y())) {
|
||||
@ -234,7 +234,7 @@ void SkGlyphRunListPainter::drawGlyphRunAsSDFWithARGBFallback(
|
||||
SkScalar maxFallbackDimension{-SK_ScalarInfinity};
|
||||
|
||||
const SkPoint* positionCursor = glyphRun.positions().data();
|
||||
for (auto glyphID : glyphRun.shuntGlyphsIDs()) {
|
||||
for (auto glyphID : glyphRun.glyphsIDs()) {
|
||||
const SkGlyph& glyph = cache->getGlyphMetrics(glyphID, {0, 0});
|
||||
SkPoint glyphPos = origin + *positionCursor++;
|
||||
if (glyph.fMaskFormat == SkMask::kSDF_Format || glyph.isEmpty()) {
|
||||
|
@ -28,7 +28,7 @@ static bool is_reversed(const uint32_t* clusters, uint32_t count) {
|
||||
SkClusterator::SkClusterator(const SkGlyphRun& run)
|
||||
: fClusters(run.clusters().data())
|
||||
, fUtf8Text(run.text().data())
|
||||
, fGlyphCount(SkToU32(run.shuntGlyphsIDs().size()))
|
||||
, fGlyphCount(SkToU32(run.glyphsIDs().size()))
|
||||
, fTextByteLength(SkToU32(run.text().size()))
|
||||
{
|
||||
if (fClusters) {
|
||||
|
@ -1038,8 +1038,8 @@ void SkPDFDevice::drawGlyphRunAsPath(const SkGlyphRun& glyphRun, SkPoint offset)
|
||||
SkPath path;
|
||||
SkASSERT(paint.getTextEncoding() == SkPaint::kGlyphID_TextEncoding);
|
||||
|
||||
paint.getPosTextPath(glyphRun.shuntGlyphsIDs().data(),
|
||||
glyphRun.shuntGlyphsIDs().size() * sizeof(SkGlyphID),
|
||||
paint.getPosTextPath(glyphRun.glyphsIDs().data(),
|
||||
glyphRun.glyphsIDs().size() * sizeof(SkGlyphID),
|
||||
glyphRun.positions().data(),
|
||||
&path);
|
||||
path.offset(offset.x(), offset.y());
|
||||
@ -1088,8 +1088,8 @@ static bool needs_new_font(SkPDFFont* font, SkGlyphID gid, SkGlyphCache* cache,
|
||||
|
||||
void SkPDFDevice::internalDrawGlyphRun(const SkGlyphRun& glyphRun, SkPoint offset) {
|
||||
|
||||
const SkGlyphID* glyphs = glyphRun.shuntGlyphsIDs().data();
|
||||
uint32_t glyphCount = SkToU32(glyphRun.shuntGlyphsIDs().size());
|
||||
const SkGlyphID* glyphs = glyphRun.glyphsIDs().data();
|
||||
uint32_t glyphCount = SkToU32(glyphRun.glyphsIDs().size());
|
||||
SkPaint srcPaint{glyphRun.paint()};
|
||||
srcPaint.setTextEncoding(SkPaint::kGlyphID_TextEncoding);
|
||||
srcPaint.setTextAlign(SkPaint::kLeft_Align);
|
||||
|
@ -872,7 +872,7 @@ public:
|
||||
const SkPaint& paint = glyphRun.paint();
|
||||
auto runSize = glyphRun.runSize();
|
||||
SkAutoSTArray<64, SkUnichar> unichars(runSize);
|
||||
paint.glyphsToUnichars(glyphRun.shuntGlyphsIDs().data(), runSize, unichars.get());
|
||||
paint.glyphsToUnichars(glyphRun.glyphsIDs().data(), runSize, unichars.get());
|
||||
auto positions = glyphRun.positions();
|
||||
for (size_t i = 0; i < runSize; ++i) {
|
||||
this->appendUnichar(unichars[i], positions[i]);
|
||||
|
@ -493,10 +493,8 @@ static SkGlyphRun make_run(size_t len, const SkGlyphID* glyphs, SkPoint* pos,
|
||||
SkPaint paint, const uint32_t* clusters,
|
||||
size_t utf8TextByteLength, const char* utf8Text) {
|
||||
return SkGlyphRun(paint, SkRunFont{paint},
|
||||
SkSpan<const uint16_t>{}, // No dense indices for now.
|
||||
SkSpan<const SkPoint>{pos, len},
|
||||
SkSpan<const SkGlyphID>{glyphs, len},
|
||||
SkSpan<const SkGlyphID>{},
|
||||
SkSpan<const char>{utf8Text, utf8TextByteLength},
|
||||
SkSpan<const uint32_t>{clusters, len});
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user