Seperate out quad updating from atlas updating

Change-Id: I5a4bfe0b728c23df76dd7de7d57ee06e42e5641b
Reviewed-on: https://skia-review.googlesource.com/c/skia/+/262939
Commit-Queue: Herb Derby <herb@google.com>
Reviewed-by: Mike Klein <mtklein@google.com>
This commit is contained in:
Herb Derby 2020-01-07 16:07:42 -05:00 committed by Skia Commit-Bot
parent 586f8d04d4
commit bc131b8779

View File

@ -82,7 +82,7 @@ public:
void translateVerticesIfNeeded(const SkMatrix& drawMatrix, SkPoint drawOrigin); void translateVerticesIfNeeded(const SkMatrix& drawMatrix, SkPoint drawOrigin);
void updateVerticesColorIfNeeded(GrColor newColor); void updateVerticesColorIfNeeded(GrColor newColor);
void updateTexCoord(size_t index); void updateTexCoords(int begin, int end);
// df properties // df properties
void setUseLCDText(bool useLCDText); void setUseLCDText(bool useLCDText);
@ -298,54 +298,57 @@ void GrTextBlob::SubRun::updateVerticesColorIfNeeded(GrColor newColor) {
} }
} }
void GrTextBlob::SubRun::updateTexCoord(size_t index) { void GrTextBlob::SubRun::updateTexCoords(int begin, int end) {
GrGlyph* glyph = this->fGlyphs[index]; const size_t vertexStride = this->vertexStride();
SkASSERT(glyph != nullptr); const size_t texCoordOffset = this->texCoordOffset();
char* vertex = this->quadStart(begin);
int width = glyph->fBounds.width();
int height = glyph->fBounds.height();
uint16_t u0, v0, u1, v1;
if (this->drawAsDistanceFields()) {
u0 = glyph->fAtlasLocation.fX + SK_DistanceFieldInset;
v0 = glyph->fAtlasLocation.fY + SK_DistanceFieldInset;
u1 = u0 + width - 2 * SK_DistanceFieldInset;
v1 = v0 + height - 2 * SK_DistanceFieldInset;
} else {
u0 = glyph->fAtlasLocation.fX;
v0 = glyph->fAtlasLocation.fY;
u1 = u0 + width;
v1 = v0 + height;
}
// We pack the 2bit page index in the low bit of the u and v texture coords
uint32_t pageIndex = glyph->pageIndex();
SkASSERT(pageIndex < 4);
uint16_t uBit = (pageIndex >> 1u) & 0x1u;
uint16_t vBit = pageIndex & 0x1u;
u0 <<= 1u;
u0 |= uBit;
v0 <<= 1u;
v0 |= vBit;
u1 <<= 1u;
u1 |= uBit;
v1 <<= 1u;
v1 |= vBit;
char* vertex = this->quadStart(index);
size_t vertexStride = this->vertexStride();
size_t texCoordOffset = this->texCoordOffset();
uint16_t* textureCoords = reinterpret_cast<uint16_t*>(vertex + texCoordOffset); uint16_t* textureCoords = reinterpret_cast<uint16_t*>(vertex + texCoordOffset);
textureCoords[0] = u0; for (int i = begin; i < end; i++) {
textureCoords[1] = v0; GrGlyph* glyph = this->fGlyphs[i];
textureCoords = SkTAddOffset<uint16_t>(textureCoords, vertexStride); SkASSERT(glyph != nullptr);
textureCoords[0] = u0;
textureCoords[1] = v1; int width = glyph->fBounds.width();
textureCoords = SkTAddOffset<uint16_t>(textureCoords, vertexStride); int height = glyph->fBounds.height();
textureCoords[0] = u1; uint16_t u0, v0, u1, v1;
textureCoords[1] = v0; if (this->drawAsDistanceFields()) {
textureCoords = SkTAddOffset<uint16_t>(textureCoords, vertexStride); u0 = glyph->fAtlasLocation.fX + SK_DistanceFieldInset;
textureCoords[0] = u1; v0 = glyph->fAtlasLocation.fY + SK_DistanceFieldInset;
textureCoords[1] = v1; u1 = u0 + width - 2 * SK_DistanceFieldInset;
v1 = v0 + height - 2 * SK_DistanceFieldInset;
} else {
u0 = glyph->fAtlasLocation.fX;
v0 = glyph->fAtlasLocation.fY;
u1 = u0 + width;
v1 = v0 + height;
}
// We pack the 2bit page index in the low bit of the u and v texture coords
uint32_t pageIndex = glyph->pageIndex();
SkASSERT(pageIndex < 4);
uint16_t uBit = (pageIndex >> 1u) & 0x1u;
uint16_t vBit = pageIndex & 0x1u;
u0 <<= 1u;
u0 |= uBit;
v0 <<= 1u;
v0 |= vBit;
u1 <<= 1u;
u1 |= uBit;
v1 <<= 1u;
v1 |= vBit;
textureCoords[0] = u0;
textureCoords[1] = v0;
textureCoords = SkTAddOffset<uint16_t>(textureCoords, vertexStride);
textureCoords[0] = u0;
textureCoords[1] = v1;
textureCoords = SkTAddOffset<uint16_t>(textureCoords, vertexStride);
textureCoords[0] = u1;
textureCoords[1] = v0;
textureCoords = SkTAddOffset<uint16_t>(textureCoords, vertexStride);
textureCoords[0] = u1;
textureCoords[1] = v1;
textureCoords = SkTAddOffset<uint16_t>(textureCoords, vertexStride);
}
} }
void GrTextBlob::SubRun::setUseLCDText(bool useLCDText) { fFlags.useLCDText = useLCDText; } void GrTextBlob::SubRun::setUseLCDText(bool useLCDText) { fFlags.useLCDText = useLCDText; }
@ -910,9 +913,11 @@ bool GrTextBlob::VertexRegenerator::updateTextureCoordinatesMaybeStrike(
// flush between. // flush between.
const bool brokenRun = fCurrGlyph > 0; const bool brokenRun = fCurrGlyph > 0;
// Update the atlas information in the GrStrike.
auto code = GrDrawOpAtlas::ErrorCode::kSucceeded; auto code = GrDrawOpAtlas::ErrorCode::kSucceeded;
int startingGlyph = fCurrGlyph; int startingGlyph = fCurrGlyph;
GrTextStrike* grStrike = fSubRun->strike(); GrTextStrike* grStrike = fSubRun->strike();
auto tokenTracker = fUploadTarget->tokenTracker();
for (; fCurrGlyph < glyphLimit; fCurrGlyph++) { for (; fCurrGlyph < glyphLimit; fCurrGlyph++) {
GrGlyph* glyph = fSubRun->fGlyphs[fCurrGlyph]; GrGlyph* glyph = fSubRun->fGlyphs[fCurrGlyph];
SkASSERT(glyph && glyph->fMaskFormat == fSubRun->maskFormat()); SkASSERT(glyph && glyph->fMaskFormat == fSubRun->maskFormat());
@ -925,12 +930,13 @@ bool GrTextBlob::VertexRegenerator::updateTextureCoordinatesMaybeStrike(
break; break;
} }
} }
auto tokenTracker = fUploadTarget->tokenTracker();
fFullAtlasManager->addGlyphToBulkAndSetUseToken( fFullAtlasManager->addGlyphToBulkAndSetUseToken(
fSubRun->bulkUseToken(), glyph, tokenTracker->nextDrawToken()); fSubRun->bulkUseToken(), glyph, tokenTracker->nextDrawToken());
fSubRun->updateTexCoord(fCurrGlyph);
} }
// Update the quads with the new atlas coordinates.
fSubRun->updateTexCoords(startingGlyph, fCurrGlyph);
result->fFinished = fCurrGlyph == (int)fSubRun->fGlyphs.size(); result->fFinished = fCurrGlyph == (int)fSubRun->fGlyphs.size();
result->fGlyphsRegenerated += fCurrGlyph - startingGlyph; result->fGlyphsRegenerated += fCurrGlyph - startingGlyph;
result->fFirstVertex = fSubRun->quadStart(startingGlyph); result->fFirstVertex = fSubRun->quadStart(startingGlyph);