vcglib/apps/sample/edgemesh_grid/edgemesh_grid.cpp

65 lines
2.1 KiB
C++

#include <stdio.h>
#include <vcg/space/color4.h>
#include <vcg/space/index/grid_static_ptr.h>
#include <vcg/simplex/vertexplus/base.h>
#include <vcg/simplex/vertexplus/component.h>
#include <vcg/simplex/edgeplus/base.h>
#include <vcg/simplex/edgeplus/component.h>
#include <vcg/complex/edgemesh/base.h>
#include <vcg/complex/edgemesh/allocate.h>
#include <vcg/complex/edgemesh/update/bounding.h>
#include <vcg/complex/edgemesh/closest.h>
//
//using namespace std;
//
class MyFace;
class MyEdge;
class MyVertex : public vcg::VertexSimp2<MyVertex,MyEdge, MyFace,vcg::vert::BitFlags,vcg::vert::Coord3f> {};
class MyEdge : public vcg::EdgeSimp2<MyVertex,MyEdge, MyVertex,vcg::edge::Mark,vcg::edge::VertexRef,vcg::edge::BitFlags> {};
class MyEdgeMesh: public vcg::edg::EdgeMesh< std::vector<MyVertex>, std::vector<MyEdge> > {};
typedef vcg::GridStaticPtr<MyEdge, MyEdge::ScalarType> EdgeMeshGrid;
#define VERT_NUMB 100
int main(int , char **)
{
//create a random mesh of edge
MyEdgeMesh em;
srand(1000);
em.vert.reserve(VERT_NUMB);
for (int i=0;i<VERT_NUMB;i=i+2)
{
float x0=((float)rand()/(float)RAND_MAX)*1000.f;
float y0=((float)rand()/(float)RAND_MAX)*1000.f;
float z0=((float)rand()/(float)RAND_MAX)*1000.f;
float x1=((float)rand()/(float)RAND_MAX)*1000.f;
float y1=((float)rand()/(float)RAND_MAX)*1000.f;
float z1=((float)rand()/(float)RAND_MAX)*1000.f;
em.vert.push_back(MyVertex());
MyVertex *v0=&em.vert.back();
em.vert.push_back(MyVertex());
MyVertex *v1=&em.vert.back();
v0->P().X()=x0;
v0->P().Y()=y0;
v0->P().Z()=z0;
v1->P().X()=x1;
v1->P().Y()=y1;
v1->P().Z()=z1;
em.edges.push_back(MyEdge());
MyEdge *e=&em.edges.back();
e->V(0)=v0;
e->V(1)=v1;
}
vcg::edg::UpdateBounding<MyEdgeMesh>::Box(em);
EdgeMeshGrid static_grid;
static_grid.Set(em.edges.begin(), em.edges.end());
float dist;
vcg::Point3f p;
MyEdge *e=vcg::edgemesh::GetClosestEdge<MyEdgeMesh,EdgeMeshGrid>(em,static_grid,vcg::Point3f(500,500,500),1000,dist,p);
std::vector<MyEdge*> ret;
int num=vcg::edgemesh::GetInBoxEdge<MyEdgeMesh,EdgeMeshGrid,std::vector<MyEdge*> >(em,static_grid,em.bbox,ret);
return 0;
}