OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2012 Google Inc. | 2 * Copyright 2012 Google Inc. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license that can be | 4 * Use of this source code is governed by a BSD-style license that can be |
5 * found in the LICENSE file. | 5 * found in the LICENSE file. |
6 */ | 6 */ |
7 #include "PathOpsExtendedTest.h" | 7 #include "PathOpsExtendedTest.h" |
| 8 #include "PathOpsTestCommon.h" |
8 #include "SkIntersections.h" | 9 #include "SkIntersections.h" |
9 #include "SkPathOpsLine.h" | 10 #include "SkPathOpsLine.h" |
10 #include "SkPathOpsQuad.h" | 11 #include "SkPathOpsQuad.h" |
11 #include "SkReduceOrder.h" | 12 #include "SkReduceOrder.h" |
12 #include "Test.h" | 13 #include "Test.h" |
13 | 14 |
14 static struct lineQuad { | 15 static struct lineQuad { |
15 SkDQuad quad; | 16 SkDQuad quad; |
16 SkDLine line; | 17 SkDLine line; |
17 int result; | 18 int result; |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
65 {{{{369.848602, 145.680267}, {382.360413, 121.298294}, {406.207703, 121.2982
94}}}, | 66 {{{{369.848602, 145.680267}, {382.360413, 121.298294}, {406.207703, 121.2982
94}}}, |
66 {{{406.207703, 121.298294}, {348.781738, 123.864815}}}}, | 67 {{{406.207703, 121.298294}, {348.781738, 123.864815}}}}, |
67 }; | 68 }; |
68 | 69 |
69 static size_t oneOffs_count = SK_ARRAY_COUNT(oneOffs); | 70 static size_t oneOffs_count = SK_ARRAY_COUNT(oneOffs); |
70 | 71 |
71 static void testOneOffs(skiatest::Reporter* reporter) { | 72 static void testOneOffs(skiatest::Reporter* reporter) { |
72 bool flipped = false; | 73 bool flipped = false; |
73 for (size_t index = 0; index < oneOffs_count; ++index) { | 74 for (size_t index = 0; index < oneOffs_count; ++index) { |
74 const SkDQuad& quad = oneOffs[index].quad; | 75 const SkDQuad& quad = oneOffs[index].quad; |
| 76 SkASSERT(ValidQuad(quad)); |
75 const SkDLine& line = oneOffs[index].line; | 77 const SkDLine& line = oneOffs[index].line; |
| 78 SkASSERT(ValidLine(line)); |
76 SkIntersections intersections; | 79 SkIntersections intersections; |
77 int result = doIntersect(intersections, quad, line, flipped); | 80 int result = doIntersect(intersections, quad, line, flipped); |
78 for (int inner = 0; inner < result; ++inner) { | 81 for (int inner = 0; inner < result; ++inner) { |
79 double quadT = intersections[0][inner]; | 82 double quadT = intersections[0][inner]; |
80 SkDPoint quadXY = quad.xyAtT(quadT); | 83 SkDPoint quadXY = quad.xyAtT(quadT); |
81 double lineT = intersections[1][inner]; | 84 double lineT = intersections[1][inner]; |
82 SkDPoint lineXY = line.xyAtT(lineT); | 85 SkDPoint lineXY = line.xyAtT(lineT); |
83 REPORTER_ASSERT(reporter, quadXY.approximatelyEqual(lineXY)); | 86 REPORTER_ASSERT(reporter, quadXY.approximatelyEqual(lineXY)); |
84 } | 87 } |
85 } | 88 } |
86 } | 89 } |
87 | 90 |
88 static void PathOpsQuadLineIntersectionTestOne(skiatest::Reporter* reporter) { | 91 static void PathOpsQuadLineIntersectionTestOne(skiatest::Reporter* reporter) { |
89 testOneOffs(reporter); | 92 testOneOffs(reporter); |
90 } | 93 } |
91 | 94 |
92 static void PathOpsQuadLineIntersectionTest(skiatest::Reporter* reporter) { | 95 static void PathOpsQuadLineIntersectionTest(skiatest::Reporter* reporter) { |
93 for (size_t index = 0; index < lineQuadTests_count; ++index) { | 96 for (size_t index = 0; index < lineQuadTests_count; ++index) { |
94 int iIndex = static_cast<int>(index); | 97 int iIndex = static_cast<int>(index); |
95 const SkDQuad& quad = lineQuadTests[index].quad; | 98 const SkDQuad& quad = lineQuadTests[index].quad; |
| 99 SkASSERT(ValidQuad(quad)); |
96 const SkDLine& line = lineQuadTests[index].line; | 100 const SkDLine& line = lineQuadTests[index].line; |
| 101 SkASSERT(ValidLine(line)); |
97 SkReduceOrder reducer1, reducer2; | 102 SkReduceOrder reducer1, reducer2; |
98 int order1 = reducer1.reduce(quad, SkReduceOrder::kFill_Style); | 103 int order1 = reducer1.reduce(quad, SkReduceOrder::kFill_Style); |
99 int order2 = reducer2.reduce(line); | 104 int order2 = reducer2.reduce(line); |
100 if (order1 < 3) { | 105 if (order1 < 3) { |
101 SkDebugf("%s [%d] quad order=%d\n", __FUNCTION__, iIndex, order1); | 106 SkDebugf("%s [%d] quad order=%d\n", __FUNCTION__, iIndex, order1); |
102 REPORTER_ASSERT(reporter, 0); | 107 REPORTER_ASSERT(reporter, 0); |
103 } | 108 } |
104 if (order2 < 2) { | 109 if (order2 < 2) { |
105 SkDebugf("%s [%d] line order=%d\n", __FUNCTION__, iIndex, order2); | 110 SkDebugf("%s [%d] line order=%d\n", __FUNCTION__, iIndex, order2); |
106 REPORTER_ASSERT(reporter, 0); | 111 REPORTER_ASSERT(reporter, 0); |
(...skipping 24 matching lines...) Expand all Loading... |
131 REPORTER_ASSERT(reporter, 0); | 136 REPORTER_ASSERT(reporter, 0); |
132 } | 137 } |
133 } | 138 } |
134 } | 139 } |
135 } | 140 } |
136 | 141 |
137 #include "TestClassDef.h" | 142 #include "TestClassDef.h" |
138 DEFINE_TESTCLASS_SHORT(PathOpsQuadLineIntersectionTest) | 143 DEFINE_TESTCLASS_SHORT(PathOpsQuadLineIntersectionTest) |
139 | 144 |
140 DEFINE_TESTCLASS_SHORT(PathOpsQuadLineIntersectionTestOne) | 145 DEFINE_TESTCLASS_SHORT(PathOpsQuadLineIntersectionTestOne) |
OLD | NEW |