2011-07-28 18:26:00 +04:00
|
|
|
/*
|
|
|
|
* Copyright 2011 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
2013-12-13 01:11:12 +04:00
|
|
|
|
2012-11-09 02:36:19 +04:00
|
|
|
#include "SkRandom.h"
|
2011-02-07 20:48:40 +03:00
|
|
|
#include "SkRect.h"
|
2014-01-25 00:56:26 +04:00
|
|
|
#include "Test.h"
|
2011-02-07 20:48:40 +03:00
|
|
|
|
2011-02-07 22:08:59 +03:00
|
|
|
static float make_zero() {
|
|
|
|
return sk_float_sin(0);
|
|
|
|
}
|
2011-02-09 05:24:26 +03:00
|
|
|
|
2013-01-08 17:23:32 +04:00
|
|
|
struct RectCenter {
|
|
|
|
SkIRect fRect;
|
|
|
|
SkIPoint fCenter;
|
|
|
|
};
|
|
|
|
|
2012-11-09 02:36:19 +04:00
|
|
|
static void test_center(skiatest::Reporter* reporter) {
|
2013-01-08 17:23:32 +04:00
|
|
|
static const RectCenter gData[] = {
|
2012-11-09 02:36:19 +04:00
|
|
|
{ { 0, 0, 0, 0 }, { 0, 0 } },
|
|
|
|
{ { 0, 0, 1, 1 }, { 0, 0 } },
|
|
|
|
{ { -1, -1, 0, 0 }, { -1, -1 } },
|
|
|
|
{ { 0, 0, 10, 7 }, { 5, 3 } },
|
|
|
|
{ { 0, 0, 11, 6 }, { 5, 3 } },
|
|
|
|
};
|
2013-01-08 17:23:32 +04:00
|
|
|
for (size_t index = 0; index < SK_ARRAY_COUNT(gData); ++index) {
|
2012-11-09 02:36:19 +04:00
|
|
|
REPORTER_ASSERT(reporter,
|
2013-01-08 17:23:32 +04:00
|
|
|
gData[index].fRect.centerX() == gData[index].fCenter.x());
|
2012-11-09 02:36:19 +04:00
|
|
|
REPORTER_ASSERT(reporter,
|
2013-01-08 17:23:32 +04:00
|
|
|
gData[index].fRect.centerY() == gData[index].fCenter.y());
|
2012-11-09 02:36:19 +04:00
|
|
|
}
|
|
|
|
|
2013-09-10 00:09:12 +04:00
|
|
|
SkRandom rand;
|
2012-11-09 02:36:19 +04:00
|
|
|
for (int i = 0; i < 10000; ++i) {
|
|
|
|
SkIRect r;
|
2012-11-09 06:01:24 +04:00
|
|
|
|
2012-11-09 02:36:19 +04:00
|
|
|
r.set(rand.nextS() >> 2, rand.nextS() >> 2,
|
|
|
|
rand.nextS() >> 2, rand.nextS() >> 2);
|
|
|
|
int cx = r.centerX();
|
|
|
|
int cy = r.centerY();
|
2012-12-12 19:58:25 +04:00
|
|
|
REPORTER_ASSERT(reporter, ((r.left() + r.right()) >> 1) == cx);
|
|
|
|
REPORTER_ASSERT(reporter, ((r.top() + r.bottom()) >> 1) == cy);
|
2012-11-09 02:36:19 +04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2011-02-09 05:24:26 +03:00
|
|
|
static void check_invalid(skiatest::Reporter* reporter,
|
|
|
|
SkScalar l, SkScalar t, SkScalar r, SkScalar b) {
|
|
|
|
SkRect rect;
|
|
|
|
rect.set(l, t, r, b);
|
2011-12-06 22:56:37 +04:00
|
|
|
REPORTER_ASSERT(reporter, !rect.isFinite());
|
2011-02-09 05:24:26 +03:00
|
|
|
}
|
2011-02-07 22:08:59 +03:00
|
|
|
|
2011-12-06 22:56:37 +04:00
|
|
|
// Tests that isFinite() will reject any rect with +/-inf values
|
2011-02-07 20:48:40 +03:00
|
|
|
// as one of its coordinates.
|
2013-12-13 01:11:12 +04:00
|
|
|
DEF_TEST(InfRect, reporter) {
|
2012-05-16 17:35:36 +04:00
|
|
|
float inf = 1 / make_zero(); // infinity
|
|
|
|
float nan = inf * 0;
|
|
|
|
SkASSERT(!(nan == nan));
|
2011-02-09 05:24:26 +03:00
|
|
|
SkScalar small = SkIntToScalar(10);
|
|
|
|
SkScalar big = SkIntToScalar(100);
|
|
|
|
|
2012-05-16 17:35:36 +04:00
|
|
|
REPORTER_ASSERT(reporter, SkRect::MakeEmpty().isFinite());
|
|
|
|
|
2011-02-09 05:24:26 +03:00
|
|
|
SkRect rect = SkRect::MakeXYWH(small, small, big, big);
|
2011-12-06 22:56:37 +04:00
|
|
|
REPORTER_ASSERT(reporter, rect.isFinite());
|
2011-02-07 20:48:40 +03:00
|
|
|
|
2012-05-16 17:35:36 +04:00
|
|
|
const SkScalar invalid[] = { nan, inf, -inf };
|
|
|
|
for (size_t i = 0; i < SK_ARRAY_COUNT(invalid); ++i) {
|
|
|
|
check_invalid(reporter, small, small, big, invalid[i]);
|
|
|
|
check_invalid(reporter, small, small, invalid[i], big);
|
|
|
|
check_invalid(reporter, small, invalid[i], big, big);
|
|
|
|
check_invalid(reporter, invalid[i], small, big, big);
|
|
|
|
}
|
2012-11-09 06:01:24 +04:00
|
|
|
|
2012-11-09 02:36:19 +04:00
|
|
|
test_center(reporter);
|
2011-02-07 20:48:40 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
// need tests for SkStrSearch
|