start removing legacy paint calls

Bug: skia:
Change-Id: I2a5c98c65e587015beb0ed6f6d5bcf5a3a1b69a2
Reviewed-on: https://skia-review.googlesource.com/c/177066
Commit-Queue: Mike Reed <reed@google.com>
Reviewed-by: Florin Malita <fmalita@chromium.org>
This commit is contained in:
Mike Reed 2018-12-12 15:48:16 -05:00 committed by Skia Commit-Bot
parent eae1d10f5d
commit 34c9b6d63e
8 changed files with 50 additions and 74 deletions

View File

@ -208,14 +208,10 @@ TextAdapter::TextAdapter(sk_sp<sksg::Group> root)
} }
sk_sp<SkTextBlob> TextAdapter::makeBlob() const { sk_sp<SkTextBlob> TextAdapter::makeBlob() const {
// TODO: convert to SkFont (missing getFontSpacing, measureText). SkFont font(fText.fTypeface, fText.fTextSize);
SkPaint font;
font.setTypeface(fText.fTypeface);
font.setTextSize(fText.fTextSize);
font.setHinting(kNo_SkFontHinting); font.setHinting(kNo_SkFontHinting);
font.setSubpixelText(true); font.setSubpixel(true);
font.setAntiAlias(true); font.setEdging(SkFont::Edging::kAntiAlias);
font.setTextEncoding(kUTF8_SkTextEncoding);
const auto align_fract = [](SkTextUtils::Align align) { const auto align_fract = [](SkTextUtils::Align align) {
switch (align) { switch (align) {
@ -226,8 +222,7 @@ sk_sp<SkTextBlob> TextAdapter::makeBlob() const {
return 0.0f; // go home, msvc... return 0.0f; // go home, msvc...
}(fText.fAlign); }(fText.fAlign);
const auto line_spacing = font.getFontSpacing(); const auto line_spacing = font.getSpacing();
const auto blob_font = SkFont::LEGACY_ExtractFromPaint(font);
float y_off = 0; float y_off = 0;
SkSTArray<256, SkGlyphID, true> line_glyph_buffer; SkSTArray<256, SkGlyphID, true> line_glyph_buffer;
SkTextBlobBuilder builder; SkTextBlobBuilder builder;
@ -235,14 +230,15 @@ sk_sp<SkTextBlob> TextAdapter::makeBlob() const {
const auto& push_line = [&](const char* start, const char* end) { const auto& push_line = [&](const char* start, const char* end) {
if (end > start) { if (end > start) {
const auto len = SkToSizeT(end - start); const auto len = SkToSizeT(end - start);
line_glyph_buffer.reset(font.textToGlyphs(start, len, nullptr)); line_glyph_buffer.reset(font.countText(start, len, kUTF8_SkTextEncoding));
SkAssertResult(font.textToGlyphs(start, len, line_glyph_buffer.data()) SkAssertResult(font.textToGlyphs(start, len, kUTF8_SkTextEncoding, line_glyph_buffer.data(),
line_glyph_buffer.count())
== line_glyph_buffer.count()); == line_glyph_buffer.count());
const auto x_off = align_fract != 0 const auto x_off = align_fract != 0
? align_fract * font.measureText(start, len) ? align_fract * font.measureText(start, len, kUTF8_SkTextEncoding)
: 0; : 0;
const auto& buf = builder.allocRun(blob_font, line_glyph_buffer.count(), x_off, y_off); const auto& buf = builder.allocRun(font, line_glyph_buffer.count(), x_off, y_off);
if (!buf.glyphs) { if (!buf.glyphs) {
return; return;
} }

View File

@ -587,7 +587,7 @@ void SkLiteDL::drawImageSet(const SkCanvas::ImageSetEntry set[], int count,
void SkLiteDL::drawTextRSXform(const void* text, size_t bytes, void SkLiteDL::drawTextRSXform(const void* text, size_t bytes,
const SkRSXform xforms[], const SkRect* cull, const SkPaint& paint) { const SkRSXform xforms[], const SkRect* cull, const SkPaint& paint) {
int n = paint.countText(text, bytes); int n = SkFont::LEGACY_ExtractFromPaint(paint).countText(text, bytes, paint.getTextEncoding());
void* pod = this->push<DrawTextRSXform>(bytes+n*sizeof(SkRSXform), bytes, n, cull, paint); void* pod = this->push<DrawTextRSXform>(bytes+n*sizeof(SkRSXform), bytes, n, cull, paint);
copy_v(pod, xforms,n, (const char*)text,bytes); copy_v(pod, xforms,n, (const char*)text,bytes);
} }

View File

@ -61,6 +61,7 @@ SkScalar SkPaint::MaxCacheSize2(SkScalar maxLimit) {
#include "SkGlyphCache.h" #include "SkGlyphCache.h"
#include "SkUtils.h" #include "SkUtils.h"
#ifdef SK_SUPPORT_LEGACY_PAINT_TEXTMEASURE
int SkPaint::countText(const void* text, size_t length) const { int SkPaint::countText(const void* text, size_t length) const {
return SkFont::LEGACY_ExtractFromPaint(*this).countText(text, length, this->getTextEncoding()); return SkFont::LEGACY_ExtractFromPaint(*this).countText(text, length, this->getTextEncoding());
} }
@ -75,6 +76,7 @@ bool SkPaint::containsText(const void* text, size_t length) const {
return SkFont::LEGACY_ExtractFromPaint(*this).containsText(text, length, return SkFont::LEGACY_ExtractFromPaint(*this).containsText(text, length,
this->getTextEncoding()); this->getTextEncoding());
} }
#endif
void SkPaint::glyphsToUnichars(const uint16_t glyphs[], int count, SkUnichar textData[]) const { void SkPaint::glyphsToUnichars(const uint16_t glyphs[], int count, SkUnichar textData[]) const {
SkFont::LEGACY_ExtractFromPaint(*this).glyphsToUnichars(glyphs, count, textData); SkFont::LEGACY_ExtractFromPaint(*this).glyphsToUnichars(glyphs, count, textData);
@ -297,6 +299,7 @@ SkScalar SkPaint::measure_text(SkGlyphCache* cache,
return x; return x;
} }
#ifdef SK_SUPPORT_LEGACY_PAINT_TEXTMEASURE
SkScalar SkPaint::measureText(const void* textData, size_t length, SkRect* bounds) const { SkScalar SkPaint::measureText(const void* textData, size_t length, SkRect* bounds) const {
const char* text = (const char*)textData; const char* text = (const char*)textData;
SkASSERT(text != nullptr || length == 0); SkASSERT(text != nullptr || length == 0);
@ -330,20 +333,10 @@ SkScalar SkPaint::measureText(const void* textData, size_t length, SkRect* bound
return width; return width;
} }
#ifdef SK_SUPPORT_LEGACY_PAINT_BREAKTEXT
size_t SkPaint::breakText(const void* textD, size_t length, SkScalar maxWidth,
SkScalar* measuredWidth) const {
return SkFont::LEGACY_ExtractFromPaint(*this).breakText(textD, length,
this->getTextEncoding(), maxWidth, measuredWidth);
}
#endif
SkScalar SkPaint::getFontMetrics(SkFontMetrics* metrics) const { SkScalar SkPaint::getFontMetrics(SkFontMetrics* metrics) const {
return SkFont::LEGACY_ExtractFromPaint(*this).getMetrics(metrics); return SkFont::LEGACY_ExtractFromPaint(*this).getMetrics(metrics);
} }
///////////////////////////////////////////////////////////////////////////////
int SkPaint::getTextWidths(const void* text, size_t len, SkScalar widths[], SkRect bounds[]) const { int SkPaint::getTextWidths(const void* text, size_t len, SkScalar widths[], SkRect bounds[]) const {
const SkFont font = SkFont::LEGACY_ExtractFromPaint(*this); const SkFont font = SkFont::LEGACY_ExtractFromPaint(*this);
SkAutoToGlyphs gly(font, text, len, this->getTextEncoding()); SkAutoToGlyphs gly(font, text, len, this->getTextEncoding());
@ -351,8 +344,19 @@ int SkPaint::getTextWidths(const void* text, size_t len, SkScalar widths[], SkRe
return gly.count(); return gly.count();
} }
#endif
#ifdef SK_SUPPORT_LEGACY_PAINT_BREAKTEXT
size_t SkPaint::breakText(const void* textD, size_t length, SkScalar maxWidth,
SkScalar* measuredWidth) const {
return SkFont::LEGACY_ExtractFromPaint(*this).breakText(textD, length,
this->getTextEncoding(), maxWidth, measuredWidth);
}
#endif
/////////////////////////////////////////////////////////////////////////////// ///////////////////////////////////////////////////////////////////////////////
#ifdef SK_SUPPORT_LEGACY_PAINT_TEXTMEASURE
#include "SkDraw.h" #include "SkDraw.h"
struct PathPosRec { struct PathPosRec {
@ -390,6 +394,7 @@ void SkPaint::getPosTextPath(const void* text, size_t length,
PathPosRec rec = { path, pos }; PathPosRec rec = { path, pos };
font.getPaths(gly.glyphs(), gly.count(), PathPosProc, &rec); font.getPaths(gly.glyphs(), gly.count(), PathPosProc, &rec);
} }
#endif
int SkPaint::getTextBlobIntercepts(const SkTextBlob* blob, const SkScalar bounds[2], int SkPaint::getTextBlobIntercepts(const SkTextBlob* blob, const SkScalar bounds[2],
SkScalar* intervals) const { SkScalar* intervals) const {

View File

@ -564,7 +564,7 @@ void SkPictureRecord::onDrawImageSet(const SkCanvas::ImageSetEntry set[], int co
void SkPictureRecord::onDrawTextRSXform(const void* text, size_t byteLength, void SkPictureRecord::onDrawTextRSXform(const void* text, size_t byteLength,
const SkRSXform xform[], const SkRect* cull, const SkRSXform xform[], const SkRect* cull,
const SkPaint& paint) { const SkPaint& paint) {
const int count = paint.countText(text, byteLength); const int count = SkFont::LEGACY_ExtractFromPaint(paint).countText(text, byteLength, paint.getTextEncoding());
// [op + paint-index + count + flags + length] + [text] + [xform] + cull // [op + paint-index + count + flags + length] + [text] + [xform] + cull
size_t size = 5 * kUInt32Size + SkAlign4(byteLength) + count * sizeof(SkRSXform); size_t size = 5 * kUInt32Size + SkAlign4(byteLength) + count * sizeof(SkRSXform);
uint32_t flags = 0; uint32_t flags = 0;

View File

@ -268,7 +268,7 @@ void SkRecorder::onDrawTextRSXform(const void* text, size_t byteLength, const Sk
paint, paint,
this->copy((const char*)text, byteLength), this->copy((const char*)text, byteLength),
byteLength, byteLength,
this->copy(xform, paint.countText(text, byteLength)), this->copy(xform, SkFont::LEGACY_ExtractFromPaint(paint).countText(text, byteLength, paint.getTextEncoding())),
this->copy(cull)); this->copy(cull));
} }

View File

@ -6,48 +6,21 @@
*/ */
#include "SkTextUtils.h" #include "SkTextUtils.h"
#include "SkTextBlob.h"
void SkTextUtils::DrawText(SkCanvas* canvas, const void* text, size_t size, SkScalar x, SkScalar y, void SkTextUtils::DrawText(SkCanvas* canvas, const void* text, size_t size, SkScalar x, SkScalar y,
const SkPaint& origPaint, Align align) { const SkPaint& paint, Align align) {
int count = origPaint.countText(text, size);
if (!count) {
return;
}
SkPaint paint(origPaint); SkFont font = SkFont::LEGACY_ExtractFromPaint(paint);
SkAutoSTArray<32, uint16_t> glyphStorage;
const uint16_t* glyphs;
if (paint.getTextEncoding() != kGlyphID_SkTextEncoding) {
glyphStorage.reset(count);
paint.textToGlyphs(text, size, glyphStorage.get());
glyphs = glyphStorage.get();
paint.setTextEncoding(kGlyphID_SkTextEncoding);
} else {
glyphs = static_cast<const uint16_t*>(text);
}
SkAutoSTArray<32, SkScalar> widthStorage(count);
SkScalar* widths = widthStorage.get();
paint.getTextWidths(glyphs, count * sizeof(uint16_t), widths);
if (align != kLeft_Align) { if (align != kLeft_Align) {
SkScalar offset = 0; SkScalar width = font.measureText(text, size, paint.getTextEncoding());
for (int i = 0; i < count; ++i) {
offset += widths[i];
}
if (align == kCenter_Align) { if (align == kCenter_Align) {
offset *= 0.5f; width *= 0.5f;
} }
x -= offset; x -= width;
} }
// Turn widths into h-positions canvas->drawTextBlob(SkTextBlob::MakeFromText(text, size, font, paint.getTextEncoding()), x, y, paint);
for (int i = 0; i < count; ++i) {
SkScalar w = widths[i];
widths[i] = x;
x += w;
}
canvas->drawPosTextH(glyphs, count * sizeof(uint16_t), widths, y, paint);
} }

View File

@ -2059,7 +2059,7 @@ SkDrawTextRSXformCommand::SkDrawTextRSXformCommand(const void* text, size_t byte
const SkPaint& paint) const SkPaint& paint)
: INHERITED(kDrawTextRSXform_OpType) : INHERITED(kDrawTextRSXform_OpType)
, fText(SkData::MakeWithCopy(text, byteLength)) , fText(SkData::MakeWithCopy(text, byteLength))
, fXform(xform, paint.countText(text, byteLength)) , fXform(xform, SkFont::LEGACY_ExtractFromPaint(paint).countText(text, byteLength, paint.getTextEncoding()))
, fCull(cull) , fCull(cull)
, fPaint(paint) {} , fPaint(paint) {}

View File

@ -628,13 +628,13 @@ void SkTestSVGTypeface::exportTtxCbdt(SkWStream* out) const {
int strikeSizes[3] = { 16, 64, 128 }; int strikeSizes[3] = { 16, 64, 128 };
SkPaint paint; SkPaint paint;
paint.setTypeface(sk_ref_sp(const_cast<SkTestSVGTypeface*>(this))); SkFont font;
paint.setTextEncoding(kGlyphID_SkTextEncoding); font.setTypeface(sk_ref_sp(const_cast<SkTestSVGTypeface*>(this)));
out->writeText(" <CBDT>\n"); out->writeText(" <CBDT>\n");
out->writeText(" <header version=\"2.0\"/>\n"); out->writeText(" <header version=\"2.0\"/>\n");
for (size_t strikeIndex = 0; strikeIndex < SK_ARRAY_COUNT(strikeSizes); ++strikeIndex) { for (size_t strikeIndex = 0; strikeIndex < SK_ARRAY_COUNT(strikeSizes); ++strikeIndex) {
paint.setTextSize(strikeSizes[strikeIndex]); font.setSize(strikeSizes[strikeIndex]);
out->writeText(" <strikedata index=\""); out->writeText(" <strikedata index=\"");
out->writeDecAsText(strikeIndex); out->writeDecAsText(strikeIndex);
out->writeText("\">\n"); out->writeText("\">\n");
@ -642,7 +642,7 @@ void SkTestSVGTypeface::exportTtxCbdt(SkWStream* out) const {
SkGlyphID gid = i; SkGlyphID gid = i;
SkScalar advance; SkScalar advance;
SkRect bounds; SkRect bounds;
paint.getTextWidths(&gid, sizeof(gid), &advance, &bounds); font.getWidthsBounds(&gid, 1, &advance, &bounds, nullptr);
SkIRect ibounds = bounds.roundOut(); SkIRect ibounds = bounds.roundOut();
if (ibounds.isEmpty()) { if (ibounds.isEmpty()) {
continue; continue;
@ -654,7 +654,8 @@ void SkTestSVGTypeface::exportTtxCbdt(SkWStream* out) const {
canvas->clear(0); canvas->clear(0);
SkPixmap pix; SkPixmap pix;
surface->peekPixels(&pix); surface->peekPixels(&pix);
canvas->drawText(&gid, sizeof(gid), -bounds.fLeft, -bounds.fTop, paint); canvas->drawSimpleText(&gid, sizeof(gid), kGlyphID_SkTextEncoding,
-bounds.fLeft, -bounds.fTop, font, paint);
canvas->flush(); canvas->flush();
sk_sp<SkImage> image = surface->makeImageSnapshot(); sk_sp<SkImage> image = surface->makeImageSnapshot();
sk_sp<SkData> data = image->encodeToData(SkEncodedImageFormat::kPNG, 100); sk_sp<SkData> data = image->encodeToData(SkEncodedImageFormat::kPNG, 100);
@ -701,8 +702,8 @@ void SkTestSVGTypeface::exportTtxCbdt(SkWStream* out) const {
out->writeText(" <CBLC>\n"); out->writeText(" <CBLC>\n");
out->writeText(" <header version=\"2.0\"/>\n"); out->writeText(" <header version=\"2.0\"/>\n");
for (size_t strikeIndex = 0; strikeIndex < SK_ARRAY_COUNT(strikeSizes); ++strikeIndex) { for (size_t strikeIndex = 0; strikeIndex < SK_ARRAY_COUNT(strikeSizes); ++strikeIndex) {
paint.setTextSize(strikeSizes[strikeIndex]); font.setSize(strikeSizes[strikeIndex]);
paint.getFontMetrics(&fm); font.getMetrics(&fm);
out->writeText(" <strike index=\""); out->writeText(" <strike index=\"");
out->writeDecAsText(strikeIndex); out->writeDecAsText(strikeIndex);
out->writeText("\">\n"); out->writeText("\">\n");
@ -763,7 +764,7 @@ void SkTestSVGTypeface::exportTtxCbdt(SkWStream* out) const {
for (int i = 0; i < fGlyphCount; ++i) { for (int i = 0; i < fGlyphCount; ++i) {
SkGlyphID gid = i; SkGlyphID gid = i;
SkRect bounds; SkRect bounds;
paint.getTextWidths(&gid, sizeof(gid), nullptr, &bounds); font.getBounds(&gid, 1, &bounds, nullptr);
if (bounds.isEmpty()) { if (bounds.isEmpty()) {
continue; continue;
} }
@ -796,8 +797,8 @@ void SkTestSVGTypeface::exportTtxSbix(SkWStream* out) const {
this->exportTtxCommon(out, "sbix"); this->exportTtxCommon(out, "sbix");
SkPaint paint; SkPaint paint;
paint.setTypeface(sk_ref_sp(const_cast<SkTestSVGTypeface*>(this))); SkFont font;
paint.setTextEncoding(kGlyphID_SkTextEncoding); font.setTypeface(sk_ref_sp(const_cast<SkTestSVGTypeface*>(this)));
out->writeText(" <glyf>\n"); out->writeText(" <glyf>\n");
for (int i = 0; i < fGlyphCount; ++i) { for (int i = 0; i < fGlyphCount; ++i) {
@ -847,7 +848,7 @@ void SkTestSVGTypeface::exportTtxSbix(SkWStream* out) const {
out->writeText(" <version value=\"1\"/>\n"); out->writeText(" <version value=\"1\"/>\n");
out->writeText(" <flags value=\"00000000 00000001\"/>\n"); out->writeText(" <flags value=\"00000000 00000001\"/>\n");
for (size_t strikeIndex = 0; strikeIndex < SK_ARRAY_COUNT(strikeSizes); ++strikeIndex) { for (size_t strikeIndex = 0; strikeIndex < SK_ARRAY_COUNT(strikeSizes); ++strikeIndex) {
paint.setTextSize(strikeSizes[strikeIndex]); font.setSize(strikeSizes[strikeIndex]);
out->writeText(" <strike>\n"); out->writeText(" <strike>\n");
out->writeText(" <ppem value=\""); out->writeText(" <ppem value=\"");
out->writeDecAsText(strikeSizes[strikeIndex]); out->writeDecAsText(strikeSizes[strikeIndex]);
@ -857,7 +858,7 @@ void SkTestSVGTypeface::exportTtxSbix(SkWStream* out) const {
SkGlyphID gid = i; SkGlyphID gid = i;
SkScalar advance; SkScalar advance;
SkRect bounds; SkRect bounds;
paint.getTextWidths(&gid, sizeof(gid), &advance, &bounds); font.getWidthsBounds(&gid, 1, &advance, &bounds, nullptr);
SkIRect ibounds = bounds.roundOut(); SkIRect ibounds = bounds.roundOut();
if (ibounds.isEmpty()) { if (ibounds.isEmpty()) {
continue; continue;
@ -869,7 +870,8 @@ void SkTestSVGTypeface::exportTtxSbix(SkWStream* out) const {
canvas->clear(0); canvas->clear(0);
SkPixmap pix; SkPixmap pix;
surface->peekPixels(&pix); surface->peekPixels(&pix);
canvas->drawText(&gid, sizeof(gid), -bounds.fLeft, -bounds.fTop, paint); canvas->drawSimpleText(&gid, sizeof(gid), kGlyphID_SkTextEncoding,
-bounds.fLeft, -bounds.fTop, font, paint);
canvas->flush(); canvas->flush();
sk_sp<SkImage> image = surface->makeImageSnapshot(); sk_sp<SkImage> image = surface->makeImageSnapshot();
sk_sp<SkData> data = image->encodeToData(SkEncodedImageFormat::kPNG, 100); sk_sp<SkData> data = image->encodeToData(SkEncodedImageFormat::kPNG, 100);