2012-08-27 14:11:33 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2012 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
2012-03-05 22:01:21 +00:00
|
|
|
#include "EdgeWalker_Test.h"
|
|
|
|
#include "Intersection_Tests.h"
|
2012-03-30 18:47:02 +00:00
|
|
|
#include "SkBitmap.h"
|
|
|
|
|
|
|
|
static SkBitmap bitmap;
|
2012-03-05 22:01:21 +00:00
|
|
|
|
|
|
|
static void testSimplifyQuad1() {
|
|
|
|
SkPath path, out;
|
|
|
|
path.moveTo(0, 0);
|
|
|
|
path.lineTo(1, 0);
|
|
|
|
path.lineTo(3, 2);
|
|
|
|
path.lineTo(3, 3);
|
|
|
|
path.close();
|
|
|
|
path.moveTo(1, 0);
|
|
|
|
path.lineTo(1, 3);
|
|
|
|
path.lineTo(1, 3);
|
|
|
|
path.lineTo(1, 3);
|
|
|
|
path.close();
|
2012-03-30 18:47:02 +00:00
|
|
|
testSimplify(path, true, out, bitmap);
|
2012-03-20 21:11:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void testSimplifyQuad2() {
|
|
|
|
SkPath path, out;
|
|
|
|
path.moveTo(0, 0);
|
|
|
|
path.lineTo(0, 0);
|
|
|
|
path.lineTo(0, 0);
|
|
|
|
path.lineTo(0, 2);
|
|
|
|
path.close();
|
|
|
|
path.moveTo(0, 1);
|
|
|
|
path.lineTo(0, 1);
|
|
|
|
path.lineTo(1, 1);
|
|
|
|
path.lineTo(0, 2);
|
|
|
|
path.close();
|
2012-03-30 18:47:02 +00:00
|
|
|
testSimplify(path, true, out, bitmap);
|
2012-03-20 21:11:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void testSimplifyQuad3() {
|
|
|
|
SkPath path, out;
|
|
|
|
path.moveTo(0, 0);
|
|
|
|
path.lineTo(0, 0);
|
|
|
|
path.lineTo(1, 0);
|
|
|
|
path.lineTo(1, 2);
|
|
|
|
path.close();
|
|
|
|
path.moveTo(0, 1);
|
|
|
|
path.lineTo(1, 1);
|
|
|
|
path.lineTo(2, 1);
|
|
|
|
path.lineTo(0, 2);
|
|
|
|
path.close();
|
2012-03-30 18:47:02 +00:00
|
|
|
testSimplify(path, true, out, bitmap);
|
2012-03-20 21:11:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void testSimplifyQuad4() {
|
|
|
|
SkPath path, out;
|
|
|
|
path.moveTo(0, 0);
|
|
|
|
path.lineTo(0, 0);
|
|
|
|
path.lineTo(1, 0);
|
|
|
|
path.lineTo(2, 2);
|
|
|
|
path.close();
|
|
|
|
path.moveTo(0, 0);
|
|
|
|
path.lineTo(2, 1);
|
|
|
|
path.lineTo(3, 1);
|
|
|
|
path.lineTo(3, 3);
|
|
|
|
path.close();
|
2012-03-30 18:47:02 +00:00
|
|
|
testSimplify(path, true, out, bitmap);
|
2012-03-20 21:11:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void testSimplifyQuad5() {
|
|
|
|
SkPath path, out;
|
|
|
|
path.moveTo(0, 0);
|
|
|
|
path.lineTo(0, 0);
|
|
|
|
path.lineTo(1, 0);
|
|
|
|
path.lineTo(3, 2);
|
|
|
|
path.close();
|
|
|
|
path.moveTo(0, 1);
|
|
|
|
path.lineTo(1, 1);
|
|
|
|
path.lineTo(2, 1);
|
|
|
|
path.lineTo(0, 2);
|
|
|
|
path.close();
|
2012-03-30 18:47:02 +00:00
|
|
|
testSimplify(path, true, out, bitmap);
|
2012-03-20 21:11:59 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void testSimplifyQuad6() {
|
|
|
|
SkPath path, out;
|
|
|
|
path.moveTo(0, 0);
|
|
|
|
path.lineTo(1, 0);
|
|
|
|
path.lineTo(1, 1);
|
|
|
|
path.lineTo(3, 3);
|
|
|
|
path.close();
|
|
|
|
path.moveTo(1, 1);
|
|
|
|
path.lineTo(1, 1);
|
|
|
|
path.lineTo(1, 1);
|
|
|
|
path.lineTo(2, 2);
|
|
|
|
path.close();
|
2012-03-30 18:47:02 +00:00
|
|
|
testSimplify(path, true, out, bitmap);
|
2012-03-05 22:01:21 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void (*simplifyTests[])() = {
|
2012-03-20 21:11:59 +00:00
|
|
|
testSimplifyQuad6,
|
|
|
|
testSimplifyQuad5,
|
|
|
|
testSimplifyQuad4,
|
|
|
|
testSimplifyQuad3,
|
|
|
|
testSimplifyQuad2,
|
2012-03-05 22:01:21 +00:00
|
|
|
testSimplifyQuad1,
|
|
|
|
};
|
|
|
|
|
|
|
|
static size_t simplifyTestsCount = sizeof(simplifyTests) / sizeof(simplifyTests[0]);
|
|
|
|
|
|
|
|
static void (*firstTest)() = 0;
|
|
|
|
|
|
|
|
void SimplifyQuadralateralPaths_Test() {
|
|
|
|
size_t index = 0;
|
|
|
|
if (firstTest) {
|
|
|
|
while (index < simplifyTestsCount && simplifyTests[index] != firstTest) {
|
|
|
|
++index;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
for ( ; index < simplifyTestsCount; ++index) {
|
|
|
|
(*simplifyTests[index])();
|
|
|
|
}
|
|
|
|
}
|