From 0c8e489f46caf5dfdb45845df07b2b006417da73 Mon Sep 17 00:00:00 2001 From: Andreas Fabri Date: Tue, 20 Aug 2024 15:16:13 +0100 Subject: [PATCH] store/retrieve selection and features of an OM --- BGL/examples/BGL_OpenMesh/PolyMesh.cpp | 51 ++++++++++++++++++++++++-- 1 file changed, 47 insertions(+), 4 deletions(-) diff --git a/BGL/examples/BGL_OpenMesh/PolyMesh.cpp b/BGL/examples/BGL_OpenMesh/PolyMesh.cpp index db92203be34..aad1c35ff62 100644 --- a/BGL/examples/BGL_OpenMesh/PolyMesh.cpp +++ b/BGL/examples/BGL_OpenMesh/PolyMesh.cpp @@ -9,17 +9,20 @@ #include #include #include - +#include #include #include typedef CGAL::Exact_predicates_inexact_constructions_kernel Kernel; typedef OpenMesh::PolyMesh_ArrayKernelT Mesh; - +typedef CGAL::Surface_mesh SM; typedef boost::graph_traits::vertex_descriptor vertex_descriptor; +typedef boost::graph_traits::vertex_descriptor sm_vertex_descriptor; typedef boost::graph_traits::face_descriptor face_descriptor; typedef boost::graph_traits::halfedge_descriptor halfedge_descriptor; +typedef boost::graph_traits::halfedge_descriptor sm_halfedge_descriptor; +typedef boost::graph_traits::edge_descriptor sm_edge_descriptor; int main(int argc, char** argv ) { @@ -30,28 +33,68 @@ int main(int argc, char** argv ) CGAL::IO::read_polygon_mesh(filename, mesh); mesh.request_vertex_status(); + mesh.request_edge_status(); int i = 0; for(auto v : vertices(mesh)){ mesh.status(v).set_selected((i%2) == 0); ++i; - } + } + i = 0; + for(auto e : edges(mesh)){ + mesh.status(e).set_feature(i > 2); + ++i; + } OpenMesh::IO::write_mesh(mesh, outname, OpenMesh::IO::Options::Status); Mesh mesh2; OpenMesh::IO::Options options = OpenMesh::IO::Options::Status; bool read = OpenMesh::IO::read_mesh(mesh2, outname, options); - std::cout << num_vertices(mesh2) << std::endl; assert(read); + + SM sm; + std::map v2v; + auto v2vpmap = boost::make_assoc_property_map(v2v); + + std::map h2h; + auto h2hpmap = boost::make_assoc_property_map(h2h); + + CGAL::copy_face_graph(mesh, sm, CGAL::parameters::vertex_to_vertex_map(v2vpmap).halfedge_to_halfedge_map(h2hpmap)); + + std::map sm_selected_map; + auto sm_selected_pmap = boost::make_assoc_property_map(sm_selected_map); if(options.vertex_has_status()){ for(auto v : vertices(mesh2)){ + put(sm_selected_pmap, v2v[v], mesh2.status(v).selected()); std::cout << std::boolalpha << mesh2.status(v).selected() << std::endl; } }else{ std::cout << "no vertex status" << std::endl; } + + std::map sm_feature_map; + auto sm_feature_pmap = boost::make_assoc_property_map(sm_feature_map); + if(options.edge_has_status()){ + for(auto e : edges(mesh2)){ + auto sme = edge(h2h[halfedge(e,mesh2)], sm); + put(sm_feature_pmap, sme , mesh2.status(e).feature()); + std::cout << std::boolalpha << mesh2.status(e).feature() << std::endl; + } + }else{ + std::cout << "no edge status" << std::endl; + } + + std::cout << "vertex selection values:\n"; + for(auto v : vertices(sm)){ + std::cout << std::boolalpha << get(sm_selected_pmap, v) << std::endl; + } + + std::cout << "edge feature values:\n"; + for(auto e : edges(sm)){ + std::cout << std::boolalpha << get(sm_feature_pmap, e) << std::endl; + } return 0; }