#include #include #include #include #include #include #include typedef CGAL::Simple_cartesian Kernel; typedef CGAL::Linear_cell_complex_traits<3, Kernel> LCC_traits; typedef CGAL::Linear_cell_complex_for_bgl_combinatorial_map_helper <2, 3, LCC_traits>::type LCC; typedef boost::graph_traits GraphTraits; typedef GraphTraits::vertex_descriptor vertex_descriptor; typedef GraphTraits::halfedge_descriptor halfedge_descriptor; typedef CGAL::Halfedge_around_target_iterator halfedge_around_target_iterator; template struct Source { const G* g; Source() : g(nullptr) {} Source(const G& g) : g(&g) {} typedef typename boost::graph_traits::vertex_descriptor result_type; typedef typename boost::graph_traits::halfedge_descriptor argument_type; result_type operator()(argument_type h) const { return source(h, *g); } }; int main(int argc, char** argv) { LCC lcc; CGAL::IO::read_polygon_mesh((argc>1)?argv[1]:CGAL::data_file_path("meshes/cube_poly.off"), lcc); GraphTraits::vertex_descriptor vd = *(vertices(lcc).first); typedef boost::transform_iterator,halfedge_around_target_iterator> adjacent_vertex_iterator; halfedge_around_target_iterator hb,he; std::tie(hb,he) = halfedges_around_target(halfedge(vd,lcc),lcc); adjacent_vertex_iterator avib, avie; avib = boost::make_transform_iterator(hb, Source(lcc)); avie = boost::make_transform_iterator(he, Source(lcc)); std::list V; std::copy(avib,avie, std::back_inserter(V)); return 0; }