mesh.delete_face()导致abort()

时间:2018-10-24 09:24:36

标签: c++ openmesh

我试图运行下面的代码,但是在使用mesh.delete_face(* it,false);时出错。

    vector<TriMesh::FaceHandle> terminalFaces;

    OpenMesh::FPropHandleT<int> faceType;
    OpenMesh::FPropHandleT<bool> faceChecked;
    mesh.add_property(faceType, "face-type");
    mesh.add_property(faceChecked, "face-checked");

    tFillFacesProperty(mesh, faceChecked, false);

    tClassifyFaces(mesh, faceType); 
    terminalFaces = tSplitJointFaces(mesh, faceType);   
    tClassifyFaces(mesh, faceType);
    tAdjustAllVertices(mesh);

    for (int i = 0; i < terminalFaces.size(); i++)
    {
        if (mesh.property(faceType, terminalFaces[i]) != FT_TERMINAL)
            continue;
        if (mesh.property(faceChecked, terminalFaces[i])) 
            continue;

        vector<TriMesh::VertexHandle> collectedVs; 
        vector<TriMesh::FaceHandle> collectedFs; 

        for (TriMesh::FaceVertexIter fvi = mesh.fv_begin(terminalFaces[i]); 
            fvi != mesh.fv_end(terminalFaces[i]);
            ++fvi)
        {
            if (mesh.valence(*fvi) == 2) {
                collectedVs.push_back(*fvi);   
                break;
            }
        }
        assert(collectedVs.size() == 1);

        while(1){
            bool mustStop = false;

            if (collectedFs.empty())
                collectedFs.push_back(terminalFaces[i]); 
            else {
                TriMesh::FaceHandle nextFh;
                for (TriMesh::FaceFaceIter ffi = mesh.ff_begin(collectedFs.back());
                    ffi != mesh.ff_end(collectedFs.back());
                    ++ffi)
                {
                    if ((find(collectedFs.begin(), collectedFs.end(), *ffi) == collectedFs.end())   
                        && mesh.is_valid_handle(*ffi)
                        && mesh.property(faceType, *ffi) != FT_NEW)
                    {
                        nextFh = *ffi;
                        break;
                    }
                }
                if (mesh.is_valid_handle(nextFh))
                    collectedFs.push_back(nextFh);
                else
                    mustStop = true;
            }
            TriMesh::FaceHandle curfh = collectedFs.back();
            mesh.property(faceChecked, curfh) = true; 
            int t = mesh.property(faceType, curfh);  
            if (t == FT_SLEEVE || t == FT_TERMINAL) {
                TriMesh::HalfedgeHandle hh2check;
                for (TriMesh::FaceHalfedgeIter fhi = mesh.fh_begin(curfh);  
                    fhi != mesh.fh_end(curfh);
                    ++fhi)
                {
                    TriMesh::FaceHandle oppof = mesh.opposite_face_handle(*fhi);
                    if (mesh.is_valid_handle(oppof)
                        && (find(collectedFs.begin(), collectedFs.end(),oppof) == collectedFs.end()))
                    {
                        hh2check = *fhi;
                        break;
                    }
                }
                assert(mesh.is_valid_handle(hh2check) && !mesh.is_boundary(hh2check));

                // add new vertices
                TriMesh::VertexHandle right, left;
                right = mesh.from_vertex_handle(hh2check);
                left = mesh.to_vertex_handle(hh2check); 
                assert(mesh.is_valid_handle(left) && mesh.is_valid_handle(right));
                if ((find(collectedVs.begin(), collectedVs.end(), left) == collectedVs.end())  
                    && mesh.is_valid_handle(left))
                    collectedVs.insert(collectedVs.begin(), left);
                if ((find(collectedVs.begin(), collectedVs.end(), right) == collectedVs.end())
                    && mesh.is_valid_handle(right))
                    collectedVs.push_back(right);

                bool inCircle = true;
                TriMesh::Point center = (mesh.point(right) + mesh.point(left)) / 2.0;
                double diamSq = tSqDist(mesh.point(right), mesh.point(left));
                for (int i = 1; i < collectedVs.size() - 1; i++)
                {
                    TriMesh::VertexHandle vh = collectedVs[i];
                    if (tSqDist(mesh.point(vh), center) * 4 > diamSq) {
                        inCircle = false;
                        break;
                    }
                }

                if (inCircle && !mustStop) {
                    continue;
                }
                else {

                    OpenMesh::IO::write_mesh(mesh, "outputtr.off");
                    for (vector<TriMesh::FaceHandle>::iterator it = collectedFs.begin(); it != collectedFs.end(); ++it){

                        mesh.delete_face(*it, false); 
                    }

我在openmesh中使用delete_face()来删除网格中的一个面。 但是,调试总是像下面这样显示:abort()和错误面板:

R6010 -abort() has been called

断点由_CrtDbgBreak()触发:

case 1: _CrtDbgBreak(); msgshown = 1;

错误可能是由悬挂的引用/指针或无效的迭代器引起的。我该如何解决?

1 个答案:

答案 0 :(得分:0)

只需添加“ mesh.request_face_status();”解决了。​​