我最近开始在一个必须细化网格的项目中使用 OpenMesh。我需要使用面split(FaceHandle _fh, Point _p)
操作在三角形的质心处插入一个顶点。但是当我使用这种方法并尝试使用 VertexFaceIterator 抓取新创建的顶点的面时,我总是会得到具有顶点索引的无效面,例如 (87, 87, -1) 或 (12, 12, -1)。似乎 OpenMesh 在拆分后没有更新网格拓扑。
我的代码看起来像这样。faceStartIt
是什么给了我这些奇怪的索引。
typedef OpenMesh::TriMesh_ArrayKernelT<> TriMesh;
TriMesh::FaceIter triangleIt = mesh.faces_begin();
for( ; triangleIt != mesh.faces_end(); )
{
TriMesh::Point centroid = mesh.calc_face_centroid( *triangleIt );
if( hasToSplit( centroid ) )
{
TriMesh::VertexHandle centroidHandle = mesh.split( *triangleIt, centroid );
TriMesh::VertexFaceIter faceStartIt = mesh.vf_begin( centroidHandle );
TriMesh::VertexFaceIter faceEndIt = mesh.vf_end( centroidHandle );
TriMesh::VertexFaceIter faceIt = faceStartIt; //faceIt++;
for( ; faceIt != faceEndIt; ++faceIt )
{
// Do something for each face
}
}
else
{
++triangleIt;
}
}