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:
parent
eae1d10f5d
commit
34c9b6d63e
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
@ -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;
|
||||||
|
@ -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));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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) {}
|
||||||
|
|
||||||
|
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user