1 /*---------------------------------------------------------------------------*\
5 * Copyright (C) 2000-2006 by the OpenSG Forum *
7 * contact: dirk@opensg.org, gerrit.voss@vossg.org, jbehr@zgdv.de *
9 \*---------------------------------------------------------------------------*/
10 /*---------------------------------------------------------------------------*\
13 * This library is free software; you can redistribute it and/or modify it *
14 * under the terms of the GNU Library General Public License as published *
15 * by the Free Software Foundation, version 2. *
17 * This library is distributed in the hope that it will be useful, but *
18 * WITHOUT ANY WARRANTY; without even the implied warranty of *
19 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU *
20 * Library General Public License for more details. *
22 * You should have received a copy of the GNU Library General Public *
23 * License along with this library; if not, write to the Free Software *
24 * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. *
26 \*---------------------------------------------------------------------------*/
27 /*---------------------------------------------------------------------------*\
35 \*---------------------------------------------------------------------------*/
37 #include <UnitTest++.h>
39 // Unit tests for vec classes
41 #include "OSGGeometry.h"
42 #include "OSGGeoVectorProperty.h"
43 #include "OSGGeoProperties.h"
44 #include "OSGFieldContainerFactory.h"
45 #include "OSGTypedGeoVectorProperty.h"
46 #include "OSGSimpleGeometry.h"
47 #include "OSGTransform.h"
54 OSG::GeometryUnrecPtr g
= OSG::Geometry::create();
58 TEST(TestInitialValues
)
60 OSG::GeometryUnrecPtr g
= OSG::Geometry::create();
63 for(unsigned i
=0;i
<OSG::Geometry::MaxAttribs
;i
++)
65 CHECK(g
->getProperty(i
) == NULL
);
66 CHECK(g
->getIndex(i
) == NULL
);
69 CHECK(g
->getMaterial() == NULL
);
72 // Test using the generic vector interfaces on geometry
73 TEST(TestGenericInterfaces
)
75 OSG::GeometryUnrecPtr g
= OSG::Geometry::create();
78 OSG::GeoPnt3fPropertyUnrecPtr pnts
= OSG::GeoPnt3fProperty ::create();
79 pnts
->addValue(OSG::Pnt3f(0,0,0));
81 g
->setPositions(pnts
);
83 OSG::GeoVectorPropertyUnrecPtr pnts_g
= g
->getPositions();
84 pnts_g
->setValue(OSG::Pnt3f(1,1,1), 0);
85 pnts_g
->setValue(OSG::Pnt3s(1,1,1), 0);
86 pnts_g
->setValue(OSG::Pnt2f(1,1 ), 0);
87 pnts_g
->setValue(OSG::Vec3f(1,1,1), 0);
88 pnts_g
->setValue(OSG::Vec2f(1,2 ), 0);
89 pnts_g
->setValue(OSG::Vec4f(1,2,3,4), 0);
90 pnts_g
->setValue(OSG::Color3f(1,2,3), 0);
91 pnts_g
->setValue(OSG::Color4f(1,2,3,4), 0);
95 TEST(TestSettingVecAttribs
)
97 // Test setting attributes to all possible value types
98 OSG::GeometryUnrecPtr g
= OSG::Geometry::create();
101 // Copied-and-macroed from OSGTypedGeoVectorPropertyFields
102 const char* allowed_vec_prop_types
[] =
114 "GeoVec1NubProperty",
115 "GeoVec2NubProperty",
116 "GeoVec3NubProperty",
117 "GeoVec4NubProperty",
119 "GeoPnt1NubProperty",
120 "GeoPnt2NubProperty",
121 "GeoPnt3NubProperty",
122 "GeoPnt4NubProperty",
156 "GeoVec1NusProperty",
157 "GeoVec2NusProperty",
158 "GeoVec3NusProperty",
159 "GeoVec4NusProperty",
161 "GeoPnt1NusProperty",
162 "GeoPnt2NusProperty",
163 "GeoPnt3NusProperty",
164 "GeoPnt4NusProperty",
207 "GeoColor3ubProperty",
208 "GeoColor4ubProperty",
209 "GeoColor3NubProperty",
210 "GeoColor4NubProperty",
212 "GeoColor3fProperty",
216 OSG::GeoVectorPropertyUnrecPtr att
;
218 unsigned num_vec_props
= sizeof(allowed_vec_prop_types
) / sizeof(char*);
220 for(unsigned i
= 0; i
< num_vec_props
;++i
)
222 att
= OSG::dynamic_pointer_cast
<OSG::GeoVectorProperty
>(
223 OSG::FieldContainerFactory::the()->createContainer(
224 allowed_vec_prop_types
[i
]));
225 unsigned prop_index
= i
% 16;
226 g
->setProperty(att
,prop_index
);
232 TEST(GeometryAsInnerNodesBoundingVolume
)
236 // +-------------------------------------+
238 // pNTrans1:pTrans1[Transform] pNTran2:pTrans2[Transform]
240 // pNGeo1:[Geometry] pNGeo2:[Geometry]
242 OSG::NodeUnrecPtr pNGeo0
= OSG::makeBox(2.0, 2.0, 4.0, 1, 1, 1);
243 OSG::NodeUnrecPtr pNGeo1
= OSG::makeBox(2.0, 2.0, 2.0, 1, 1, 1);
244 OSG::NodeUnrecPtr pNGeo2
= OSG::makeBox(2.0, 2.0, 2.0, 1, 1, 1);
246 OSG::NodeUnrecPtr pNTrans1
= OSG::Node::create();
247 OSG::TransformUnrecPtr pTrans1
= OSG::Transform::create();
248 OSG::NodeUnrecPtr pNTrans2
= OSG::Node::create();
249 OSG::TransformUnrecPtr pTrans2
= OSG::Transform::create();
251 pNTrans1
->setCore (pTrans1
);
252 pNTrans1
->addChild(pNGeo1
);
253 pNTrans2
->setCore (pTrans2
);
254 pNTrans2
->addChild(pNGeo2
);
256 pNGeo0
->addChild(pNTrans1
);
257 pNGeo0
->addChild(pNTrans2
);
262 mat1
.setTranslate(OSG::Vec3f( 3.0, 0.0, 0.0));
263 mat2
.setTranslate(OSG::Vec3f(- 3.0, 0.0, 0.0));
265 pTrans1
->editSFMatrix()->setValue(mat1
);
266 pTrans2
->editSFMatrix()->setValue(mat2
);
268 OSG::commitChanges();
274 pNGeo1
->getWorldVolume(bbox
);
275 bbox
.getBounds(min
, max
);
277 CHECK_CLOSE( 2.0, min
[0], 1e-6);
278 CHECK_CLOSE(-1.0, min
[1], 1e-6);
279 CHECK_CLOSE(-1.0, min
[2], 1e-6);
281 CHECK_CLOSE( 4.0, max
[0], 1e-6);
282 CHECK_CLOSE( 1.0, max
[1], 1e-6);
283 CHECK_CLOSE( 1.0, max
[2], 1e-6);
285 pNGeo2
->getWorldVolume(bbox
);
286 bbox
.getBounds(min
, max
);
288 CHECK_CLOSE(-4.0, min
[0], 1e-6);
289 CHECK_CLOSE(-1.0, min
[1], 1e-6);
290 CHECK_CLOSE(-1.0, min
[2], 1e-6);
292 CHECK_CLOSE(-2.0, max
[0], 1e-6);
293 CHECK_CLOSE( 1.0, max
[1], 1e-6);
294 CHECK_CLOSE( 1.0, max
[2], 1e-6);
296 pNGeo0
->getWorldVolume(bbox
);
297 bbox
.getBounds(min
, max
);
299 CHECK_CLOSE(-4.0, min
[0], 1e-6);
300 CHECK_CLOSE(-1.0, min
[1], 1e-6);
301 CHECK_CLOSE(-2.0, min
[2], 1e-6);
303 CHECK_CLOSE( 4.0, max
[0], 1e-6);
304 CHECK_CLOSE( 1.0, max
[1], 1e-6);
305 CHECK_CLOSE( 2.0, max
[2], 1e-6);