cleaned up and added all the refinement strategies including catmull clark (that now crash...)
This commit is contained in:
parent
aa04a96264
commit
493553c5f1
|
@ -1,8 +1,6 @@
|
||||||
|
|
||||||
// mesh definition
|
|
||||||
|
|
||||||
#include<vcg/simplex/vertex/base.h>
|
#include<vcg/simplex/vertex/base.h>
|
||||||
#include<vcg/simplex/face/base.h>
|
#include<vcg/simplex/face/base.h>
|
||||||
|
#include<vcg/simplex/face/component_ocf.h>
|
||||||
#include<vcg/simplex/face/topology.h>
|
#include<vcg/simplex/face/topology.h>
|
||||||
|
|
||||||
#include<vcg/complex/trimesh/base.h>
|
#include<vcg/complex/trimesh/base.h>
|
||||||
|
@ -11,6 +9,9 @@
|
||||||
#include <vcg/complex/trimesh/update/normal.h>
|
#include <vcg/complex/trimesh/update/normal.h>
|
||||||
#include <vcg/complex/trimesh/update/flag.h>
|
#include <vcg/complex/trimesh/update/flag.h>
|
||||||
#include <vcg/complex/trimesh/refine.h>
|
#include <vcg/complex/trimesh/refine.h>
|
||||||
|
#include <vcg/complex/trimesh/refine_loop.h>
|
||||||
|
|
||||||
|
#include <vcg/complex/trimesh/bitquad_creation.h>
|
||||||
|
|
||||||
// input output
|
// input output
|
||||||
#include <wrap/io_trimesh/import_ply.h>
|
#include <wrap/io_trimesh/import_ply.h>
|
||||||
|
@ -22,11 +23,6 @@
|
||||||
using namespace vcg;
|
using namespace vcg;
|
||||||
using namespace std;
|
using namespace std;
|
||||||
|
|
||||||
//struct MyFace;
|
|
||||||
//struct MyEdge;
|
|
||||||
//struct MyVertex: public VertexVN<float,MyEdge,MyFace>{};
|
|
||||||
//struct MyFace: public FaceAF<MyVertex,MyEdge,MyFace>{};
|
|
||||||
//struct MyMesh: public tri::TriMesh< vector<MyVertex>, vector<MyFace> >{};
|
|
||||||
|
|
||||||
class MyEdge; // dummy prototype never used
|
class MyEdge; // dummy prototype never used
|
||||||
class MyFace;
|
class MyFace;
|
||||||
|
@ -36,13 +32,15 @@ struct MyUsedTypes : public UsedTypes< Use<MyVertex>::AsVertexType,
|
||||||
Use<MyFace>::AsFaceType>{};
|
Use<MyFace>::AsFaceType>{};
|
||||||
|
|
||||||
class MyVertex : public Vertex< MyUsedTypes, vertex::Coord3f, vertex::Normal3f, vertex::BitFlags >{};
|
class MyVertex : public Vertex< MyUsedTypes, vertex::Coord3f, vertex::Normal3f, vertex::BitFlags >{};
|
||||||
class MyFace : public Face < MyUsedTypes, face::FFAdj, face::VertexRef, face::BitFlags > {};
|
class MyFace : public Face < MyUsedTypes, face::InfoOcf, face::FFAdjOcf, face::VertexRef, face::BitFlags > {};
|
||||||
class MyMesh : public vcg::tri::TriMesh< vector<MyVertex>, vector<MyFace> > {};
|
class MyMesh : public vcg::tri::TriMesh< vector<MyVertex>, face::vector_ocf<MyFace> > {};
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#define FLAT 0
|
#define FLAT 0
|
||||||
#define BUTTERFLY 2
|
#define LOOP 1
|
||||||
|
#define CATMULL 2
|
||||||
|
#define BUTTERFLY 3
|
||||||
|
|
||||||
int main(int argc, char **argv)
|
int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
|
@ -55,8 +53,10 @@ int main(int argc, char **argv)
|
||||||
"Commands: \n"
|
"Commands: \n"
|
||||||
" Refinement rules:\n"
|
" Refinement rules:\n"
|
||||||
" -m use simple midpoint subdivision (default) \n"
|
" -m use simple midpoint subdivision (default) \n"
|
||||||
" -b use butterfly subdivision scheme \n"
|
" -b use butterfly subdivision scheme \n"
|
||||||
" -l# refine only if the the edge is longer than #(default 0.0)\n"
|
" -l use butterfly subdivision scheme \n"
|
||||||
|
" -c use butterfly subdivision scheme \n"
|
||||||
|
" -e# refine only if the the edge is longer than #(default 0.0)\n"
|
||||||
);
|
);
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
|
@ -71,30 +71,48 @@ int main(int argc, char **argv)
|
||||||
{
|
{
|
||||||
case 'm' : RefMode=FLAT; break;
|
case 'm' : RefMode=FLAT; break;
|
||||||
case 'b' : RefMode=BUTTERFLY; break;
|
case 'b' : RefMode=BUTTERFLY; break;
|
||||||
case 'l' : length=(float)atof(argv[i]+2); break;
|
case 'l' : RefMode=LOOP; break;
|
||||||
|
case 'c' : RefMode=CATMULL; break;
|
||||||
|
case 'e' : length=(float)atof(argv[i]+2); break;
|
||||||
default : {printf("Error unable to parse option '%s'\n",argv[i]); exit(0);}
|
default : {printf("Error unable to parse option '%s'\n",argv[i]); exit(0);}
|
||||||
}
|
}
|
||||||
++i;
|
++i;
|
||||||
}
|
}
|
||||||
|
|
||||||
MyMesh m;
|
MyMesh m;
|
||||||
if(vcg::tri::io::ImporterPLY<MyMesh>::Open(m,argv[1])!=0)
|
if(tri::io::ImporterPLY<MyMesh>::Open(m,argv[1])!=0)
|
||||||
{
|
{
|
||||||
printf("Error reading file %s\n",argv[1]);
|
printf("Error reading file %s\n",argv[1]);
|
||||||
exit(0);
|
exit(0);
|
||||||
}
|
}
|
||||||
vcg::tri::UpdateTopology<MyMesh>::FaceFace(m);
|
m.face.EnableFFAdjacency();
|
||||||
vcg::tri::UpdateFlags<MyMesh>::FaceBorderFromFF(m);
|
tri::UpdateTopology<MyMesh>::FaceFace(m);
|
||||||
vcg::tri::UpdateNormals<MyMesh>::PerVertexNormalized(m);
|
tri::UpdateFlags<MyMesh>::FaceBorderFromFF(m);
|
||||||
|
tri::UpdateNormals<MyMesh>::PerVertexNormalized(m);
|
||||||
printf("Input mesh vn:%i fn:%i\n",m.vn,m.fn);
|
printf("Input mesh vn:%i fn:%i\n",m.vn,m.fn);
|
||||||
|
|
||||||
n_steps=atoi(argv[3]);
|
n_steps=atoi(argv[3]);
|
||||||
|
|
||||||
for(i=0;i < n_steps;++i)
|
for(i=0;i < n_steps;++i)
|
||||||
{
|
{
|
||||||
switch(RefMode){
|
switch(RefMode)
|
||||||
case FLAT: Refine<MyMesh, MidPoint<MyMesh> >(m,MidPoint<MyMesh>(&m),length); break;
|
{
|
||||||
case BUTTERFLY: Refine<MyMesh, MidPointButterfly<MyMesh> >(m,MidPointButterfly<MyMesh>(),length); break;
|
case FLAT:
|
||||||
|
Refine<MyMesh, MidPoint<MyMesh> >(m,MidPoint<MyMesh>(&m),length);
|
||||||
|
break;
|
||||||
|
case LOOP:
|
||||||
|
tri::RefineOddEven<MyMesh, tri::OddPointLoop<MyMesh>, tri::EvenPointLoop<MyMesh> >(m, tri::OddPointLoop<MyMesh>(), tri::EvenPointLoop<MyMesh>(), length);
|
||||||
|
break;
|
||||||
|
case CATMULL:
|
||||||
|
tri::BitQuadCreation<MyMesh>::MakePureByRefine(m);
|
||||||
|
assert(tri::BitQuadCreation<MyMesh>::IsBitTriQuadConventional(m));
|
||||||
|
tri::UpdateTopology<MyMesh>::FaceFace(m);
|
||||||
|
tri::BitQuadCreation<MyMesh>::MakePureByRefine(m);
|
||||||
|
tri::UpdateNormals<MyMesh>::PerBitQuadFaceNormalized(m);
|
||||||
|
break;
|
||||||
|
case BUTTERFLY:
|
||||||
|
Refine<MyMesh, MidPointButterfly<MyMesh> >(m,MidPointButterfly<MyMesh>(),length);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -10,4 +10,6 @@ DEPENDPATH += .
|
||||||
INCLUDEPATH += . ../../..
|
INCLUDEPATH += . ../../..
|
||||||
CONFIG += console stl
|
CONFIG += console stl
|
||||||
TEMPLATE = app
|
TEMPLATE = app
|
||||||
SOURCES += trimesh_refine.cpp ../../../wrap/ply/plylib.cpp
|
SOURCES += trimesh_refine.cpp ../../../wrap/ply/plylib.cpp
|
||||||
|
# Mac specific Config required to avoid to make application bundles
|
||||||
|
CONFIG -= app_bundle
|
||||||
|
|
Loading…
Reference in New Issue