Cleanups related to SkFixed.
This CL relands https://codereview.chromium.org/1683743005/ with two fixes: - Removing the test for vertical text. Vertical text doesn't work on Windows and breakText isn't supported for non-trivial text. - Omit PaintBreakTextTest in Google3 because we don't have the correct font setup yet. Remove SK_FixedNaN. It does not seem to be supported or used anywhere in Skia, Chromium, Android, or Google3, (except accidentally by TwoPtRadial::kDontDrawT). I think supporting it would erase any benefit of SkFixed over float. Remove SkBitmapFilter::lookup. It does not appear to be used anywhere in Skia, Chromium, Android, or Google3. Fix a bug in SkPaint::breakText that limited it to ~5kB of text. Now it can handle more than 1GB. BUG=skia:4632 GOLD_TRYBOT_URL= https://gold.skia.org/search2?unt=true&query=source_type%3Dgm&master=false&issue=1683743005 Committed: https://skia.googlesource.com/skia/+/7ea5cb18389db11a94175de95c9db2b44972630c patch from issue 1683743005 at patchset 120001 (http://crrev.com/1683743005#ps120001) Review URL: https://codereview.chromium.org/1739453002
This commit is contained in:
parent
d77061067a
commit
f6bfccd562
@ -22,7 +22,6 @@ typedef int32_t SkFixed;
|
||||
#define SK_FixedHalf (1 << 15)
|
||||
#define SK_FixedMax (0x7FFFFFFF)
|
||||
#define SK_FixedMin (-SK_FixedMax)
|
||||
#define SK_FixedNaN ((int) 0x80000000)
|
||||
#define SK_FixedPI (0x3243F)
|
||||
#define SK_FixedSqrt2 (92682)
|
||||
#define SK_FixedTanPIOver8 (0x6A0A)
|
||||
|
@ -463,8 +463,7 @@ struct SK_API SkRect {
|
||||
|
||||
/**
|
||||
* Returns true iff all values in the rect are finite. If any are
|
||||
* infinite or NaN (or SK_FixedNaN when SkScalar is fixed) then this
|
||||
* returns false.
|
||||
* infinite or NaN then this returns false.
|
||||
*/
|
||||
bool isFinite() const {
|
||||
float accum = 0;
|
||||
|
@ -464,7 +464,7 @@ def DM_ARGS(base_dir):
|
||||
"--nogpu",
|
||||
"--verbose",
|
||||
# TODO(mtklein): maybe investigate why these fail?
|
||||
"--match ~FontMgr ~Scalar ~Canvas ~Codec_stripes ~Codec_Dimensions ~Codec ~Stream ~skps ~RecordDraw_TextBounds",
|
||||
"--match ~FontMgr ~Scalar ~Canvas ~Codec_stripes ~Codec_Dimensions ~Codec ~Stream ~skps ~RecordDraw_TextBounds ~PaintBreakText",
|
||||
"--resourcePath %s/resources" % base_dir,
|
||||
"--images %s/resources" % base_dir,
|
||||
]
|
||||
|
@ -27,41 +27,6 @@
|
||||
#include "SkStream.h"
|
||||
#include "SkXMLParser.h"
|
||||
|
||||
static void test_breakText() {
|
||||
SkPaint paint;
|
||||
const char* text = "sdfkljAKLDFJKEWkldfjlk#$%&sdfs.dsj";
|
||||
size_t length = strlen(text);
|
||||
SkScalar width = paint.measureText(text, length);
|
||||
|
||||
SkScalar mm = 0;
|
||||
SkScalar nn = 0;
|
||||
for (SkScalar w = 0; w <= width; w += SK_Scalar1) {
|
||||
SkScalar m;
|
||||
size_t n = paint.breakText(text, length, w, &m);
|
||||
|
||||
SkASSERT(n <= length);
|
||||
SkASSERT(m <= width);
|
||||
|
||||
if (n == 0) {
|
||||
SkASSERT(m == 0);
|
||||
} else {
|
||||
// now assert that we're monotonic
|
||||
if (n == nn) {
|
||||
SkASSERT(m == mm);
|
||||
} else {
|
||||
SkASSERT(n > nn);
|
||||
SkASSERT(m > mm);
|
||||
}
|
||||
}
|
||||
nn = SkIntToScalar((unsigned int)n);
|
||||
mm = m;
|
||||
}
|
||||
|
||||
SkDEBUGCODE(size_t length2 =) paint.breakText(text, length, width, &mm);
|
||||
SkASSERT(length2 == length);
|
||||
SkASSERT(mm == width);
|
||||
}
|
||||
|
||||
static const struct {
|
||||
const char* fName;
|
||||
uint32_t fFlags;
|
||||
@ -109,8 +74,6 @@ public:
|
||||
TextSpeedView() {
|
||||
fHints = 0;
|
||||
fClickX = 0;
|
||||
|
||||
test_breakText();
|
||||
}
|
||||
|
||||
protected:
|
||||
|
@ -28,15 +28,6 @@ public:
|
||||
}
|
||||
virtual ~SkBitmapFilter() {}
|
||||
|
||||
SkFixed lookup(float x) const {
|
||||
if (!fPrecomputed) {
|
||||
precomputeTable();
|
||||
}
|
||||
int filter_idx = int(sk_float_abs(x * fLookupMultiplier));
|
||||
SkASSERT(filter_idx < SKBITMAP_FILTER_TABLE_SIZE);
|
||||
return fFilterTable[filter_idx];
|
||||
}
|
||||
|
||||
SkScalar lookupScalar(float x) const {
|
||||
if (!fPrecomputed) {
|
||||
precomputeTable();
|
||||
@ -67,19 +58,16 @@ protected:
|
||||
float fLookupMultiplier;
|
||||
|
||||
mutable bool fPrecomputed;
|
||||
mutable SkFixed fFilterTable[SKBITMAP_FILTER_TABLE_SIZE];
|
||||
mutable SkScalar fFilterTableScalar[SKBITMAP_FILTER_TABLE_SIZE];
|
||||
|
||||
private:
|
||||
void precomputeTable() const {
|
||||
fPrecomputed = true;
|
||||
SkFixed *ftp = fFilterTable;
|
||||
SkScalar *ftpScalar = fFilterTableScalar;
|
||||
for (int x = 0; x < SKBITMAP_FILTER_TABLE_SIZE; ++x) {
|
||||
float fx = ((float)x + .5f) * this->width() / SKBITMAP_FILTER_TABLE_SIZE;
|
||||
float filter_value = evaluate(fx);
|
||||
*ftpScalar++ = filter_value;
|
||||
*ftp++ = SkFloatToFixed(filter_value);
|
||||
}
|
||||
}
|
||||
};
|
||||
|
@ -925,7 +925,7 @@ size_t SkPaint::breakText(const void* textD, size_t length, SkScalar maxWidth,
|
||||
GlyphCacheProc glyphCacheProc = paint.getGlyphCacheProc(false);
|
||||
const int xyIndex = paint.isVerticalText() ? 1 : 0;
|
||||
// use 64bits for our accumulator, to avoid overflowing 16.16
|
||||
Sk48Dot16 max = SkScalarToFixed(maxWidth);
|
||||
Sk48Dot16 max = SkScalarTo48Dot16(maxWidth);
|
||||
Sk48Dot16 width = 0;
|
||||
|
||||
SkAutoKern autokern;
|
||||
|
@ -15,6 +15,7 @@
|
||||
// Should only be initialized once via init(). Immutable afterwards.
|
||||
struct TwoPtRadial {
|
||||
enum {
|
||||
// This value is outside the range SK_FixedMin to SK_FixedMax.
|
||||
kDontDrawT = 0x80000000
|
||||
};
|
||||
|
||||
|
84
tests/PaintBreakTextTest.cpp
Normal file
84
tests/PaintBreakTextTest.cpp
Normal file
@ -0,0 +1,84 @@
|
||||
/*
|
||||
* Copyright 2011-2016 Google Inc.
|
||||
*
|
||||
* Use of this source code is governed by a BSD-style license that can be
|
||||
* found in the LICENSE file.
|
||||
*/
|
||||
|
||||
#include "SkPaint.h"
|
||||
#include "Test.h"
|
||||
|
||||
static void test_monotonic(skiatest::Reporter* reporter,
|
||||
const SkPaint& paint,
|
||||
const char* msg) {
|
||||
const char* text = "sdfkljAKLDFJKEWkldfjlk#$%&sdfs.dsj";
|
||||
const size_t length = strlen(text);
|
||||
const SkScalar width = paint.measureText(text, length);
|
||||
|
||||
SkScalar mm = 0;
|
||||
size_t nn = 0;
|
||||
const SkScalar step = SkMaxScalar(width / 10, SK_Scalar1);
|
||||
for (SkScalar w = 0; w <= width; w += step) {
|
||||
SkScalar m;
|
||||
const size_t n = paint.breakText(text, length, w, &m);
|
||||
|
||||
REPORTER_ASSERT_MESSAGE(reporter, n <= length, msg);
|
||||
REPORTER_ASSERT_MESSAGE(reporter, m <= width, msg);
|
||||
|
||||
if (n == 0) {
|
||||
REPORTER_ASSERT_MESSAGE(reporter, m == 0, msg);
|
||||
} else {
|
||||
// now assert that we're monotonic
|
||||
if (n == nn) {
|
||||
REPORTER_ASSERT_MESSAGE(reporter, m == mm, msg);
|
||||
} else {
|
||||
REPORTER_ASSERT_MESSAGE(reporter, n > nn, msg);
|
||||
REPORTER_ASSERT_MESSAGE(reporter, m > mm, msg);
|
||||
}
|
||||
}
|
||||
nn = n;
|
||||
mm = m;
|
||||
}
|
||||
}
|
||||
|
||||
static void test_eq_measure_text(skiatest::Reporter* reporter,
|
||||
const SkPaint& paint,
|
||||
const char* msg) {
|
||||
const char* text = "The ultimate measure of a man is not where he stands in moments of comfort "
|
||||
"and convenience, but where he stands at times of challenge and controversy.";
|
||||
const size_t length = strlen(text);
|
||||
const SkScalar width = paint.measureText(text, length);
|
||||
|
||||
SkScalar mm;
|
||||
const size_t length2 = paint.breakText(text, length, width, &mm);
|
||||
REPORTER_ASSERT_MESSAGE(reporter, length2 == length, msg);
|
||||
REPORTER_ASSERT_MESSAGE(reporter, mm == width, msg);
|
||||
}
|
||||
|
||||
static void test_long_text(skiatest::Reporter* reporter,
|
||||
const SkPaint& paint,
|
||||
const char* msg) {
|
||||
static const int kSize = 16 * 1024;
|
||||
SkAutoMalloc block(kSize);
|
||||
memset(block.get(), 'a', kSize - 1);
|
||||
char* text = static_cast<char*>(block.get());
|
||||
text[kSize - 1] = '\0';
|
||||
const SkScalar width = paint.measureText(text, kSize);
|
||||
|
||||
SkScalar mm;
|
||||
const size_t length = paint.breakText(text, kSize, width, &mm);
|
||||
REPORTER_ASSERT_MESSAGE(reporter, length == kSize, msg);
|
||||
REPORTER_ASSERT_MESSAGE(reporter, mm == width, msg);
|
||||
}
|
||||
|
||||
DEF_TEST(PaintBreakText, reporter) {
|
||||
SkPaint paint;
|
||||
test_monotonic(reporter, paint, "default");
|
||||
test_eq_measure_text(reporter, paint, "default");
|
||||
test_long_text(reporter, paint, "default");
|
||||
paint.setTextSize(SkIntToScalar(1 << 17));
|
||||
test_monotonic(reporter, paint, "huge text size");
|
||||
test_eq_measure_text(reporter, paint, "huge text size");
|
||||
paint.setTextSize(0);
|
||||
test_monotonic(reporter, paint, "zero text size");
|
||||
}
|
Loading…
Reference in New Issue
Block a user