109dbbe93SAndrew Rist /**************************************************************
2cdf0e10cSrcweir *
309dbbe93SAndrew Rist * Licensed to the Apache Software Foundation (ASF) under one
409dbbe93SAndrew Rist * or more contributor license agreements. See the NOTICE file
509dbbe93SAndrew Rist * distributed with this work for additional information
609dbbe93SAndrew Rist * regarding copyright ownership. The ASF licenses this file
709dbbe93SAndrew Rist * to you under the Apache License, Version 2.0 (the
809dbbe93SAndrew Rist * "License"); you may not use this file except in compliance
909dbbe93SAndrew Rist * with the License. You may obtain a copy of the License at
10cdf0e10cSrcweir *
1109dbbe93SAndrew Rist * http://www.apache.org/licenses/LICENSE-2.0
12cdf0e10cSrcweir *
1309dbbe93SAndrew Rist * Unless required by applicable law or agreed to in writing,
1409dbbe93SAndrew Rist * software distributed under the License is distributed on an
1509dbbe93SAndrew Rist * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
1609dbbe93SAndrew Rist * KIND, either express or implied. See the License for the
1709dbbe93SAndrew Rist * specific language governing permissions and limitations
1809dbbe93SAndrew Rist * under the License.
19cdf0e10cSrcweir *
2009dbbe93SAndrew Rist *************************************************************/
2109dbbe93SAndrew Rist
2209dbbe93SAndrew Rist
23cdf0e10cSrcweir
24cdf0e10cSrcweir
25cdf0e10cSrcweir // MARKER(update_precomp.py): autogen include statement, do not remove
26cdf0e10cSrcweir #include "precompiled_basegfx.hxx"
27cdf0e10cSrcweir // autogenerated file with codegen.pl
28cdf0e10cSrcweir
29cdf0e10cSrcweir #include "preextstl.h"
30131e08e2SDamjan Jovanovic #include "gtest/gtest.h"
31cdf0e10cSrcweir #include "postextstl.h"
32cdf0e10cSrcweir
33cdf0e10cSrcweir #include <basegfx/matrix/b2dhommatrix.hxx>
34cdf0e10cSrcweir #include <basegfx/polygon/b2dpolygon.hxx>
35cdf0e10cSrcweir #include <basegfx/polygon/b2dpolygontools.hxx>
36cdf0e10cSrcweir #include <basegfx/curve/b2dcubicbezier.hxx>
37cdf0e10cSrcweir #include <basegfx/curve/b2dbeziertools.hxx>
38cdf0e10cSrcweir #include <basegfx/polygon/b2dpolypolygontools.hxx>
39cdf0e10cSrcweir #include <basegfx/polygon/b2dpolygonclipper.hxx>
40cdf0e10cSrcweir #include <basegfx/polygon/b2dpolypolygon.hxx>
41cdf0e10cSrcweir #include <basegfx/range/b2dpolyrange.hxx>
42cdf0e10cSrcweir #include <basegfx/numeric/ftools.hxx>
43cdf0e10cSrcweir #include <basegfx/color/bcolor.hxx>
44cdf0e10cSrcweir #include <basegfx/color/bcolortools.hxx>
45cdf0e10cSrcweir
46cdf0e10cSrcweir #include <basegfx/tools/debugplotter.hxx>
47cdf0e10cSrcweir
48cdf0e10cSrcweir #include <iostream>
49cdf0e10cSrcweir #include <fstream>
50cdf0e10cSrcweir
51cdf0e10cSrcweir using namespace ::basegfx;
52cdf0e10cSrcweir
53cdf0e10cSrcweir
54cdf0e10cSrcweir namespace basegfx2d
55cdf0e10cSrcweir {
56cdf0e10cSrcweir
57131e08e2SDamjan Jovanovic class b2dsvgdimpex : public ::testing::Test
58cdf0e10cSrcweir {
59131e08e2SDamjan Jovanovic protected:
60cdf0e10cSrcweir ::rtl::OUString aPath0;
61cdf0e10cSrcweir ::rtl::OUString aPath1;
62cdf0e10cSrcweir ::rtl::OUString aPath2;
63cdf0e10cSrcweir ::rtl::OUString aPath3;
64cdf0e10cSrcweir
65cdf0e10cSrcweir public:
66cdf0e10cSrcweir // initialise your test code values here.
SetUp()67131e08e2SDamjan Jovanovic virtual void SetUp()
68cdf0e10cSrcweir {
69cdf0e10cSrcweir // simple rectangle
70cdf0e10cSrcweir aPath0 = ::rtl::OUString::createFromAscii(
71cdf0e10cSrcweir "M 10 10-10 10-10-10 10-10Z" );
72cdf0e10cSrcweir
73cdf0e10cSrcweir // simple bezier polygon
74cdf0e10cSrcweir aPath1 = ::rtl::OUString::createFromAscii(
75cdf0e10cSrcweir "m11430 0c-8890 3810 5715 6985 5715 6985 "
76cdf0e10cSrcweir "0 0-17145-1905-17145-1905 0 0 22860-10160 "
77cdf0e10cSrcweir "16510 6350-6350 16510-3810-11430-3810-11430z" );
78cdf0e10cSrcweir
79cdf0e10cSrcweir // '@' as a bezier polygon
80cdf0e10cSrcweir aPath2 = ::rtl::OUString::createFromAscii(
81cdf0e10cSrcweir "m1917 1114c-89-189-233-284-430-284-167 "
82cdf0e10cSrcweir "0-306 91-419 273-113 182-170 370-170 564 "
83cdf0e10cSrcweir "0 145 33 259 98 342 65 84 150 126 257 126 "
84cdf0e10cSrcweir "77 0 154-19 231-57 77-38 147-97 210-176 63"
85cdf0e10cSrcweir "-79 99-143 109-190 38-199 76-398 114-598z"
86cdf0e10cSrcweir "m840 1646c-133 73-312 139-537 197-225 57"
87cdf0e10cSrcweir "-440 86-644 87-483-1-866-132-1150-392-284"
88cdf0e10cSrcweir "-261-426-619-426-1076 0-292 67-560 200-803 "
89cdf0e10cSrcweir "133-243 321-433 562-569 241-136 514-204 821"
90cdf0e10cSrcweir "-204 405 0 739 125 1003 374 264 250 396 550 "
91cdf0e10cSrcweir "396 899 0 313-88 576-265 787-177 212-386 318"
92cdf0e10cSrcweir "-627 318-191 0-308-94-352-281-133 187-315 281"
93cdf0e10cSrcweir "-546 281-172 0-315-67-428-200-113-133-170-301"
94cdf0e10cSrcweir "-170-505 0-277 90-527 271-751 181-223 394"
95cdf0e10cSrcweir "-335 640-335 196 0 353 83 470 250 13-68 26"
96cdf0e10cSrcweir "-136 41-204 96 0 192 0 288 0-74 376-148 752"
97cdf0e10cSrcweir "-224 1128-21 101-31 183-31 245 0 39 9 70 26 "
98cdf0e10cSrcweir "93 17 24 39 36 67 36 145 0 279-80 400-240 121"
99cdf0e10cSrcweir "-160 182-365 182-615 0-288-107-533-322-734"
100cdf0e10cSrcweir "-215-201-487-301-816-301-395 0-715 124-960 "
101cdf0e10cSrcweir "373-245 249-368 569-368 958 0 385 119 685 "
102cdf0e10cSrcweir "357 900 237 216 557 324 958 325 189-1 389-27 "
103cdf0e10cSrcweir "600-77 211-52 378-110 503-174 27 70 54 140 81 210z" );
104cdf0e10cSrcweir
105cdf0e10cSrcweir // first part of 'Hello World' as a line polygon
106cdf0e10cSrcweir aPath3 = ::rtl::OUString::createFromAscii(
107cdf0e10cSrcweir "m1598 125h306v2334h-306v-1105h-1293v1105h-305v"
108cdf0e10cSrcweir "-2334h305v973h1293zm2159 1015 78-44 85 235-91 "
109cdf0e10cSrcweir "47-91 40-90 34-90 29-89 21-88 16-88 10-88 3-102"
110cdf0e10cSrcweir "-4-97-12-91-19-85-26-40-16-39-18-38-20-36-22-34"
111cdf0e10cSrcweir "-24-33-26-32-27-30-30-29-31-27-33-25-33-23-36-21"
112cdf0e10cSrcweir "-36-19-38-18-40-16-40-26-86-18-91-11-97-4-103 3"
113cdf0e10cSrcweir "-98 11-94 17-89 24-84 31-79 37-75 22-35 23-34 24"
114cdf0e10cSrcweir "-33 27-32 28-30 29-28 31-27 31-24 33-22 34-21 35"
115cdf0e10cSrcweir "-18 37-17 38-14 38-13 41-11 41-8 86-12 91-4 82 4 "
116cdf0e10cSrcweir "78 10 37 9 37 9 36 12 35 14 33 15 33 17 32 19 31 "
117cdf0e10cSrcweir "21 30 22 30 25 55 54 26 29 24 31 22 32 21 33 19 "
118cdf0e10cSrcweir "34 18 36 30 74 23 80 17 84 10 89 3 94v78h-1277l6 "
119cdf0e10cSrcweir "75 10 70 14 66 19 62 23 57 13 26 14 26 15 25 17 "
120cdf0e10cSrcweir "23 17 22 19 21 19 20 21 18 21 18 23 16 23 14 24 "
121cdf0e10cSrcweir "14 26 12 26 11 27 10 28 8 59 13 63 7 67 3 80-3 81"
122cdf0e10cSrcweir "-9 79-14 80-21 78-26 79-32zm-1049-808-12 53h963l"
123cdf0e10cSrcweir "-7-51-11-49-14-46-17-43-21-40-24-38-27-36-31-32"
124cdf0e10cSrcweir "-33-29-35-25-37-22-38-17-40-14-41-9-42-6-44-2-48 "
125cdf0e10cSrcweir "2-46 6-44 9-42 13-40 17-38 21-36 24-34 28-32 32"
126cdf0e10cSrcweir "-29 34-26 38-23 41-20 44-17 47zm1648-1293h288v"
127cdf0e10cSrcweir "2459h-288zm752-2459h288v2459h-288zm1286-1750 86-11 "
128cdf0e10cSrcweir "91-4 91 4 85 12 42 8 39 11 39 13 38 14 36 17 35 18 "
129cdf0e10cSrcweir "34 20 33 23 31 24 30 26 29 28 28 30 26 32 25 33 23 "
130cdf0e10cSrcweir "34 21 35 37 75 31 80 24 84 16 90 11 94 3 100-3 100"
131cdf0e10cSrcweir "-11 95-16 89-24 85-31 80-37 74-21 35-23 35-25 32-26 "
132cdf0e10cSrcweir "32-28 30-29 28-30 26-31 24-33 22-34 21-35 18-36 17"
133cdf0e10cSrcweir "-38 14-39 13-39 10-42 9-85 12-91 4-91-4-86-12-41-9"
134cdf0e10cSrcweir "-40-10-39-13-37-14-36-17-35-18-34-21-33-22-31-24-30"
135cdf0e10cSrcweir "-26-29-28-28-30-26-32-25-32-23-35-21-35-38-74-30-80"
136cdf0e10cSrcweir "-24-85-17-89-11-95-3-100 3-101 11-95 17-90 24-85 30"
137cdf0e10cSrcweir "-79 38-75 21-35 23-35 25-32 26-32 28-30 29-28 30-26 "
138cdf0e10cSrcweir "31-24 33-22 34-20 35-18 36-16 37-15 39-12 40-11z" );
139cdf0e10cSrcweir }
140cdf0e10cSrcweir
TearDown()141131e08e2SDamjan Jovanovic virtual void TearDown()
142cdf0e10cSrcweir {
143cdf0e10cSrcweir }
144131e08e2SDamjan Jovanovic }; // class b2dsvgdimpex
145cdf0e10cSrcweir
TEST_F(b2dsvgdimpex,impex)146131e08e2SDamjan Jovanovic TEST_F(b2dsvgdimpex,impex)
147cdf0e10cSrcweir {
148cdf0e10cSrcweir B2DPolyPolygon aPoly;
149cdf0e10cSrcweir ::rtl::OUString aExport;
150cdf0e10cSrcweir
151131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::importFromSvgD( aPoly, aPath0, false, 0 )) << "importing simple rectangle from SVG-D";
1521f882ec4SArmin Le Grand aExport = tools::exportToSvgD( aPoly, true, true, false );
153cdf0e10cSrcweir const char* sExportString = "m10 10h-20v-20h20z";
154131e08e2SDamjan Jovanovic ASSERT_TRUE(!aExport.compareToAscii(sExportString) ) << "exporting rectangle to SVG-D";
155131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::importFromSvgD( aPoly, aExport, false, 0 )) << "importing simple rectangle from SVG-D (round-trip";
1561f882ec4SArmin Le Grand aExport = tools::exportToSvgD( aPoly, true, true, false );
157131e08e2SDamjan Jovanovic ASSERT_TRUE(!aExport.compareToAscii(sExportString)) << "exporting rectangle to SVG-D (round-trip)";
158cdf0e10cSrcweir
159131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::importFromSvgD( aPoly, aPath1, false, 0 )) << "importing simple bezier polygon from SVG-D";
1601f882ec4SArmin Le Grand aExport = tools::exportToSvgD( aPoly, true, true, false );
161cdf0e10cSrcweir
162cdf0e10cSrcweir // Adaptions for B2DPolygon bezier change (see #i77162#):
163cdf0e10cSrcweir //
164cdf0e10cSrcweir // The import/export of aPath1 does not reproduce aExport again. This is
165cdf0e10cSrcweir // correct since aPath1 contains a segment with non-used control points
166cdf0e10cSrcweir // which gets exported now correctly as 'l' and also a point (#4, index 3)
167*d941b70cSJohn Bampton // with C2 continuity which produces a 's' statement now.
168cdf0e10cSrcweir //
169*d941b70cSJohn Bampton // The old SVGexport identified nun-used ControlVectors erroneously as bezier segments
170cdf0e10cSrcweir // because the 2nd vector at the start point was used, even when added
171cdf0e10cSrcweir // with start point was identical to end point. Exactly for that reason
172cdf0e10cSrcweir // i reworked the B2DPolygon to use prev, next control points.
173cdf0e10cSrcweir //
174cdf0e10cSrcweir // so for correct unit test i add the new exported string here as sExportStringSimpleBezier
175cdf0e10cSrcweir // and compare to it.
176cdf0e10cSrcweir const char* sExportStringSimpleBezier =
177cdf0e10cSrcweir "m11430 0c-8890 3810 5715 6985 5715 6985"
178cdf0e10cSrcweir "l-17145-1905c0 0 22860-10160 16510 6350"
179cdf0e10cSrcweir "s-3810-11430-3810-11430z";
180131e08e2SDamjan Jovanovic ASSERT_TRUE(!aExport.compareToAscii(sExportStringSimpleBezier)) << "exporting bezier polygon to SVG-D";
181cdf0e10cSrcweir
182cdf0e10cSrcweir // Adaptions for B2DPolygon bezier change (see #i77162#):
183cdf0e10cSrcweir //
184cdf0e10cSrcweir // a 2nd good test is that re-importing of aExport has to create the same
185cdf0e10cSrcweir // B2DPolPolygon again:
186cdf0e10cSrcweir B2DPolyPolygon aReImport;
187131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::importFromSvgD( aReImport, aExport, false, 0)) << "importing simple bezier polygon from SVG-D";
188131e08e2SDamjan Jovanovic ASSERT_TRUE(aReImport == aPoly) << "re-imported polygon needs to be identical";
189cdf0e10cSrcweir
190131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::importFromSvgD( aPoly, aPath2, false, 0)) << "importing '@' from SVG-D";
1911f882ec4SArmin Le Grand aExport = tools::exportToSvgD( aPoly, true, true, false );
192cdf0e10cSrcweir
193cdf0e10cSrcweir // Adaptions for B2DPolygon bezier change (see #i77162#):
194cdf0e10cSrcweir //
195cdf0e10cSrcweir // same here, the corrected export with the corrected B2DPolygon is simply more efficient,
196cdf0e10cSrcweir // so i needed to change the compare string. Also adding the re-import comparison below.
197cdf0e10cSrcweir const char* sExportString1 =
198cdf0e10cSrcweir "m1917 1114c-89-189-233-284-430-284-167 0-306 91-419 273s-170 370-17"
199cdf0e10cSrcweir "0 564c0 145 33 259 98 342 65 84 150 126 257 126q115.5 0 231-57s147-97 210-176 99-143 109-190c38-199 76-398 114"
200cdf0e10cSrcweir "-598zm840 1646c-133 73-312 139-537 197-225 57-440 86-644 87-483-1-866-132-1150-392-284-261-426-619-426-1076 0-"
201cdf0e10cSrcweir "292 67-560 200-803s321-433 562-569 514-204 821-204c405 0 739 125 1003 374 264 250 396 550 396 899 0 313-88 576"
202cdf0e10cSrcweir "-265 787q-265.5 318-627 318c-191 0-308-94-352-281-133 187-315 281-546 281-172 0-315-67-428-200s-170-301-170-50"
203cdf0e10cSrcweir "5c0-277 90-527 271-751 181-223 394-335 640-335 196 0 353 83 470 250 13-68 26-136 41-204q144 0 288 0c-74 376-14"
204cdf0e10cSrcweir "8 752-224 1128-21 101-31 183-31 245 0 39 9 70 26 93 17 24 39 36 67 36 145 0 279-80 400-240s182-365 182-615c0-2"
205cdf0e10cSrcweir "88-107-533-322-734s-487-301-816-301c-395 0-715 124-960 373s-368 569-368 958q0 577.5 357 900c237 216 557 324 95"
206cdf0e10cSrcweir "8 325 189-1 389-27 600-77 211-52 378-110 503-174q40.5 105 81 210z";
207131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::importFromSvgD( aReImport, aExport, false, 0)) << "re-importing '@' from SVG-D";
208131e08e2SDamjan Jovanovic ASSERT_TRUE(aReImport == aPoly) << "re-imported '@' needs to be identical";
209cdf0e10cSrcweir
210131e08e2SDamjan Jovanovic ASSERT_TRUE(!aExport.compareToAscii(sExportString1)) << "exporting '@' to SVG-D";
211131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::importFromSvgD( aPoly, aExport, false, 0 )) << "importing '@' from SVG-D (round-trip)";
2121f882ec4SArmin Le Grand aExport = tools::exportToSvgD( aPoly, true, true, false );
213131e08e2SDamjan Jovanovic ASSERT_TRUE(!aExport.compareToAscii(sExportString1)) << "exporting '@' to SVG-D (round-trip)";
214cdf0e10cSrcweir
215cdf0e10cSrcweir
216131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::importFromSvgD( aPoly, aPath3, false, 0 )) << "importing complex polygon from SVG-D";
2171f882ec4SArmin Le Grand aExport = tools::exportToSvgD( aPoly, true, true, false );
218cdf0e10cSrcweir const char* sExportString2 =
219cdf0e10cSrcweir "m1598 125h306v2334h-306v-1105h-1293v1105h-305v-2334h305v973h1293"
220cdf0e10cSrcweir "zm2159 1015 78-44 85 235-91 47-91 40-90 34-90 29-89 21-88 16-88 10-88 3-102-4-97"
221cdf0e10cSrcweir "-12-91-19-85-26-40-16-39-18-38-20-36-22-34-24-33-26-32-27-30-30-29-31-27-33-25-3"
222cdf0e10cSrcweir "3-23-36-21-36-19-38-18-40-16-40-26-86-18-91-11-97-4-103 3-98 11-94 17-89 24-84 3"
223cdf0e10cSrcweir "1-79 37-75 22-35 23-34 24-33 27-32 28-30 29-28 31-27 31-24 33-22 34-21 35-18 37-"
224cdf0e10cSrcweir "17 38-14 38-13 41-11 41-8 86-12 91-4 82 4 78 10 37 9 37 9 36 12 35 14 33 15 33 1"
225cdf0e10cSrcweir "7 32 19 31 21 30 22 30 25 55 54 26 29 24 31 22 32 21 33 19 34 18 36 30 74 23 80 "
226cdf0e10cSrcweir "17 84 10 89 3 94v78h-1277l6 75 10 70 14 66 19 62 23 57 13 26 14 26 15 25 17 23 1"
227cdf0e10cSrcweir "7 22 19 21 19 20 21 18 21 18 23 16 23 14 24 14 26 12 26 11 27 10 28 8 59 13 63 7"
228cdf0e10cSrcweir " 67 3 80-3 81-9 79-14 80-21 78-26 79-32zm-1049-808-12 53h963l-7-51-11-49-14-46-1"
229cdf0e10cSrcweir "7-43-21-40-24-38-27-36-31-32-33-29-35-25-37-22-38-17-40-14-41-9-42-6-44-2-48 2-4"
230cdf0e10cSrcweir "6 6-44 9-42 13-40 17-38 21-36 24-34 28-32 32-29 34-26 38-23 41-20 44-17 47zm1648"
231cdf0e10cSrcweir "-1293h288v2459h-288zm752-2459h288v2459h-288zm1286-1750 86-11 91-4 91 4 85 12 42 "
232cdf0e10cSrcweir "8 39 11 39 13 38 14 36 17 35 18 34 20 33 23 31 24 30 26 29 28 28 30 26 32 25 33 "
233cdf0e10cSrcweir "23 34 21 35 37 75 31 80 24 84 16 90 11 94 3 100-3 100-11 95-16 89-24 85-31 80-37"
234cdf0e10cSrcweir " 74-21 35-23 35-25 32-26 32-28 30-29 28-30 26-31 24-33 22-34 21-35 18-36 17-38 1"
235cdf0e10cSrcweir "4-39 13-39 10-42 9-85 12-91 4-91-4-86-12-41-9-40-10-39-13-37-14-36-17-35-18-34-2"
236cdf0e10cSrcweir "1-33-22-31-24-30-26-29-28-28-30-26-32-25-32-23-35-21-35-38-74-30-80-24-85-17-89-"
237cdf0e10cSrcweir "11-95-3-100 3-101 11-95 17-90 24-85 30-79 38-75 21-35 23-35 25-32 26-32 28-30 29"
238cdf0e10cSrcweir "-28 30-26 31-24 33-22 34-20 35-18 36-16 37-15 39-12 40-11z";
239131e08e2SDamjan Jovanovic ASSERT_TRUE(!aExport.compareToAscii(sExportString2)) << "exporting complex polygon to SVG-D";
240131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::importFromSvgD( aPoly, aExport, false, 0 )) << "importing complex polygon from SVG-D (round-trip)";
2411f882ec4SArmin Le Grand aExport = tools::exportToSvgD( aPoly, true, true, false );
242131e08e2SDamjan Jovanovic ASSERT_TRUE(!aExport.compareToAscii(sExportString2)) << "exporting complex polygon to SVG-D (round-trip)";
243cdf0e10cSrcweir
244cdf0e10cSrcweir const B2DPolygon aRect(
245cdf0e10cSrcweir tools::createPolygonFromRect( B2DRange(0.0,0.0,4000.0,4000.0) ));
2461f882ec4SArmin Le Grand aExport = tools::exportToSvgD( B2DPolyPolygon(aRect), false, false, false );
247cdf0e10cSrcweir
248cdf0e10cSrcweir const char* sExportStringRect = "M0 0H4000V4000H0Z";
249131e08e2SDamjan Jovanovic ASSERT_TRUE(!aExport.compareToAscii(sExportStringRect)) << "exporting to rectangle svg-d string";
250cdf0e10cSrcweir }
251cdf0e10cSrcweir
252131e08e2SDamjan Jovanovic class b2dpolyrange : public ::testing::Test
253cdf0e10cSrcweir {
254cdf0e10cSrcweir public:
SetUp()255131e08e2SDamjan Jovanovic virtual void SetUp()
256cdf0e10cSrcweir {}
257cdf0e10cSrcweir
TearDown()258131e08e2SDamjan Jovanovic virtual void TearDown()
259cdf0e10cSrcweir {}
260131e08e2SDamjan Jovanovic };
261cdf0e10cSrcweir
TEST_F(b2dpolyrange,check)262131e08e2SDamjan Jovanovic TEST_F(b2dpolyrange, check)
263cdf0e10cSrcweir {
264cdf0e10cSrcweir B2DPolyRange aRange;
265cdf0e10cSrcweir aRange.appendElement(B2DRange(0,0,1,1),ORIENTATION_POSITIVE);
266cdf0e10cSrcweir aRange.appendElement(B2DRange(2,2,3,3),ORIENTATION_POSITIVE);
267cdf0e10cSrcweir
268131e08e2SDamjan Jovanovic ASSERT_TRUE(aRange.count() == 2) << "simple poly range - count";
269131e08e2SDamjan Jovanovic ASSERT_TRUE(aRange.getElement(0).head == B2DRange(0,0,1,1)) << "simple poly range - first element";
270131e08e2SDamjan Jovanovic ASSERT_TRUE(aRange.getElement(1).head == B2DRange(2,2,3,3)) << "simple poly range - second element";
271cdf0e10cSrcweir
272cdf0e10cSrcweir // B2DPolyRange relies on correctly orientated rects
273cdf0e10cSrcweir const B2DRange aRect(0,0,1,1);
274131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::getOrientation(tools::createPolygonFromRect(aRect)) == ORIENTATION_POSITIVE ) <<
275131e08e2SDamjan Jovanovic "createPolygonFromRect - correct orientation";
276cdf0e10cSrcweir }
277cdf0e10cSrcweir
278cdf0e10cSrcweir
279131e08e2SDamjan Jovanovic class b2dbeziertools : public ::testing::Test
280cdf0e10cSrcweir {
281131e08e2SDamjan Jovanovic protected:
282cdf0e10cSrcweir B2DCubicBezier aHalfCircle; // not exactly, but a look-alike
283cdf0e10cSrcweir B2DCubicBezier aQuarterCircle; // not exactly, but a look-alike
284cdf0e10cSrcweir B2DCubicBezier aLoop; // identical endpoints, curve goes back to where it started
285cdf0e10cSrcweir B2DCubicBezier aStraightLineDistinctEndPoints; // truly a line
286cdf0e10cSrcweir B2DCubicBezier aStraightLineDistinctEndPoints2; // truly a line, with slightly different control points
287cdf0e10cSrcweir B2DCubicBezier aStraightLineIdenticalEndPoints; // degenerate case of aLoop
288cdf0e10cSrcweir B2DCubicBezier aStraightLineIdenticalEndPoints2;// degenerate case of aLoop, with slightly different control points
289cdf0e10cSrcweir B2DCubicBezier aCrossing; // curve self-intersects somewhere in the middle
290cdf0e10cSrcweir B2DCubicBezier aCusp; // curve has a point of undefined tangency
291cdf0e10cSrcweir
292cdf0e10cSrcweir
293cdf0e10cSrcweir public:
294cdf0e10cSrcweir // initialise your test code values here.
SetUp()295131e08e2SDamjan Jovanovic virtual void SetUp()
296cdf0e10cSrcweir {
297cdf0e10cSrcweir const B2DPoint a00(0.0, 0.0);
298cdf0e10cSrcweir const B2DPoint a10(1.0, 0.0);
299cdf0e10cSrcweir const B2DPoint a11(1.0, 1.0);
300cdf0e10cSrcweir const B2DPoint a01(0.0, 1.0);
301cdf0e10cSrcweir const B2DPoint middle( 0.5, 0.5 );
302cdf0e10cSrcweir const B2DPoint quarterDown( 0.25, 0.25 );
303cdf0e10cSrcweir const B2DPoint quarterUp( 0.75, 0.75 );
304cdf0e10cSrcweir
305cdf0e10cSrcweir aHalfCircle = B2DCubicBezier(a00, a01, a11, a10);
306cdf0e10cSrcweir
307cdf0e10cSrcweir // The spline control points become
308cdf0e10cSrcweir //
309cdf0e10cSrcweir // (R * cos(A), R * sin(A))
310cdf0e10cSrcweir // (R * cos(A) - h * sin(A), R * sin(A) + h * cos (A))
311cdf0e10cSrcweir // (R * cos(B) + h * sin(B), R * sin(B) - h * cos (B))
312cdf0e10cSrcweir // (R * cos(B), R * sin(B))
313cdf0e10cSrcweir //
314cdf0e10cSrcweir // where h = 4/3 * R * tan ((B-A)/4)
315cdf0e10cSrcweir //
316cdf0e10cSrcweir // with R being the radius, A start angle and B end angle (A < B).
317cdf0e10cSrcweir //
318cdf0e10cSrcweir // (This calculation courtesy Carl Worth, himself based on
319cdf0e10cSrcweir // Michael Goldapp and Dokken/Daehlen)
320cdf0e10cSrcweir
321cdf0e10cSrcweir // Choosing R=1, A=0, B=pi/2
322cdf0e10cSrcweir const double h( 4.0/3.0 * tan(M_PI/8.0) );
323cdf0e10cSrcweir aQuarterCircle = B2DCubicBezier(a10 + B2DPoint(1.0,0.0),
324cdf0e10cSrcweir B2DPoint(B2DPoint( 1.0, h ) + B2DPoint(1.0,0.0)),
325cdf0e10cSrcweir B2DPoint(B2DPoint( h, 1.0) + B2DPoint(1.0,0.0)),
326cdf0e10cSrcweir a01 + B2DPoint(1.0,0.0));
327cdf0e10cSrcweir
328cdf0e10cSrcweir aCusp = B2DCubicBezier(a00 + B2DPoint(2.0,0.0),
329cdf0e10cSrcweir B2DPoint(a11 + B2DPoint(2.0,0.0)),
330cdf0e10cSrcweir B2DPoint(a01 + B2DPoint(2.0,0.0)),
331cdf0e10cSrcweir a10 + B2DPoint(2.0,0.0));
332cdf0e10cSrcweir
333cdf0e10cSrcweir aLoop = B2DCubicBezier(a00 + B2DPoint(3.0,0.0),
334cdf0e10cSrcweir B2DPoint(a01 + B2DPoint(3.0,0.0)),
335cdf0e10cSrcweir B2DPoint(a10 + B2DPoint(3.0,0.0)),
336cdf0e10cSrcweir a00 + B2DPoint(3.0,0.0));
337cdf0e10cSrcweir
338cdf0e10cSrcweir aStraightLineDistinctEndPoints = B2DCubicBezier(a00 + B2DPoint(4.0,0.0),
339cdf0e10cSrcweir B2DPoint(middle + B2DPoint(4.0,0.0)),
340cdf0e10cSrcweir B2DPoint(middle + B2DPoint(4.0,0.0)),
341cdf0e10cSrcweir a11 + B2DPoint(4.0,0.0));
342cdf0e10cSrcweir
343cdf0e10cSrcweir aStraightLineDistinctEndPoints2 = B2DCubicBezier(a00 + B2DPoint(5.0,0.0),
344cdf0e10cSrcweir B2DPoint(quarterDown + B2DPoint(5.0,0.0)),
345cdf0e10cSrcweir B2DPoint(quarterUp + B2DPoint(5.0,0.0)),
346cdf0e10cSrcweir a11 + B2DPoint(5.0,0.0));
347cdf0e10cSrcweir
348cdf0e10cSrcweir aStraightLineIdenticalEndPoints = B2DCubicBezier(a00 + B2DPoint(6.0,0.0),
349cdf0e10cSrcweir B2DPoint(a11 + B2DPoint(6.0,0.0)),
350cdf0e10cSrcweir B2DPoint(a11 + B2DPoint(6.0,0.0)),
351cdf0e10cSrcweir a00 + B2DPoint(6.0,0.0));
352cdf0e10cSrcweir
353cdf0e10cSrcweir aStraightLineIdenticalEndPoints2 = B2DCubicBezier(a00 + B2DPoint(7.0,0.0),
354cdf0e10cSrcweir B2DPoint(quarterDown + B2DPoint(7.0,0.0)),
355cdf0e10cSrcweir B2DPoint(quarterUp + B2DPoint(7.0,0.0)),
356cdf0e10cSrcweir a00 + B2DPoint(7.0,0.0));
357cdf0e10cSrcweir
358cdf0e10cSrcweir aCrossing = B2DCubicBezier(a00 + B2DPoint(8.0,0.0),
359cdf0e10cSrcweir B2DPoint(B2DPoint(2.0,2.0) + B2DPoint(8.0,0.0)),
360cdf0e10cSrcweir B2DPoint(B2DPoint(-1.0,2.0) + B2DPoint(8.0,0.0)),
361cdf0e10cSrcweir a10 + B2DPoint(8.0,0.0));
362cdf0e10cSrcweir
363cdf0e10cSrcweir ::std::ofstream output("bez_testcases.gnuplot");
364cdf0e10cSrcweir DebugPlotter aPlotter( "Original curves",
365cdf0e10cSrcweir output );
366cdf0e10cSrcweir
367cdf0e10cSrcweir aPlotter.plot( aHalfCircle,
368cdf0e10cSrcweir "half circle" );
369cdf0e10cSrcweir aPlotter.plot( aQuarterCircle,
370cdf0e10cSrcweir "quarter circle" );
371cdf0e10cSrcweir aPlotter.plot( aCusp,
372cdf0e10cSrcweir "cusp" );
373cdf0e10cSrcweir aPlotter.plot( aLoop,
374cdf0e10cSrcweir "loop" );
375cdf0e10cSrcweir aPlotter.plot( aStraightLineDistinctEndPoints,
376cdf0e10cSrcweir "straight line 0" );
377cdf0e10cSrcweir aPlotter.plot( aStraightLineDistinctEndPoints2,
378cdf0e10cSrcweir "straight line 1" );
379cdf0e10cSrcweir aPlotter.plot( aStraightLineIdenticalEndPoints,
380cdf0e10cSrcweir "straight line 2" );
381cdf0e10cSrcweir aPlotter.plot( aStraightLineIdenticalEndPoints2,
382cdf0e10cSrcweir "straight line 3" );
383cdf0e10cSrcweir aPlotter.plot( aCrossing,
384cdf0e10cSrcweir "crossing" );
385cdf0e10cSrcweir
386cdf0e10cSrcweir // break up a complex bezier (loopy, spiky or self intersecting)
387cdf0e10cSrcweir // into simple segments (left to right)
388cdf0e10cSrcweir B2DCubicBezier aSegment = aCrossing;
389cdf0e10cSrcweir double fExtremePos(0.0);
390cdf0e10cSrcweir
391cdf0e10cSrcweir aPlotter.plot( aSegment, "segment" );
392cdf0e10cSrcweir while(aSegment.getMinimumExtremumPosition(fExtremePos))
393cdf0e10cSrcweir {
394cdf0e10cSrcweir aSegment.split(fExtremePos, 0, &aSegment);
395cdf0e10cSrcweir aPlotter.plot( aSegment, "segment" );
396cdf0e10cSrcweir }
397cdf0e10cSrcweir }
398cdf0e10cSrcweir
TearDown()399131e08e2SDamjan Jovanovic virtual void TearDown()
400cdf0e10cSrcweir {
401cdf0e10cSrcweir }
402131e08e2SDamjan Jovanovic }; // class b2dbeziertools
403cdf0e10cSrcweir
TEST_F(b2dbeziertools,adaptiveByDistance)404131e08e2SDamjan Jovanovic TEST_F(b2dbeziertools, adaptiveByDistance)
405cdf0e10cSrcweir {
406cdf0e10cSrcweir ::std::ofstream output("bez_adaptiveByDistance.gnuplot");
407cdf0e10cSrcweir DebugPlotter aPlotter( "distance-adaptive subdivision",
408cdf0e10cSrcweir output );
409cdf0e10cSrcweir
410cdf0e10cSrcweir const double fBound( 0.0001 );
411cdf0e10cSrcweir B2DPolygon result;
412cdf0e10cSrcweir
413cdf0e10cSrcweir aHalfCircle.adaptiveSubdivideByDistance(result, fBound);
414cdf0e10cSrcweir aPlotter.plot(result,
415cdf0e10cSrcweir "half circle"); result.clear();
416cdf0e10cSrcweir
417cdf0e10cSrcweir aQuarterCircle.adaptiveSubdivideByDistance(result, fBound);
418cdf0e10cSrcweir aPlotter.plot(result,
419cdf0e10cSrcweir "quarter circle"); result.clear();
420cdf0e10cSrcweir
421cdf0e10cSrcweir aLoop.adaptiveSubdivideByDistance(result, fBound);
422cdf0e10cSrcweir aPlotter.plot(result,
423cdf0e10cSrcweir "loop"); result.clear();
424cdf0e10cSrcweir
425cdf0e10cSrcweir aStraightLineDistinctEndPoints.adaptiveSubdivideByDistance(result, fBound);
426cdf0e10cSrcweir aPlotter.plot(result,
427cdf0e10cSrcweir "straight line 0"); result.clear();
428cdf0e10cSrcweir
429cdf0e10cSrcweir aStraightLineDistinctEndPoints2.adaptiveSubdivideByDistance(result, fBound);
430cdf0e10cSrcweir aPlotter.plot(result,
431cdf0e10cSrcweir "straight line 1"); result.clear();
432cdf0e10cSrcweir
433cdf0e10cSrcweir aStraightLineIdenticalEndPoints.adaptiveSubdivideByDistance(result, fBound);
434cdf0e10cSrcweir aPlotter.plot(result,
435cdf0e10cSrcweir "straight line 2"); result.clear();
436cdf0e10cSrcweir
437cdf0e10cSrcweir aStraightLineIdenticalEndPoints2.adaptiveSubdivideByDistance(result, fBound);
438cdf0e10cSrcweir aPlotter.plot(result,
439cdf0e10cSrcweir "straight line 3"); result.clear();
440cdf0e10cSrcweir
441cdf0e10cSrcweir aCrossing.adaptiveSubdivideByDistance(result, fBound);
442cdf0e10cSrcweir aPlotter.plot(result,
443cdf0e10cSrcweir "straight line 4"); result.clear();
444cdf0e10cSrcweir
445cdf0e10cSrcweir aCusp.adaptiveSubdivideByDistance(result, fBound);
446cdf0e10cSrcweir aPlotter.plot(result,
447cdf0e10cSrcweir "straight line 5"); result.clear();
448cdf0e10cSrcweir
449131e08e2SDamjan Jovanovic ASSERT_TRUE( true ) << "adaptiveByDistance";
450cdf0e10cSrcweir }
451cdf0e10cSrcweir
TEST_F(b2dbeziertools,adaptiveByAngle)452131e08e2SDamjan Jovanovic TEST_F(b2dbeziertools, adaptiveByAngle)
453cdf0e10cSrcweir {
454cdf0e10cSrcweir const double fBound( 5.0 );
455cdf0e10cSrcweir B2DPolygon result;
456cdf0e10cSrcweir
457cdf0e10cSrcweir ::std::ofstream output("bez_adaptiveByAngle.gnuplot");
458cdf0e10cSrcweir DebugPlotter aPlotter( "angle-adaptive subdivision",
459cdf0e10cSrcweir output );
460cdf0e10cSrcweir
461cdf0e10cSrcweir aHalfCircle.adaptiveSubdivideByAngle(result, fBound, true);
462cdf0e10cSrcweir aPlotter.plot(result,
463cdf0e10cSrcweir "half circle"); result.clear();
464cdf0e10cSrcweir
465cdf0e10cSrcweir aQuarterCircle.adaptiveSubdivideByAngle(result, fBound, true);
466cdf0e10cSrcweir aPlotter.plot(result,
467cdf0e10cSrcweir "quarter cirle"); result.clear();
468cdf0e10cSrcweir
469cdf0e10cSrcweir aLoop.adaptiveSubdivideByAngle(result, fBound, true);
470cdf0e10cSrcweir aPlotter.plot(result,
471cdf0e10cSrcweir "loop"); result.clear();
472cdf0e10cSrcweir
473cdf0e10cSrcweir aStraightLineDistinctEndPoints.adaptiveSubdivideByAngle(result, fBound, true);
474cdf0e10cSrcweir aPlotter.plot(result,
475cdf0e10cSrcweir "straight line 0"); result.clear();
476cdf0e10cSrcweir
477cdf0e10cSrcweir aStraightLineDistinctEndPoints2.adaptiveSubdivideByAngle(result, fBound, true);
478cdf0e10cSrcweir aPlotter.plot(result,
479cdf0e10cSrcweir "straight line 1"); result.clear();
480cdf0e10cSrcweir
481cdf0e10cSrcweir aStraightLineIdenticalEndPoints.adaptiveSubdivideByAngle(result, fBound, true);
482cdf0e10cSrcweir aPlotter.plot(result,
483cdf0e10cSrcweir "straight line 2"); result.clear();
484cdf0e10cSrcweir
485cdf0e10cSrcweir aStraightLineIdenticalEndPoints2.adaptiveSubdivideByAngle(result, fBound, true);
486cdf0e10cSrcweir aPlotter.plot(result,
487cdf0e10cSrcweir "straight line 3"); result.clear();
488cdf0e10cSrcweir
489cdf0e10cSrcweir aCrossing.adaptiveSubdivideByAngle(result, fBound, true);
490cdf0e10cSrcweir aPlotter.plot(result,
491cdf0e10cSrcweir "straight line 4"); result.clear();
492cdf0e10cSrcweir
493cdf0e10cSrcweir aCusp.adaptiveSubdivideByAngle(result, fBound, true);
494cdf0e10cSrcweir aPlotter.plot(result,
495cdf0e10cSrcweir "straight line 5"); result.clear();
496cdf0e10cSrcweir
497131e08e2SDamjan Jovanovic ASSERT_TRUE( true ) << "adaptiveByAngle";
498cdf0e10cSrcweir }
499cdf0e10cSrcweir
500cdf0e10cSrcweir
501131e08e2SDamjan Jovanovic class b2dcubicbezier : public ::testing::Test
502cdf0e10cSrcweir {
503cdf0e10cSrcweir public:
504cdf0e10cSrcweir // initialise your test code values here.
SetUp()505131e08e2SDamjan Jovanovic virtual void SetUp()
506cdf0e10cSrcweir {
507cdf0e10cSrcweir }
508cdf0e10cSrcweir
TearDown()509131e08e2SDamjan Jovanovic virtual void TearDown()
510cdf0e10cSrcweir {
511cdf0e10cSrcweir }
512cdf0e10cSrcweir }; // class b2dcubicbezier
513cdf0e10cSrcweir
514cdf0e10cSrcweir
515131e08e2SDamjan Jovanovic class b2dhommatrix : public ::testing::Test
516cdf0e10cSrcweir {
517131e08e2SDamjan Jovanovic protected:
518cdf0e10cSrcweir B2DHomMatrix maIdentity;
519cdf0e10cSrcweir B2DHomMatrix maScale;
520cdf0e10cSrcweir B2DHomMatrix maTranslate;
521cdf0e10cSrcweir B2DHomMatrix maShear;
522cdf0e10cSrcweir B2DHomMatrix maAffine;
523cdf0e10cSrcweir B2DHomMatrix maPerspective;
524cdf0e10cSrcweir
525cdf0e10cSrcweir public:
526cdf0e10cSrcweir // initialise your test code values here.
SetUp()527131e08e2SDamjan Jovanovic virtual void SetUp()
528cdf0e10cSrcweir {
529cdf0e10cSrcweir // setup some test matrices
530cdf0e10cSrcweir maIdentity.identity(); // force compact layout
531cdf0e10cSrcweir maIdentity.set(0,0, 1.0);
532cdf0e10cSrcweir maIdentity.set(0,1, 0.0);
533cdf0e10cSrcweir maIdentity.set(0,2, 0.0);
534cdf0e10cSrcweir maIdentity.set(1,0, 0.0);
535cdf0e10cSrcweir maIdentity.set(1,1, 1.0);
536cdf0e10cSrcweir maIdentity.set(1,2, 0.0);
537cdf0e10cSrcweir
538cdf0e10cSrcweir maScale.identity(); // force compact layout
539cdf0e10cSrcweir maScale.set(0,0, 2.0);
540cdf0e10cSrcweir maScale.set(1,1, 20.0);
541cdf0e10cSrcweir
542cdf0e10cSrcweir maTranslate.identity(); // force compact layout
543cdf0e10cSrcweir maTranslate.set(0,2, 20.0);
544cdf0e10cSrcweir maTranslate.set(1,2, 2.0);
545cdf0e10cSrcweir
546cdf0e10cSrcweir maShear.identity(); // force compact layout
547cdf0e10cSrcweir maShear.set(0,1, 3.0);
548cdf0e10cSrcweir maShear.set(1,0, 7.0);
549cdf0e10cSrcweir maShear.set(1,1, 22.0);
550cdf0e10cSrcweir
551cdf0e10cSrcweir maAffine.identity(); // force compact layout
552cdf0e10cSrcweir maAffine.set(0,0, 1.0);
553cdf0e10cSrcweir maAffine.set(0,1, 2.0);
554cdf0e10cSrcweir maAffine.set(0,2, 3.0);
555cdf0e10cSrcweir maAffine.set(1,0, 4.0);
556cdf0e10cSrcweir maAffine.set(1,1, 5.0);
557cdf0e10cSrcweir maAffine.set(1,2, 6.0);
558cdf0e10cSrcweir
559cdf0e10cSrcweir maPerspective.set(0,0, 1.0);
560cdf0e10cSrcweir maPerspective.set(0,1, 2.0);
561cdf0e10cSrcweir maPerspective.set(0,2, 3.0);
562cdf0e10cSrcweir maPerspective.set(1,0, 4.0);
563cdf0e10cSrcweir maPerspective.set(1,1, 5.0);
564cdf0e10cSrcweir maPerspective.set(1,2, 6.0);
565cdf0e10cSrcweir maPerspective.set(2,0, 7.0);
566cdf0e10cSrcweir maPerspective.set(2,1, 8.0);
567cdf0e10cSrcweir maPerspective.set(2,2, 9.0);
568cdf0e10cSrcweir }
569cdf0e10cSrcweir
TearDown()570131e08e2SDamjan Jovanovic virtual void TearDown()
571cdf0e10cSrcweir {
572cdf0e10cSrcweir }
573cdf0e10cSrcweir
impFillMatrix(B2DHomMatrix & rSource,double fScaleX,double fScaleY,double fShearX,double fRotate)574131e08e2SDamjan Jovanovic void impFillMatrix(B2DHomMatrix& rSource, double fScaleX, double fScaleY, double fShearX, double fRotate)
575131e08e2SDamjan Jovanovic {
576131e08e2SDamjan Jovanovic // fill rSource with a linear combination of scale, shear and rotate
577131e08e2SDamjan Jovanovic rSource.identity();
578131e08e2SDamjan Jovanovic rSource.scale(fScaleX, fScaleY);
579131e08e2SDamjan Jovanovic rSource.shearX(fShearX);
580131e08e2SDamjan Jovanovic rSource.rotate(fRotate);
581131e08e2SDamjan Jovanovic }
582131e08e2SDamjan Jovanovic
impDecomposeComposeTest(double fScaleX,double fScaleY,double fShearX,double fRotate)583131e08e2SDamjan Jovanovic bool impDecomposeComposeTest(double fScaleX, double fScaleY, double fShearX, double fRotate)
584131e08e2SDamjan Jovanovic {
585131e08e2SDamjan Jovanovic // linear combine matrix with given values
586131e08e2SDamjan Jovanovic B2DHomMatrix aSource;
587131e08e2SDamjan Jovanovic impFillMatrix(aSource, fScaleX, fScaleY, fShearX, fRotate);
588131e08e2SDamjan Jovanovic
589131e08e2SDamjan Jovanovic // decompose that matrix
590131e08e2SDamjan Jovanovic B2DTuple aDScale;
591131e08e2SDamjan Jovanovic B2DTuple aDTrans;
592131e08e2SDamjan Jovanovic double fDRot;
593131e08e2SDamjan Jovanovic double fDShX;
594131e08e2SDamjan Jovanovic bool bWorked = aSource.decompose(aDScale, aDTrans, fDRot, fDShX);
595131e08e2SDamjan Jovanovic
596131e08e2SDamjan Jovanovic // linear combine another matrix with decomposition results
597131e08e2SDamjan Jovanovic B2DHomMatrix aRecombined;
598131e08e2SDamjan Jovanovic impFillMatrix(aRecombined, aDScale.getX(), aDScale.getY(), fDShX, fDRot);
599131e08e2SDamjan Jovanovic
600131e08e2SDamjan Jovanovic // if decomposition worked, matrices need to be the same
601131e08e2SDamjan Jovanovic return bWorked && aSource == aRecombined;
602131e08e2SDamjan Jovanovic }
603131e08e2SDamjan Jovanovic }; // class b2dhommatrix
604131e08e2SDamjan Jovanovic
605131e08e2SDamjan Jovanovic
TEST_F(b2dhommatrix,equal)606131e08e2SDamjan Jovanovic TEST_F(b2dhommatrix, equal)
607cdf0e10cSrcweir {
608cdf0e10cSrcweir B2DHomMatrix aIdentity;
609cdf0e10cSrcweir B2DHomMatrix aScale;
610cdf0e10cSrcweir B2DHomMatrix aTranslate;
611cdf0e10cSrcweir B2DHomMatrix aShear;
612cdf0e10cSrcweir B2DHomMatrix aAffine;
613cdf0e10cSrcweir B2DHomMatrix aPerspective;
614cdf0e10cSrcweir
615cdf0e10cSrcweir // setup some test matrices
616cdf0e10cSrcweir aIdentity.identity(); // force compact layout
617cdf0e10cSrcweir aIdentity.set(0,0, 1.0);
618cdf0e10cSrcweir aIdentity.set(0,1, 0.0);
619cdf0e10cSrcweir aIdentity.set(0,2, 0.0);
620cdf0e10cSrcweir aIdentity.set(1,0, 0.0);
621cdf0e10cSrcweir aIdentity.set(1,1, 1.0);
622cdf0e10cSrcweir aIdentity.set(1,2, 0.0);
623cdf0e10cSrcweir
624cdf0e10cSrcweir aScale.identity(); // force compact layout
625cdf0e10cSrcweir aScale.set(0,0, 2.0);
626cdf0e10cSrcweir aScale.set(1,1, 20.0);
627cdf0e10cSrcweir
628cdf0e10cSrcweir aTranslate.identity(); // force compact layout
629cdf0e10cSrcweir aTranslate.set(0,2, 20.0);
630cdf0e10cSrcweir aTranslate.set(1,2, 2.0);
631cdf0e10cSrcweir
632cdf0e10cSrcweir aShear.identity(); // force compact layout
633cdf0e10cSrcweir aShear.set(0,1, 3.0);
634cdf0e10cSrcweir aShear.set(1,0, 7.0);
635cdf0e10cSrcweir aShear.set(1,1, 22.0);
636cdf0e10cSrcweir
637cdf0e10cSrcweir aAffine.identity(); // force compact layout
638cdf0e10cSrcweir aAffine.set(0,0, 1.0);
639cdf0e10cSrcweir aAffine.set(0,1, 2.0);
640cdf0e10cSrcweir aAffine.set(0,2, 3.0);
641cdf0e10cSrcweir aAffine.set(1,0, 4.0);
642cdf0e10cSrcweir aAffine.set(1,1, 5.0);
643cdf0e10cSrcweir aAffine.set(1,2, 6.0);
644cdf0e10cSrcweir
645cdf0e10cSrcweir aPerspective.set(0,0, 1.0);
646cdf0e10cSrcweir aPerspective.set(0,1, 2.0);
647cdf0e10cSrcweir aPerspective.set(0,2, 3.0);
648cdf0e10cSrcweir aPerspective.set(1,0, 4.0);
649cdf0e10cSrcweir aPerspective.set(1,1, 5.0);
650cdf0e10cSrcweir aPerspective.set(1,2, 6.0);
651cdf0e10cSrcweir aPerspective.set(2,0, 7.0);
652cdf0e10cSrcweir aPerspective.set(2,1, 8.0);
653cdf0e10cSrcweir aPerspective.set(2,2, 9.0);
654cdf0e10cSrcweir
655131e08e2SDamjan Jovanovic ASSERT_TRUE(aIdentity == maIdentity) << "operator==: identity matrix";
656131e08e2SDamjan Jovanovic ASSERT_TRUE(aScale == maScale) << "operator==: scale matrix";
657131e08e2SDamjan Jovanovic ASSERT_TRUE(aTranslate == maTranslate) << "operator==: translate matrix";
658131e08e2SDamjan Jovanovic ASSERT_TRUE(aShear == maShear) << "operator==: shear matrix";
659131e08e2SDamjan Jovanovic ASSERT_TRUE(aAffine == maAffine) << "operator==: affine matrix";
660131e08e2SDamjan Jovanovic ASSERT_TRUE(aPerspective == maPerspective) << "operator==: perspective matrix";
661cdf0e10cSrcweir }
662cdf0e10cSrcweir
TEST_F(b2dhommatrix,identity)663131e08e2SDamjan Jovanovic TEST_F(b2dhommatrix, identity)
664cdf0e10cSrcweir {
665cdf0e10cSrcweir B2DHomMatrix ident;
666cdf0e10cSrcweir
667131e08e2SDamjan Jovanovic ASSERT_TRUE(maIdentity == ident) << "identity";
668cdf0e10cSrcweir }
669cdf0e10cSrcweir
TEST_F(b2dhommatrix,scale)670131e08e2SDamjan Jovanovic TEST_F(b2dhommatrix, scale)
671cdf0e10cSrcweir {
672cdf0e10cSrcweir B2DHomMatrix mat;
673cdf0e10cSrcweir mat.scale(2.0,20.0);
674131e08e2SDamjan Jovanovic ASSERT_TRUE(maScale == mat) << "scale";
675cdf0e10cSrcweir }
676cdf0e10cSrcweir
TEST_F(b2dhommatrix,translate)677131e08e2SDamjan Jovanovic TEST_F(b2dhommatrix, translate)
678cdf0e10cSrcweir {
679cdf0e10cSrcweir B2DHomMatrix mat;
680cdf0e10cSrcweir mat.translate(20.0,2.0);
681131e08e2SDamjan Jovanovic ASSERT_TRUE(maTranslate == mat) << "translate";
682cdf0e10cSrcweir }
683cdf0e10cSrcweir
TEST_F(b2dhommatrix,shear)684131e08e2SDamjan Jovanovic TEST_F(b2dhommatrix, shear)
685cdf0e10cSrcweir {
686cdf0e10cSrcweir B2DHomMatrix mat;
687cdf0e10cSrcweir mat.shearX(3.0);
688cdf0e10cSrcweir mat.shearY(7.0);
689131e08e2SDamjan Jovanovic ASSERT_TRUE(maShear == mat) << "translate";
690cdf0e10cSrcweir }
691cdf0e10cSrcweir
TEST_F(b2dhommatrix,multiply)692131e08e2SDamjan Jovanovic TEST_F(b2dhommatrix, multiply)
693cdf0e10cSrcweir {
694cdf0e10cSrcweir B2DHomMatrix affineAffineProd;
695cdf0e10cSrcweir
696cdf0e10cSrcweir affineAffineProd.set(0,0, 9);
697cdf0e10cSrcweir affineAffineProd.set(0,1, 12);
698cdf0e10cSrcweir affineAffineProd.set(0,2, 18);
699cdf0e10cSrcweir affineAffineProd.set(1,0, 24);
700cdf0e10cSrcweir affineAffineProd.set(1,1, 33);
701cdf0e10cSrcweir affineAffineProd.set(1,2, 48);
702cdf0e10cSrcweir
703cdf0e10cSrcweir B2DHomMatrix affinePerspectiveProd;
704cdf0e10cSrcweir
705cdf0e10cSrcweir affinePerspectiveProd.set(0,0, 30);
706cdf0e10cSrcweir affinePerspectiveProd.set(0,1, 36);
707cdf0e10cSrcweir affinePerspectiveProd.set(0,2, 42);
708cdf0e10cSrcweir affinePerspectiveProd.set(1,0, 66);
709cdf0e10cSrcweir affinePerspectiveProd.set(1,1, 81);
710cdf0e10cSrcweir affinePerspectiveProd.set(1,2, 96);
711cdf0e10cSrcweir affinePerspectiveProd.set(2,0, 7);
712cdf0e10cSrcweir affinePerspectiveProd.set(2,1, 8);
713cdf0e10cSrcweir affinePerspectiveProd.set(2,2, 9);
714cdf0e10cSrcweir
715cdf0e10cSrcweir B2DHomMatrix perspectiveAffineProd;
716cdf0e10cSrcweir
717cdf0e10cSrcweir perspectiveAffineProd.set(0,0, 9);
718cdf0e10cSrcweir perspectiveAffineProd.set(0,1, 12);
719cdf0e10cSrcweir perspectiveAffineProd.set(0,2, 18);
720cdf0e10cSrcweir perspectiveAffineProd.set(1,0, 24);
721cdf0e10cSrcweir perspectiveAffineProd.set(1,1, 33);
722cdf0e10cSrcweir perspectiveAffineProd.set(1,2, 48);
723cdf0e10cSrcweir perspectiveAffineProd.set(2,0, 39);
724cdf0e10cSrcweir perspectiveAffineProd.set(2,1, 54);
725cdf0e10cSrcweir perspectiveAffineProd.set(2,2, 78);
726cdf0e10cSrcweir
727cdf0e10cSrcweir B2DHomMatrix perspectivePerspectiveProd;
728cdf0e10cSrcweir
729cdf0e10cSrcweir perspectivePerspectiveProd.set(0,0, 30);
730cdf0e10cSrcweir perspectivePerspectiveProd.set(0,1, 36);
731cdf0e10cSrcweir perspectivePerspectiveProd.set(0,2, 42);
732cdf0e10cSrcweir perspectivePerspectiveProd.set(1,0, 66);
733cdf0e10cSrcweir perspectivePerspectiveProd.set(1,1, 81);
734cdf0e10cSrcweir perspectivePerspectiveProd.set(1,2, 96);
735cdf0e10cSrcweir perspectivePerspectiveProd.set(2,0, 102);
736cdf0e10cSrcweir perspectivePerspectiveProd.set(2,1, 126);
737cdf0e10cSrcweir perspectivePerspectiveProd.set(2,2, 150);
738cdf0e10cSrcweir
739cdf0e10cSrcweir B2DHomMatrix temp;
740cdf0e10cSrcweir
741cdf0e10cSrcweir temp = maAffine;
742cdf0e10cSrcweir temp*=maAffine;
743131e08e2SDamjan Jovanovic ASSERT_TRUE(temp == affineAffineProd) << "multiply: both compact";
744cdf0e10cSrcweir
745cdf0e10cSrcweir temp = maPerspective;
746cdf0e10cSrcweir temp*=maAffine;
747131e08e2SDamjan Jovanovic ASSERT_TRUE(temp == affinePerspectiveProd) << "multiply: first compact";
748cdf0e10cSrcweir
749cdf0e10cSrcweir temp = maAffine;
750cdf0e10cSrcweir temp*=maPerspective;
751131e08e2SDamjan Jovanovic ASSERT_TRUE(temp == perspectiveAffineProd) << "multiply: second compact";
752cdf0e10cSrcweir
753cdf0e10cSrcweir temp = maPerspective;
754cdf0e10cSrcweir temp*=maPerspective;
755131e08e2SDamjan Jovanovic ASSERT_TRUE(temp == perspectivePerspectiveProd) << "multiply: none compact";
756cdf0e10cSrcweir }
757cdf0e10cSrcweir
758cdf0e10cSrcweir
TEST_F(b2dhommatrix,decompose)759131e08e2SDamjan Jovanovic TEST_F(b2dhommatrix, decompose)
760cdf0e10cSrcweir {
761cdf0e10cSrcweir // test matrix decompositions. Each matrix decomposed and rebuilt
762cdf0e10cSrcweir // using the decompose result should be the same as before. Test
763cdf0e10cSrcweir // with all ranges of values. Translations are not tested since these
764cdf0e10cSrcweir // are just the two rightmost values and uncritical
765cdf0e10cSrcweir static double fSX(10.0);
766cdf0e10cSrcweir static double fSY(12.0);
767cdf0e10cSrcweir static double fR(45.0 * F_PI180);
768cdf0e10cSrcweir static double fS(15.0 * F_PI180);
769cdf0e10cSrcweir
770cdf0e10cSrcweir // check all possible scaling combinations
771131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, fSY, 0.0, 0.0)) << "decompose: error test A1";
772131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, fSY, 0.0, 0.0)) << "decompose: error test A2";
773131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, -fSY, 0.0, 0.0)) << "decompose: error test A3";
774131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, -fSY, 0.0, 0.0)) << "decompose: error test A4";
775cdf0e10cSrcweir
776cdf0e10cSrcweir // check all possible scaling combinations with positive rotation
777131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, fSY, 0.0, fR)) << "decompose: error test B1";
778131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, fSY, 0.0, fR)) << "decompose: error test B2";
779131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, -fSY, 0.0, fR)) << "decompose: error test B3";
780131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, -fSY, 0.0, fR)) << "decompose: error test B4";
781cdf0e10cSrcweir
782cdf0e10cSrcweir // check all possible scaling combinations with negative rotation
783131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, fSY, 0.0, -fR)) << "decompose: error test C1";
784131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, fSY, 0.0, -fR)) << "decompose: error test C2";
785131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, -fSY, 0.0, -fR)) << "decompose: error test C3";
786131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, -fSY, 0.0, -fR)) << "decompose: error test C4";
787cdf0e10cSrcweir
788cdf0e10cSrcweir // check all possible scaling combinations with positive shear
789131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, fSY, tan(fS), 0.0)) << "decompose: error test D1";
790131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, fSY, tan(fS), 0.0)) << "decompose: error test D2";
791131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, -fSY, tan(fS), 0.0)) << "decompose: error test D3";
792131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, -fSY, tan(fS), 0.0)) << "decompose: error test D4";
793cdf0e10cSrcweir
794cdf0e10cSrcweir // check all possible scaling combinations with negative shear
795131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, fSY, tan(-fS), 0.0)) << "decompose: error test E1";
796131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, fSY, tan(-fS), 0.0)) << "decompose: error test E2";
797131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, -fSY, tan(-fS), 0.0)) << "decompose: error test E3";
798131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, -fSY, tan(-fS), 0.0)) << "decompose: error test E4";
799cdf0e10cSrcweir
800cdf0e10cSrcweir // check all possible scaling combinations with positive rotate and positive shear
801131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, fSY, tan(fS), fR)) << "decompose: error test F1";
802131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, fSY, tan(fS), fR)) << "decompose: error test F2";
803131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, -fSY, tan(fS), fR)) << "decompose: error test F3";
804131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, -fSY, tan(fS), fR)) << "decompose: error test F4";
805cdf0e10cSrcweir
806cdf0e10cSrcweir // check all possible scaling combinations with negative rotate and positive shear
807131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, fSY, tan(fS), -fR)) << "decompose: error test G1";
808131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, fSY, tan(fS), -fR)) << "decompose: error test G2";
809131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, -fSY, tan(fS), -fR)) << "decompose: error test G3";
810131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, -fSY, tan(fS), -fR)) << "decompose: error test G4";
811cdf0e10cSrcweir
812cdf0e10cSrcweir // check all possible scaling combinations with positive rotate and negative shear
813131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, fSY, tan(-fS), fR)) << "decompose: error test H1";
814131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, fSY, tan(-fS), fR)) << "decompose: error test H2";
815131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, -fSY, tan(-fS), fR)) << "decompose: error test H3";
816131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, -fSY, tan(-fS), fR)) << "decompose: error test H4";
817cdf0e10cSrcweir
818cdf0e10cSrcweir // check all possible scaling combinations with negative rotate and negative shear
819131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, fSY, tan(-fS), -fR)) << "decompose: error test I1";
820131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, fSY, tan(-fS), -fR)) << "decompose: error test I2";
821131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(fSX, -fSY, tan(-fS), -fR)) << "decompose: error test I3";
822131e08e2SDamjan Jovanovic ASSERT_TRUE(impDecomposeComposeTest(-fSX, -fSY, tan(-fS), -fR)) << "decompose: error test I4";
823cdf0e10cSrcweir }
824cdf0e10cSrcweir
825cdf0e10cSrcweir
826131e08e2SDamjan Jovanovic class b2dhompoint : public ::testing::Test
827cdf0e10cSrcweir {
828cdf0e10cSrcweir public:
829cdf0e10cSrcweir // initialise your test code values here.
SetUp()830131e08e2SDamjan Jovanovic virtual void SetUp()
831cdf0e10cSrcweir {
832cdf0e10cSrcweir }
833cdf0e10cSrcweir
TearDown()834131e08e2SDamjan Jovanovic virtual void TearDown()
835cdf0e10cSrcweir {
836cdf0e10cSrcweir }
837cdf0e10cSrcweir }; // class b2dhompoint
838cdf0e10cSrcweir
839cdf0e10cSrcweir
840131e08e2SDamjan Jovanovic class b2dpoint : public ::testing::Test
841cdf0e10cSrcweir {
842cdf0e10cSrcweir public:
843cdf0e10cSrcweir // initialise your test code values here.
SetUp()844131e08e2SDamjan Jovanovic virtual void SetUp()
845cdf0e10cSrcweir {
846cdf0e10cSrcweir }
847cdf0e10cSrcweir
TearDown()848131e08e2SDamjan Jovanovic virtual void TearDown()
849cdf0e10cSrcweir {
850cdf0e10cSrcweir }
851cdf0e10cSrcweir }; // class b2dpoint
852cdf0e10cSrcweir
853cdf0e10cSrcweir
854131e08e2SDamjan Jovanovic class b2dpolygon : public ::testing::Test
855cdf0e10cSrcweir {
856cdf0e10cSrcweir public:
857cdf0e10cSrcweir // initialise your test code values here.
SetUp()858131e08e2SDamjan Jovanovic virtual void SetUp()
859cdf0e10cSrcweir {
860cdf0e10cSrcweir }
861cdf0e10cSrcweir
TearDown()862131e08e2SDamjan Jovanovic virtual void TearDown()
863cdf0e10cSrcweir {
864cdf0e10cSrcweir }
865131e08e2SDamjan Jovanovic }; // class b2dpolygon
866cdf0e10cSrcweir
TEST_F(b2dpolygon,testBasics)867131e08e2SDamjan Jovanovic TEST_F(b2dpolygon, testBasics)
868cdf0e10cSrcweir {
869cdf0e10cSrcweir B2DPolygon aPoly;
870cdf0e10cSrcweir
871cdf0e10cSrcweir aPoly.appendBezierSegment(B2DPoint(1,1),B2DPoint(2,2),B2DPoint(3,3));
872cdf0e10cSrcweir
873131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getB2DPoint(0) == B2DPoint(3,3)) << "#1 first polygon point wrong";
874131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getPrevControlPoint(0) == B2DPoint(2,2)) << "#1 first control point wrong";
875131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getNextControlPoint(0) == B2DPoint(3,3)) << "#1 second control point wrong";
876131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.isNextControlPointUsed(0) == false) << "next control point not used";
877cdf0e10cSrcweir
878cdf0e10cSrcweir aPoly.setNextControlPoint(0,B2DPoint(4,4));
879131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getNextControlPoint(0) == B2DPoint(4,4)) << "#1.1 second control point wrong";
880131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.isNextControlPointUsed(0) == true) << "next control point used";
881131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.areControlPointsUsed() == true) << "areControlPointsUsed() wrong";
882131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getContinuityInPoint(0) == CONTINUITY_C2) << "getContinuityInPoint() wrong";
883cdf0e10cSrcweir
884cdf0e10cSrcweir aPoly.resetControlPoints();
885131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getB2DPoint(0) == B2DPoint(3,3)) << "resetControlPoints() did not clear";
886131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getPrevControlPoint(0) == B2DPoint(3,3)) << "resetControlPoints() did not clear";
887131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getNextControlPoint(0) == B2DPoint(3,3)) << "resetControlPoints() did not clear";
888131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.areControlPointsUsed() == false) << "areControlPointsUsed() wrong #2";
889cdf0e10cSrcweir
890cdf0e10cSrcweir aPoly.clear();
891cdf0e10cSrcweir aPoly.append(B2DPoint(0,0));
892cdf0e10cSrcweir aPoly.appendBezierSegment(B2DPoint(1,1),B2DPoint(2,2),B2DPoint(3,3));
893cdf0e10cSrcweir
894131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getB2DPoint(0) == B2DPoint(0,0)) << "#2 first polygon point wrong";
895131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getPrevControlPoint(0) == B2DPoint(0,0)) << "#2 first control point wrong";
896131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getNextControlPoint(0) == B2DPoint(1,1)) << "#2 second control point wrong";
897131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getPrevControlPoint(1) == B2DPoint(2,2)) << "#2 third control point wrong";
898131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getNextControlPoint(1) == B2DPoint(3,3)) << "#2 fourth control point wrong";
899131e08e2SDamjan Jovanovic ASSERT_TRUE(aPoly.getB2DPoint(1) == B2DPoint(3,3)) << "#2 second polygon point wrong";
900cdf0e10cSrcweir }
901cdf0e10cSrcweir
902131e08e2SDamjan Jovanovic class b2dpolygontools : public ::testing::Test
903cdf0e10cSrcweir {
904cdf0e10cSrcweir public:
905cdf0e10cSrcweir // initialise your test code values here.
SetUp()906131e08e2SDamjan Jovanovic virtual void SetUp()
907cdf0e10cSrcweir {
908cdf0e10cSrcweir }
909cdf0e10cSrcweir
TearDown()910131e08e2SDamjan Jovanovic virtual void TearDown()
911cdf0e10cSrcweir {
912cdf0e10cSrcweir }
913131e08e2SDamjan Jovanovic }; // class b2dpolygontools
914cdf0e10cSrcweir
TEST_F(b2dpolygontools,testIsRectangle)915131e08e2SDamjan Jovanovic TEST_F(b2dpolygontools, testIsRectangle)
916cdf0e10cSrcweir {
917cdf0e10cSrcweir B2DPolygon aRect1(
918cdf0e10cSrcweir tools::createPolygonFromRect(
919cdf0e10cSrcweir B2DRange(0,0,1,1) ) );
920cdf0e10cSrcweir
921cdf0e10cSrcweir B2DPolygon aRect2;
922cdf0e10cSrcweir aRect2.append( B2DPoint(0,0) );
923cdf0e10cSrcweir aRect2.append( B2DPoint(1,0) );
924cdf0e10cSrcweir aRect2.append( B2DPoint(1,.5));
925cdf0e10cSrcweir aRect2.append( B2DPoint(1,1) );
926cdf0e10cSrcweir aRect2.append( B2DPoint(0,1) );
927cdf0e10cSrcweir aRect2.setClosed(true);
928cdf0e10cSrcweir
929cdf0e10cSrcweir B2DPolygon aNonRect1;
930cdf0e10cSrcweir aNonRect1.append( B2DPoint(0,0) );
931cdf0e10cSrcweir aNonRect1.append( B2DPoint(1,0) );
932cdf0e10cSrcweir aNonRect1.append( B2DPoint(1,1) );
933cdf0e10cSrcweir aNonRect1.append( B2DPoint(0.5,1) );
934cdf0e10cSrcweir aNonRect1.append( B2DPoint(0.5,0) );
935cdf0e10cSrcweir aNonRect1.setClosed(true);
936cdf0e10cSrcweir
937cdf0e10cSrcweir B2DPolygon aNonRect2;
938cdf0e10cSrcweir aNonRect2.append( B2DPoint(0,0) );
939cdf0e10cSrcweir aNonRect2.append( B2DPoint(1,1) );
940cdf0e10cSrcweir aNonRect2.append( B2DPoint(1,0) );
941cdf0e10cSrcweir aNonRect2.append( B2DPoint(0,1) );
942cdf0e10cSrcweir aNonRect2.setClosed(true);
943cdf0e10cSrcweir
944cdf0e10cSrcweir B2DPolygon aNonRect3;
945cdf0e10cSrcweir aNonRect3.append( B2DPoint(0,0) );
946cdf0e10cSrcweir aNonRect3.append( B2DPoint(1,0) );
947cdf0e10cSrcweir aNonRect3.append( B2DPoint(1,1) );
948cdf0e10cSrcweir aNonRect3.setClosed(true);
949cdf0e10cSrcweir
950cdf0e10cSrcweir B2DPolygon aNonRect4;
951cdf0e10cSrcweir aNonRect4.append( B2DPoint(0,0) );
952cdf0e10cSrcweir aNonRect4.append( B2DPoint(1,0) );
953cdf0e10cSrcweir aNonRect4.append( B2DPoint(1,1) );
954cdf0e10cSrcweir aNonRect4.append( B2DPoint(0,1) );
955cdf0e10cSrcweir
956cdf0e10cSrcweir B2DPolygon aNonRect5;
957cdf0e10cSrcweir aNonRect5.append( B2DPoint(0,0) );
958cdf0e10cSrcweir aNonRect5.append( B2DPoint(1,0) );
959cdf0e10cSrcweir aNonRect5.append( B2DPoint(1,1) );
960cdf0e10cSrcweir aNonRect5.append( B2DPoint(0,1) );
961cdf0e10cSrcweir aNonRect5.setControlPoints(1,B2DPoint(1,0),B2DPoint(-11,0));
962cdf0e10cSrcweir aNonRect5.setClosed(true);
963cdf0e10cSrcweir
964131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::isRectangle( aRect1 )) << "checking rectangle-ness of rectangle 1";
965131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::isRectangle( aRect2 )) << "checking rectangle-ness of rectangle 2";
966131e08e2SDamjan Jovanovic ASSERT_TRUE(!tools::isRectangle( aNonRect1 )) << "checking non-rectangle-ness of polygon 1";
967131e08e2SDamjan Jovanovic ASSERT_TRUE(!tools::isRectangle( aNonRect2 )) << "checking non-rectangle-ness of polygon 2";
968131e08e2SDamjan Jovanovic ASSERT_TRUE(!tools::isRectangle( aNonRect3 )) << "checking non-rectangle-ness of polygon 3";
969131e08e2SDamjan Jovanovic ASSERT_TRUE(!tools::isRectangle( aNonRect4 )) << "checking non-rectangle-ness of polygon 4";
970131e08e2SDamjan Jovanovic ASSERT_TRUE(!tools::isRectangle( aNonRect5 )) << "checking non-rectangle-ness of polygon 5";
971cdf0e10cSrcweir }
972cdf0e10cSrcweir
973131e08e2SDamjan Jovanovic class b2dpolypolygon : public ::testing::Test
974cdf0e10cSrcweir {
975cdf0e10cSrcweir public:
976cdf0e10cSrcweir // initialise your test code values here.
SetUp()977131e08e2SDamjan Jovanovic virtual void SetUp()
978cdf0e10cSrcweir {
979cdf0e10cSrcweir }
980cdf0e10cSrcweir
TearDown()981131e08e2SDamjan Jovanovic virtual void TearDown()
982cdf0e10cSrcweir {
983cdf0e10cSrcweir }
984cdf0e10cSrcweir }; // class b2dpolypolygon
985cdf0e10cSrcweir
986cdf0e10cSrcweir
987131e08e2SDamjan Jovanovic class b2dquadraticbezier : public ::testing::Test
988cdf0e10cSrcweir {
989cdf0e10cSrcweir public:
990cdf0e10cSrcweir // initialise your test code values here.
SetUp()991131e08e2SDamjan Jovanovic virtual void SetUp()
992cdf0e10cSrcweir {
993cdf0e10cSrcweir }
994cdf0e10cSrcweir
TearDown()995131e08e2SDamjan Jovanovic virtual void TearDown()
996cdf0e10cSrcweir {
997cdf0e10cSrcweir }
998cdf0e10cSrcweir }; // class b2dquadraticbezier
999cdf0e10cSrcweir
1000cdf0e10cSrcweir
1001131e08e2SDamjan Jovanovic class b2drange : public ::testing::Test
1002cdf0e10cSrcweir {
1003cdf0e10cSrcweir public:
1004cdf0e10cSrcweir // initialise your test code values here.
SetUp()1005131e08e2SDamjan Jovanovic virtual void SetUp()
1006cdf0e10cSrcweir {
1007cdf0e10cSrcweir }
1008cdf0e10cSrcweir
TearDown()1009131e08e2SDamjan Jovanovic virtual void TearDown()
1010cdf0e10cSrcweir {
1011cdf0e10cSrcweir }
1012cdf0e10cSrcweir }; // class b2drange
1013cdf0e10cSrcweir
1014cdf0e10cSrcweir
1015131e08e2SDamjan Jovanovic class b2dtuple : public ::testing::Test
1016cdf0e10cSrcweir {
1017cdf0e10cSrcweir public:
1018cdf0e10cSrcweir // initialise your test code values here.
SetUp()1019131e08e2SDamjan Jovanovic virtual void SetUp()
1020cdf0e10cSrcweir {
1021cdf0e10cSrcweir }
1022cdf0e10cSrcweir
TearDown()1023131e08e2SDamjan Jovanovic virtual void TearDown()
1024cdf0e10cSrcweir {
1025cdf0e10cSrcweir }
1026cdf0e10cSrcweir }; // class b2dtuple
1027cdf0e10cSrcweir
1028cdf0e10cSrcweir
1029131e08e2SDamjan Jovanovic class b2dvector : public ::testing::Test
1030cdf0e10cSrcweir {
1031cdf0e10cSrcweir public:
1032cdf0e10cSrcweir // initialise your test code values here.
SetUp()1033131e08e2SDamjan Jovanovic virtual void SetUp()
1034cdf0e10cSrcweir {
1035cdf0e10cSrcweir }
1036cdf0e10cSrcweir
TearDown()1037131e08e2SDamjan Jovanovic virtual void TearDown()
1038cdf0e10cSrcweir {
1039cdf0e10cSrcweir }
1040cdf0e10cSrcweir }; // class b2dvector
1041cdf0e10cSrcweir
1042131e08e2SDamjan Jovanovic class bcolor : public ::testing::Test
1043cdf0e10cSrcweir {
1044131e08e2SDamjan Jovanovic protected:
1045cdf0e10cSrcweir BColor maWhite;
1046cdf0e10cSrcweir BColor maBlack;
1047cdf0e10cSrcweir BColor maRed;
1048cdf0e10cSrcweir BColor maGreen;
1049cdf0e10cSrcweir BColor maBlue;
1050cdf0e10cSrcweir BColor maYellow;
1051cdf0e10cSrcweir BColor maMagenta;
1052cdf0e10cSrcweir BColor maCyan;
1053cdf0e10cSrcweir
1054cdf0e10cSrcweir public:
bcolor()1055cdf0e10cSrcweir bcolor() :
1056cdf0e10cSrcweir maWhite(1,1,1),
1057cdf0e10cSrcweir maBlack(0,0,0),
1058cdf0e10cSrcweir maRed(1,0,0),
1059cdf0e10cSrcweir maGreen(0,1,0),
1060cdf0e10cSrcweir maBlue(0,0,1),
1061cdf0e10cSrcweir maYellow(1,1,0),
1062cdf0e10cSrcweir maMagenta(1,0,1),
1063cdf0e10cSrcweir maCyan(0,1,1)
1064cdf0e10cSrcweir {}
1065cdf0e10cSrcweir
1066cdf0e10cSrcweir
1067cdf0e10cSrcweir // initialise your test code values here.
SetUp()1068131e08e2SDamjan Jovanovic virtual void SetUp()
1069cdf0e10cSrcweir {
1070cdf0e10cSrcweir }
1071cdf0e10cSrcweir
TearDown()1072131e08e2SDamjan Jovanovic virtual void TearDown()
1073cdf0e10cSrcweir {
1074cdf0e10cSrcweir }
1075131e08e2SDamjan Jovanovic }; // class bcolor
1076cdf0e10cSrcweir
TEST_F(bcolor,hslTest)1077131e08e2SDamjan Jovanovic TEST_F(bcolor, hslTest)
1078cdf0e10cSrcweir {
1079131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maWhite) == BColor(0,0,1)) << "white";
1080131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maBlack) == BColor(0,0,0)) << "black";
1081131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maRed) == BColor(0,1,0.5)) << "red";
1082131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maGreen) == BColor(120,1,0.5)) << "green";
1083131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maBlue) == BColor(240,1,0.5)) << "blue";
1084131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maYellow) == BColor(60,1,0.5)) << "yellow";
1085131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maMagenta) == BColor(300,1,0.5)) << "magenta";
1086131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maCyan) == BColor(180,1,0.5)) << "cyan";
1087131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(BColor(0,0.5,1)) == BColor(210,1,0.5)) << "third hue case";
1088cdf0e10cSrcweir
1089131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsl2rgb(tools::rgb2hsl(maWhite)) == maWhite) << "roundtrip white";
1090131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsl2rgb(tools::rgb2hsl(maBlack)) == maBlack) << "roundtrip black";
1091131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsl2rgb(tools::rgb2hsl(maRed)) == maRed) << "roundtrip red";
1092131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsl2rgb(tools::rgb2hsl(maGreen)) == maGreen) << "roundtrip green";
1093131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsl2rgb(tools::rgb2hsl(maBlue)) == maBlue) << "roundtrip blue";
1094131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsl2rgb(tools::rgb2hsl(maYellow)) == maYellow) << "roundtrip yellow";
1095131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsl2rgb(tools::rgb2hsl(maMagenta)) == maMagenta) << "roundtrip magenta";
1096131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsl2rgb(tools::rgb2hsl(maCyan)) == maCyan) << "roundtrip cyan";
1097cdf0e10cSrcweir
1098131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maWhite*.1) == BColor(0,0,.1)) << "grey10";
1099131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maWhite*.9) == BColor(0,0,.9)) << "grey90";
1100131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maRed*.5) == BColor(0,1,0.25)) << "red/2";
1101131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maGreen*.5) == BColor(120,1,0.25)) << "green/2";
1102131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maBlue*.5) == BColor(240,1,0.25)) << "blue/2";
1103131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maYellow*.5) == BColor(60,1,0.25)) << "yellow/2";
1104131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maMagenta*.5) == BColor(300,1,0.25)) << "magenta/2";
1105131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(maCyan*.5) == BColor(180,1,0.25)) << "cyan/2";
1106cdf0e10cSrcweir
1107131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsl(BColor(.75,.25,.25)) == BColor(0,.5,.5)) << "pastel";
1108cdf0e10cSrcweir }
1109cdf0e10cSrcweir
TEST_F(bcolor,hsvTest)1110131e08e2SDamjan Jovanovic TEST_F(bcolor, hsvTest)
1111cdf0e10cSrcweir {
1112131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maWhite) == BColor(0,0,1)) << "white";
1113131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maBlack) == BColor(0,0,0)) << "black";
1114131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maRed) == BColor(0,1,1)) << "red";
1115131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maGreen) == BColor(120,1,1)) << "green";
1116131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maBlue) == BColor(240,1,1)) << "blue";
1117131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maYellow) == BColor(60,1,1)) << "yellow";
1118131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maMagenta) == BColor(300,1,1)) << "magenta";
1119131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maCyan) == BColor(180,1,1)) << "cyan";
1120cdf0e10cSrcweir
1121131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsv2rgb(tools::rgb2hsv(maWhite)) == maWhite) << "roundtrip white";
1122131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsv2rgb(tools::rgb2hsv(maBlack)) == maBlack) << "roundtrip black";
1123131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsv2rgb(tools::rgb2hsv(maRed)) == maRed) << "roundtrip red";
1124131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsv2rgb(tools::rgb2hsv(maGreen)) == maGreen) << "roundtrip green";
1125131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsv2rgb(tools::rgb2hsv(maBlue)) == maBlue) << "roundtrip blue";
1126131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsv2rgb(tools::rgb2hsv(maYellow)) == maYellow) << "roundtrip yellow";
1127131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsv2rgb(tools::rgb2hsv(maMagenta)) == maMagenta) << "roundtrip magenta";
1128131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::hsv2rgb(tools::rgb2hsv(maCyan)) == maCyan) << "roundtrip cyan";
1129cdf0e10cSrcweir
1130131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maWhite*.1) == BColor(0,0,.1)) << "grey10";
1131131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maWhite*.9) == BColor(0,0,.9)) << "grey90";
1132131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maRed*.5) == BColor(0,1,0.5)) << "red/2";
1133131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maGreen*.5) == BColor(120,1,0.5)) << "green/2";
1134131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maBlue*.5) == BColor(240,1,0.5)) << "blue/2";
1135131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maYellow*.5) == BColor(60,1,0.5)) << "yellow/2";
1136131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maMagenta*.5) == BColor(300,1,0.5)) << "magenta/2";
1137131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(maCyan*.5) == BColor(180,1,0.5)) << "cyan/2";
1138cdf0e10cSrcweir
1139131e08e2SDamjan Jovanovic ASSERT_TRUE(tools::rgb2hsv(BColor(.5,.25,.25)) == BColor(0,.5,.5)) << "pastel";
1140cdf0e10cSrcweir }
1141cdf0e10cSrcweir
TEST_F(bcolor,ciexyzTest)1142131e08e2SDamjan Jovanovic TEST_F(bcolor, ciexyzTest)
1143cdf0e10cSrcweir {
1144cdf0e10cSrcweir tools::rgb2ciexyz(maWhite);
1145cdf0e10cSrcweir tools::rgb2ciexyz(maBlack);
1146cdf0e10cSrcweir tools::rgb2ciexyz(maRed);
1147cdf0e10cSrcweir tools::rgb2ciexyz(maGreen);
1148cdf0e10cSrcweir tools::rgb2ciexyz(maBlue);
1149cdf0e10cSrcweir tools::rgb2ciexyz(maYellow);
1150cdf0e10cSrcweir tools::rgb2ciexyz(maMagenta);
1151cdf0e10cSrcweir tools::rgb2ciexyz(maCyan);
1152cdf0e10cSrcweir }
1153cdf0e10cSrcweir
1154cdf0e10cSrcweir // -----------------------------------------------------------------------------
1155cdf0e10cSrcweir
1156cdf0e10cSrcweir } // namespace basegfx2d
1157