Mesh_feature_extractor не возвращает правильную границу

Я не могу понять, как работает граница Mesh_feature_extractor. Я использую идеальный куб с 8 вершинами, когда я вызываю get_nb_borders(), он возвращает 1, что я считаю неправильным (возможно, мое понимание 'Границы' неверно). Кто-нибудь может объяснить, что такое граница?

    std::vector<Vector3> tempVertices;
    tempVertices.push_back(Vector3(-50, 50, -50));
    tempVertices.push_back(Vector3(-50, 50, 50));
    tempVertices.push_back(Vector3(50, 50, 50));
    tempVertices.push_back(Vector3(50, 50, -50));

    tempVertices.push_back(Vector3(-50, -50, -50));
    tempVertices.push_back(Vector3(-50, -50, 50));
    tempVertices.push_back(Vector3(50, -50, 50));
    tempVertices.push_back(Vector3(50, -50, -50));

    std::vector<int32> tempIndices;
    tempIndices.push_back(0);   tempIndices.push_back(2);   tempIndices.push_back(1);
    tempIndices.push_back(0);   tempIndices.push_back(3);   tempIndices.push_back(2);

    tempIndices.push_back(4);   tempIndices.push_back(6);   tempIndices.push_back(5);
    tempIndices.push_back(4);   tempIndices.push_back(7);   tempIndices.push_back(6);

    tempIndices.push_back(4);   tempIndices.push_back(3);   tempIndices.push_back(0);
    tempIndices.push_back(4);   tempIndices.push_back(7);   tempIndices.push_back(3);

    tempIndices.push_back(7);   tempIndices.push_back(2);   tempIndices.push_back(3);
    tempIndices.push_back(7);   tempIndices.push_back(6);   tempIndices.push_back(2);

    tempIndices.push_back(6);   tempIndices.push_back(1);   tempIndices.push_back(2);
    tempIndices.push_back(6);   tempIndices.push_back(5);   tempIndices.push_back(1);

    tempIndices.push_back(5);   tempIndices.push_back(0);   tempIndices.push_back(1);
    tempIndices.push_back(5);   tempIndices.push_back(4);   tempIndices.push_back(0);

    typedef Polyhedron::HalfedgeDS  HalfedgeDS;

    Polyhedron mesh;
    CGALTriangleBuilder<HalfedgeDS> triangle(tempVertices, tempIndices);
    mesh.delegate(triangle);

    typedef CGAL::Parameterization_polyhedron_adaptor_3<Polyhedron> Parameterization_polyhedron_adaptor;
    Parameterization_polyhedron_adaptor mesh_adaptor(mesh);

    // Helper class to compute genus or extract borders
    typedef CGAL::Parameterization_mesh_feature_extractor<Parameterization_polyhedron_adaptor> Mesh_feature_extractor;


    // Extract mesh borders and compute genus
    Mesh_feature_extractor feature_extractor(mesh_adaptor);
    int nb_borders = feature_extractor.get_nb_borders();
    int genus = feature_extractor.get_genus();

1 ответ

Мое плохое 1 лицо куба было по часовой стрелке, а остальные были против часовой стрелки...

Другие вопросы по тегам