Chromium Code Reviews

Unified Diff: src/core/SkBBoxRecord.cpp

Issue 23001007: Remove the call to getFontMetrics from SkBBoxRecord (Closed) Base URL: https://skia.googlecode.com/svn/trunk
Patch Set: Created 7 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments.
Jump to:
View side-by-side diff with in-line comments
« no previous file with comments | « no previous file | src/core/SkPictureRecord.h » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: src/core/SkBBoxRecord.cpp
diff --git a/src/core/SkBBoxRecord.cpp b/src/core/SkBBoxRecord.cpp
index 366808703f6a97ef74987fde48a4a7d7f1bac818..1e6c69ba09c2a3a89b3b3a1186b85a7ae0c756cd 100644
--- a/src/core/SkBBoxRecord.cpp
+++ b/src/core/SkBBoxRecord.cpp
@@ -179,35 +179,45 @@ void SkBBoxRecord::drawPosText(const void* text, size_t byteLength,
void SkBBoxRecord::drawPosTextH(const void* text, size_t byteLength, const SkScalar xpos[],
SkScalar constY, const SkPaint& paint) {
- SkRect bbox;
size_t numChars = paint.countText(text, byteLength);
- if (numChars > 0) {
- bbox.fLeft = xpos[0];
- bbox.fRight = xpos[numChars - 1];
- // if we had a guarantee that these will be monotonically increasing, this could be sped up
- for (size_t i = 1; i < numChars; ++i) {
- if (xpos[i] < bbox.fLeft) {
- bbox.fLeft = xpos[i];
- }
- if (xpos[i] > bbox.fRight) {
- bbox.fRight = xpos[i];
- }
+ if (numChars == 0) {
+ return;
+ }
+
+ const SkFlatData* flatPaintData = this->getFlatPaintData(paint);
+ WriteTopBot(paint, *flatPaintData);
+
+ SkScalar top = flatPaintData->topBot()[0];
+ SkScalar bottom = flatPaintData->topBot()[1];
+ SkScalar pad = top - bottom;
+
+ SkRect bbox;
+ bbox.fLeft = SK_ScalarMax;
+ bbox.fRight = SK_ScalarMin;
+
+ for (size_t i = 0; i < numChars; ++i) {
+ if (xpos[i] < bbox.fLeft) {
+ bbox.fLeft = xpos[i];
}
- SkPaint::FontMetrics metrics;
- paint.getFontMetrics(&metrics);
-
- // pad horizontally by max glyph height
- SkScalar pad = (metrics.fTop - metrics.fBottom);
- bbox.fLeft += pad;
- bbox.fRight -= pad;
-
- bbox.fTop = metrics.fTop + constY;
- bbox.fBottom = metrics.fBottom + constY;
- if (!this->transformBounds(bbox, &paint)) {
- return;
+ if (xpos[i] > bbox.fRight) {
+ bbox.fRight = xpos[i];
}
}
- INHERITED::drawPosTextH(text, byteLength, xpos, constY, paint);
+
+ // pad horizontally by max glyph height
+ bbox.fLeft += pad;
+ bbox.fRight -= pad;
+
+ bbox.fTop = top + constY;
+ bbox.fBottom = bottom + constY;
+
+ if (!this->transformBounds(bbox, &paint)) {
+ return;
+ }
+ // This is the equivalent of calling:
+ // INHERITED::drawPosTextH(text, byteLength, xpos, constY, paint);
+ // but we filled our flat paint beforehand so that we could get font metrics.
+ drawPosTextHImpl(text, byteLength, xpos, constY, paint, flatPaintData);
}
void SkBBoxRecord::drawSprite(const SkBitmap& bitmap, int left, int top,
« no previous file with comments | « no previous file | src/core/SkPictureRecord.h » ('j') | no next file with comments »

Powered by Google App Engine