Rewrote the function for the selection and counting of non manifold vertices. Now it does not require VF topology, just FF.

This commit is contained in:
Paolo Cignoni 2008-11-07 10:12:39 +00:00
parent a9e5756eda
commit df84db769c
1 changed files with 91 additions and 30 deletions

View File

@ -226,6 +226,7 @@ Initial Release
#include <vcg/complex/trimesh/closest.h> #include <vcg/complex/trimesh/closest.h>
#include <vcg/space/index/grid_static_ptr.h> #include <vcg/space/index/grid_static_ptr.h>
#include<vcg/complex/trimesh/allocate.h> #include<vcg/complex/trimesh/allocate.h>
#include<vcg/complex/trimesh/update/selection.h>
namespace vcg { namespace vcg {
@ -474,6 +475,22 @@ private:
return count_fd; return count_fd;
} }
static int RemoveNonManifoldVertex(MeshType& m)
{
int count_vd = CountNonManifoldVertexFF(m,true);
int count_fd = UpdateSelection<MeshType>::FaceFromVertexLoose(m);
FaceIterator fi;
for(fi=m.face.begin(); fi!=m.face.end();++fi)
if(!(*fi).IsD() && (*fi).IsS())
Allocator<MeshType>::DeleteFace(m,*fi);
VertexIterator vi;
for(vi=m.vert.begin(); vi!=m.vert.end();++vi)
if(!(*vi).IsD() && (*vi).IsS())
Allocator<MeshType>::DeleteVertex(m,*vi);
}
static int RemoveNonManifoldFace(MeshType& m) static int RemoveNonManifoldFace(MeshType& m)
{ {
FaceIterator fi; FaceIterator fi;
@ -629,11 +646,49 @@ private:
return flagManifold; return flagManifold;
} }
static bool IsTwoManifoldVertex( MeshType & m ) static int CountNonManifoldVertexFF( MeshType & m, bool select = true )
{ {
assert(tri::HasFFAdjacency(m));
int nonManifoldCnt=0;
SimpleTempData<typename MeshType::VertContainer, int > TD(m.vert,0);
// primo loop, si conta quanti facce incidono su ogni vertice...
FaceIterator fi;
for (fi = m.face.begin(); fi != m.face.end(); ++fi) if (!fi->IsD())
{
TD[(*fi).V(0)]++;
TD[(*fi).V(1)]++;
TD[(*fi).V(2)]++;
}
tri::UpdateFlags<MeshType>::VertexClearV(m);
for (fi = m.face.begin(); fi != m.face.end(); ++fi) if (!fi->IsD())
{
for(int i=0;i<3;i++) if(!(*fi).V(i)->IsV()){
(*fi).V(i)->SetV();
face::Pos<FaceType> pos(&(*fi),i);
int starSizeFF = pos.NumberOfIncidentFaces();
if (starSizeFF != TD[(*fi).V(i)])
{
if(select) (*fi).V(i)->SetS();
nonManifoldCnt++;
}
}
}
return nonManifoldCnt;
}
static int CountNonManifoldVertexFFVF( MeshType & m, bool select = true )
{
int nonManifoldCnt=0;
VertexIterator vi; VertexIterator vi;
bool flagManifold = true; bool flagManifold = true;
assert(m.HasVFTopology()); assert(tri::HasVFAdjacency(m));
assert(tri::HasFFAdjacency(m));
face::VFIterator<FaceType> vfi; face::VFIterator<FaceType> vfi;
int starSizeFF; int starSizeFF;
@ -657,12 +712,18 @@ private:
if (starSizeFF != starSizeVF) if (starSizeFF != starSizeVF)
{ {
flagManifold = false; flagManifold = false;
break; if(select) (*vi).SetS();
nonManifoldCnt++;
} }
} }
} }
return flagManifold; return nonManifoldCnt;
}
static bool IsTwoManifoldVertex( MeshType & m )
{
return CountNonManifoldVertex(m,false) == 0 ;
} }
static void CountEdges( MeshType & m, int &count_e, int &boundary_e ) static void CountEdges( MeshType & m, int &count_e, int &boundary_e )