2005-09-28 22:14:53 +02:00
|
|
|
// standard headers
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
// stl headers
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
// vcg headers
|
2006-10-13 15:17:23 +02:00
|
|
|
//#include<vcg/simplex/vertex/vertex.h>
|
|
|
|
//#include<vcg/simplex/face/with/rtfmfn.h>
|
|
|
|
#include<vcg/simplex/vertexplus/base.h>
|
|
|
|
#include<vcg/simplex/faceplus/base.h>
|
|
|
|
#include<vcg/simplex/faceplus/component_rt.h>
|
|
|
|
|
2005-09-28 22:14:53 +02:00
|
|
|
#include<vcg/simplex/face/distance.h>
|
|
|
|
#include<vcg/complex/trimesh/base.h>
|
|
|
|
#include <vcg/complex/trimesh/create/platonic.h>
|
|
|
|
#include <vcg/complex/trimesh/update/normal.h>
|
|
|
|
#include <vcg/complex/trimesh/update/edges.h>
|
|
|
|
#include <vcg/complex/trimesh/update/flag.h>
|
2005-09-29 13:52:22 +02:00
|
|
|
#include <vcg/space/intersection3.h>
|
2005-09-28 22:14:53 +02:00
|
|
|
|
|
|
|
#include <vcg/space/index/aabb_binary_tree/aabb_binary_tree.h>
|
|
|
|
|
|
|
|
typedef float AScalarType;
|
|
|
|
|
2006-10-13 15:17:23 +02:00
|
|
|
using namespace vcg;
|
|
|
|
|
2005-09-28 22:14:53 +02:00
|
|
|
class AEdge;
|
|
|
|
class AFace;
|
2006-10-13 15:17:23 +02:00
|
|
|
class AVertex : public VertexSimp2< AVertex, AEdge, AFace, vert::Normal3f, vert::Coord3f >{};
|
|
|
|
class AFace : public FaceSimp2< AVertex, AEdge, AFace, face::VertexRef, face::Normal3f, face::RTInfo, face::BitFlags> {};
|
|
|
|
|
|
|
|
//class AVertex : public vcg::Vertex< AScalarType, AEdge, AFace > { };
|
|
|
|
//class AFace : public vcg::FaceRTFMFN< AVertex, AEdge, AFace > { };
|
|
|
|
|
2005-09-28 22:14:53 +02:00
|
|
|
class AMesh : public vcg::tri::TriMesh< std::vector<AVertex>, std::vector<AFace> > { };
|
|
|
|
|
|
|
|
typedef vcg::AABBBinaryTreeIndex<AFace, AScalarType, vcg::EmptyClass> AIndex;
|
|
|
|
|
|
|
|
static AMesh gMesh;
|
|
|
|
static AIndex gIndex;
|
|
|
|
|
|
|
|
static void CreateMesh(void) {
|
|
|
|
vcg::tri::Dodecahedron<AMesh>(gMesh);
|
|
|
|
|
|
|
|
vcg::tri::UpdateFlags<AMesh>::Clear(gMesh);
|
|
|
|
vcg::tri::UpdateNormals<AMesh>::PerVertexNormalized(gMesh);
|
|
|
|
vcg::tri::UpdateEdges<AMesh>::Set(gMesh);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void SetIndex(void) {
|
|
|
|
gIndex.Set(gMesh.face.begin(), gMesh.face.end());
|
|
|
|
}
|
|
|
|
|
|
|
|
static void TestClosest(void) {
|
|
|
|
vcg::face::PointDistanceFunctor getPtDist;
|
|
|
|
const AIndex::ScalarType x = 0;
|
|
|
|
const AIndex::CoordType queryPoint((AIndex::ScalarType)0, (AIndex::ScalarType)0, (AIndex::ScalarType)0);
|
|
|
|
const AIndex::ScalarType maxDist = std::numeric_limits<AIndex::ScalarType>::max();
|
|
|
|
|
|
|
|
AIndex::ObjPtr closestFace;
|
|
|
|
AIndex::ScalarType closestDist;
|
|
|
|
AIndex::CoordType closestPoint;
|
|
|
|
|
|
|
|
closestFace = gIndex.GetClosest(getPtDist, vcg::EmptyClass(), queryPoint, maxDist, closestDist, closestPoint);
|
|
|
|
|
|
|
|
printf("GetClosest Test:\n");
|
|
|
|
|
|
|
|
if (closestFace != 0) {
|
|
|
|
printf("\tface : 0x%p\n", closestFace);
|
|
|
|
printf("\tdistance : %f\n", closestDist);
|
|
|
|
printf("\tpoint : [%f, %f, %f]\n", closestPoint[0], closestPoint[1], closestPoint[2]);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
printf("\tno object found (index is probably empty).\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void TestKClosest(void) {
|
|
|
|
vcg::face::PointDistanceFunctor getPtDist;
|
|
|
|
const unsigned int k = 10;
|
|
|
|
const AIndex::CoordType queryPoint((AIndex::ScalarType)0, (AIndex::ScalarType)0, (AIndex::ScalarType)0);
|
|
|
|
const AIndex::ScalarType maxDist = std::numeric_limits<AIndex::ScalarType>::max();
|
|
|
|
|
|
|
|
std::vector<AIndex::ObjPtr> closestObjects;
|
|
|
|
std::vector<AIndex::ScalarType> closestDistances;
|
|
|
|
std::vector<AIndex::CoordType> closestPoints;
|
|
|
|
|
|
|
|
unsigned int rk = gIndex.GetKClosest(getPtDist, vcg::EmptyClass(), k, queryPoint, maxDist, closestObjects, closestDistances, closestPoints);
|
|
|
|
|
|
|
|
printf("GetKClosest Test:\n");
|
|
|
|
printf("\tfound %d objects\n", rk);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void TestRay(void) {
|
|
|
|
const bool TEST_BACK_FACES = true;
|
|
|
|
|
2005-09-29 13:52:22 +02:00
|
|
|
vcg::RayTriangleIntersectionFunctor<TEST_BACK_FACES> rayIntersector;
|
2005-09-28 22:14:53 +02:00
|
|
|
const AIndex::ScalarType maxDist = std::numeric_limits<AIndex::ScalarType>::max();
|
|
|
|
const AIndex::CoordType rayOrigin((AIndex::ScalarType)0, (AIndex::ScalarType)0, (AIndex::ScalarType)0);
|
|
|
|
const AIndex::CoordType rayDirection((AIndex::ScalarType)1, (AIndex::ScalarType)0, (AIndex::ScalarType)0);
|
|
|
|
const vcg::Ray3<AIndex::ScalarType, false> ray(rayOrigin, rayDirection);
|
|
|
|
|
|
|
|
AIndex::ObjPtr isectFace;
|
|
|
|
AIndex::ScalarType rayT;
|
|
|
|
AIndex::CoordType isectPt;
|
|
|
|
|
|
|
|
isectFace = gIndex.DoRay(rayIntersector, vcg::EmptyClass(), ray, maxDist, rayT);
|
|
|
|
|
|
|
|
printf("DoRay Test:\n");
|
|
|
|
if (isectFace != 0) {
|
|
|
|
printf("\tface : 0x%p\n", isectFace);
|
|
|
|
printf("\tray t : %f\n", rayT);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
printf("\tno object found (index is probably empty).\n");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2005-11-14 10:29:32 +01:00
|
|
|
int main (int /*argc*/, char ** /*argv*/) {
|
2005-09-28 22:14:53 +02:00
|
|
|
CreateMesh();
|
|
|
|
|
|
|
|
SetIndex();
|
|
|
|
|
|
|
|
printf("Spatial Index Tests\n");
|
|
|
|
printf("---\n");
|
|
|
|
TestClosest();
|
|
|
|
printf("---\n");
|
|
|
|
TestKClosest();
|
|
|
|
printf("---\n");
|
|
|
|
TestRay();
|
|
|
|
printf("---\n");
|
|
|
|
|
|
|
|
return (0);
|
|
|
|
}
|