1

我最近开始在一个必须细化网格的项目中使用 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;
        }
    }
4

2 回答 2

1

我发现了我遇到的问题。该split方法工作正常,我做错了什么在// Do something for each face评论中。对于每个面,我都在进行边缘翻转操作,但是由于翻转会导致后来评估的面发生变化,所以参考丢失了。解决方案是在一次迭代中,在分割一个面之后,插入我想要翻转的每条边,std::set以确保它们是唯一的。然后在另一次迭代中对标记的边缘进行实际翻转。

于 2016-12-07T12:46:22.483 回答
0

也许你可以改为

TriMesh::FaceIter triangleIt = mesh.faces_begin();

TriMesh::FaceIter triangleIt = mesh.faces_sbegin();

garbage_collection()也可以,但系数低。如果使用face_sbegin(),迭代器将跳过无效面。

于 2021-01-14T03:38:40.990 回答