2 * Copyright (c) 2014 Samsung Electronics Co., Ltd.
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
8 * http://www.apache.org/licenses/LICENSE-2.0
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
21 #include <dali/public-api/dali-core.h>
22 #include <dali-test-suite-utils.h>
25 using namespace Dali::Internal;
29 // Knots fed into Allegro, which generates control points
30 static void SetupPath( Dali::Path& path)
32 path.AddPoint(Vector3( 30.0, 80.0, 0.0));
33 path.AddPoint(Vector3( 70.0, 120.0, 0.0));
34 path.AddPoint(Vector3(100.0, 100.0, 0.0));
36 //Control points for first segment
37 path.AddControlPoint( Vector3( 39.0, 90.0, 0.0) );
38 path.AddControlPoint(Vector3( 56.0, 119.0, 0.0) );
40 //Control points for second segment
41 path.AddControlPoint(Vector3( 78.0, 120.0, 0.0) );
42 path.AddControlPoint(Vector3( 93.0, 104.0, 0.0) );
45 } // anonymous namespace
47 int utcDaliPathGetPoint(void)
49 TestApplication application;
51 Dali::Path path = Dali::Path::New();
52 path.AddPoint(Vector3( 50.0, 50.0, 0.0));
53 path.AddPoint(Vector3(120.0, 70.0, 0.0));
54 path.AddPoint(Vector3(190.0, 250.0, 0.0));
55 path.AddPoint(Vector3(260.0, 260.0, 0.0));
56 path.AddPoint(Vector3(330.0, 220.0, 0.0));
57 path.AddPoint(Vector3(400.0, 50.0, 0.0));
59 DALI_TEST_EQUALS(path.GetPoint(0), Vector3( 50.0, 50.0, 0.0), TEST_LOCATION);
60 DALI_TEST_EQUALS(path.GetPoint(1), Vector3(120.0, 70.0, 0.0), TEST_LOCATION);
61 DALI_TEST_EQUALS(path.GetPoint(2), Vector3(190.0, 250.0, 0.0), TEST_LOCATION);
62 DALI_TEST_EQUALS(path.GetPoint(3), Vector3(260.0, 260.0, 0.0), TEST_LOCATION);
63 DALI_TEST_EQUALS(path.GetPoint(4), Vector3(330.0, 220.0, 0.0), TEST_LOCATION);
64 DALI_TEST_EQUALS(path.GetPoint(5), Vector3(400.0, 50.0, 0.0), TEST_LOCATION);
68 int utcDaliPathGetPoint02(void)
70 TestApplication application;
72 Dali::Path path = Dali::Path::New();
73 path.AddPoint(Vector3( 50.0, 50.0, 0.0f));
80 catch (Dali::DaliException& e)
82 tet_printf("Assertion %s failed at %s\n", e.mCondition.c_str(), e.mLocation.c_str());
83 DALI_TEST_ASSERT(e, "index < mPoint.Size()", TEST_LOCATION);
88 int utcDaliPathGetPoint03(void)
90 TestApplication application;
92 Dali::Path path = Dali::Path::New();
99 catch (Dali::DaliException& e)
101 tet_printf("Assertion %s failed at %s\n", e.mCondition.c_str(), e.mLocation.c_str());
102 DALI_TEST_ASSERT(e, "index < mPoint.Size()", TEST_LOCATION);
107 int utcDaliPathGetControlPoints(void)
109 TestApplication application;
111 Dali::Path path = Dali::Path::New();
112 path.AddControlPoint( Vector3(0.0f, 0.0f, 0.0) );
113 path.AddControlPoint( Vector3(108.0f, 57.0f, 0.0) );
115 DALI_TEST_EQUALS(path.GetControlPoint(0), Vector3(0.0f, 0.0f, 0.0f), TEST_LOCATION);
116 DALI_TEST_EQUALS(path.GetControlPoint(1), Vector3(108.0f, 57.0f, 0.0f), TEST_LOCATION);
120 int utcDaliPathGetControlPoints01(void)
122 TestApplication application;
124 Dali::Path path = Dali::Path::New();
125 path.AddControlPoint(Vector3(0.0f, 0.0f, 0.0) );
126 path.AddControlPoint(Vector3(108.0f, 57.0f, 0.0) );
130 path.GetControlPoint(5);
131 tet_result(TET_FAIL);
133 catch (Dali::DaliException& e)
135 tet_printf("Assertion %s failed at %s\n", e.mCondition.c_str(), e.mLocation.c_str());
136 DALI_TEST_ASSERT(e, "index < mControlPoint.Size()", TEST_LOCATION);
141 int utcDaliPathGetControlPoints02(void)
143 TestApplication application;
145 Dali::Path path = Dali::Path::New();
148 path.GetControlPoint(0);
149 tet_result(TET_FAIL);
151 catch (Dali::DaliException& e)
153 tet_printf("Assertion %s failed at %s\n", e.mCondition.c_str(), e.mLocation.c_str());
154 DALI_TEST_ASSERT(e, "index < mControlPoint.Size()", TEST_LOCATION);
159 int utcDaliPathGenerateControlPoints01(void)
161 TestApplication application;
163 Dali::Path path = Dali::Path::New();
165 path.AddPoint(Vector3( 50.0, 50.0, 0.0));
166 path.AddPoint(Vector3(120.0, 70.0, 0.0));
167 path.AddPoint(Vector3(190.0, 250.0, 0.0));
168 path.AddPoint(Vector3(260.0, 260.0, 0.0));
169 path.AddPoint(Vector3(330.0, 220.0, 0.0));
170 path.AddPoint(Vector3(400.0, 50.0, 0.0));
172 path.GenerateControlPoints(0.25);
174 DALI_TEST_EQUALS(path.GetControlPoint(0), Vector3( 68.0, 55.0, 0.0), 1.0, TEST_LOCATION);
175 DALI_TEST_EQUALS(path.GetControlPoint(1), Vector3(107.0, 58.0, 0.0), 1.0, TEST_LOCATION);
177 DALI_TEST_EQUALS(path.GetControlPoint(2), Vector3(156.0, 102.0, 0.0), 1.0, TEST_LOCATION);
178 DALI_TEST_EQUALS(path.GetControlPoint(3), Vector3(152.0, 220.0, 0.0), 1.0, TEST_LOCATION);
180 DALI_TEST_EQUALS(path.GetControlPoint(4), Vector3(204.0, 261.0, 0.0), 1.0, TEST_LOCATION);
181 DALI_TEST_EQUALS(path.GetControlPoint(5), Vector3(243.0, 263.0, 0.0), 1.0, TEST_LOCATION);
183 DALI_TEST_EQUALS(path.GetControlPoint(6), Vector3(280.0, 256.0, 0.0), 1.0, TEST_LOCATION);
184 DALI_TEST_EQUALS(path.GetControlPoint(7), Vector3(317.0, 235.0, 0.0), 1.0, TEST_LOCATION);
186 DALI_TEST_EQUALS(path.GetControlPoint(8), Vector3(360.0, 185.0, 0.0), 1.0, TEST_LOCATION);
187 DALI_TEST_EQUALS(path.GetControlPoint(9), Vector3(383.0, 93.0, 0.0), 1.0, TEST_LOCATION);
192 int utcDaliPathGenerateControlPoints02(void)
194 TestApplication application;
196 Dali::Path path = Dali::Path::New();
199 path.GenerateControlPoints(0.25);
200 tet_result(TET_FAIL);
202 catch (Dali::DaliException& e)
204 tet_printf("Assertion %s failed at %s\n", e.mCondition.c_str(), e.mLocation.c_str());
205 DALI_TEST_ASSERT(e, "numSegments > 0", TEST_LOCATION);
210 int utcDaliPathGenerateControlPoints03(void)
212 TestApplication application;
214 Dali::Path path = Dali::Path::New();
215 path.AddPoint(Vector3(400.0, 50.0, 0.0f));
218 path.GenerateControlPoints(0.25);
219 tet_result(TET_FAIL);
221 catch (Dali::DaliException& e)
223 tet_printf("Assertion %s failed at %s\n", e.mCondition.c_str(), e.mLocation.c_str());
224 DALI_TEST_ASSERT(e, "numSegments > 0", TEST_LOCATION);
229 int UtcDaliPathSample01(void)
231 TestApplication application;
232 Dali::Path path = Dali::Path::New();
236 Vector3 position, tangent;
237 path.Sample(0.0f, position, tangent );
238 DALI_TEST_EQUALS(position.x, 30.0f, TEST_LOCATION);
239 DALI_TEST_EQUALS(position.y, 80.0f, TEST_LOCATION);
240 DALI_TEST_EQUALS(tangent.x, 0.6f, 0.1f, TEST_LOCATION);
241 DALI_TEST_EQUALS(tangent.y, 0.7f, 0.1f, TEST_LOCATION);
244 path.Sample(0.25f, position, tangent );
245 DALI_TEST_EQUALS(position.x, 48.0f, 2.0f, TEST_LOCATION);
246 DALI_TEST_EQUALS(position.y, 102.0f, 2.0f, TEST_LOCATION);
247 DALI_TEST_EQUALS(tangent.x, 0.6f, 0.1f, TEST_LOCATION);
248 DALI_TEST_EQUALS(tangent.y, 0.7f, 0.1f, TEST_LOCATION);
251 path.Sample(0.5f, position, tangent );
252 DALI_TEST_EQUALS(position.x, 70.0f, TEST_LOCATION);
253 DALI_TEST_EQUALS(position.y, 120.0f, TEST_LOCATION);
254 DALI_TEST_EQUALS(tangent.x, 1.0f, 0.1f, TEST_LOCATION);
255 DALI_TEST_EQUALS(tangent.y, 0.0f, 0.1f, TEST_LOCATION);
259 path.Sample(0.75f, position, tangent );
260 DALI_TEST_EQUALS(position.x, 85.0f, 2.0f, TEST_LOCATION);
261 DALI_TEST_EQUALS(position.y, 112.0f, 2.0f, TEST_LOCATION);
262 DALI_TEST_EQUALS(tangent.x, 0.7f, 0.1f, TEST_LOCATION);
263 DALI_TEST_EQUALS(tangent.y, -0.6f, 0.1f, TEST_LOCATION);
266 path.Sample(1.0f, position, tangent );
267 DALI_TEST_EQUALS(position.x, 100.0f, TEST_LOCATION);
268 DALI_TEST_EQUALS(position.y, 100.0f, TEST_LOCATION);
269 DALI_TEST_EQUALS(tangent.x, 0.8f, 0.1f, TEST_LOCATION);
270 DALI_TEST_EQUALS(tangent.y, -0.4f, 0.1f, TEST_LOCATION);