CGAL get intersection primitive id

2 篇文章 0 订阅
   
  #include <iostream>
   
  #include <CGAL/Simple_cartesian.h>
  #include <CGAL/AABB_tree.h>
  #include <CGAL/AABB_traits.h>
  #include <CGAL/Polyhedron_3.h>
  #include <CGAL/AABB_polyhedron_triangle_primitive.h>
   
  typedef CGAL::Simple_cartesian<double> K;
  typedef K::Point_3 Point;
  typedef K::Plane_3 Plane;
  typedef K::Vector_3 Vector;
  typedef K::Segment_3 Segment;
  typedef CGAL::Polyhedron_3<K> Polyhedron;
  typedef CGAL::AABB_polyhedron_triangle_primitive<K,Polyhedron> Primitive;
  typedef CGAL::AABB_traits<K, Primitive> Traits;
  typedef CGAL::AABB_tree<Traits> Tree;
  typedef Tree::Object_and_primitive_id Object_and_primitive_id;
  typedef Tree::Primitive_id Primitive_id;
   
  int main()
  {
  Point p(1.0, 0.0, 0.0);
  Point q(0.0, 1.0, 0.0);
  Point r(0.0, 0.0, 1.0);
  Point s(0.0, 0.0, 0.0);
  Polyhedron polyhedron;
  polyhedron.make_tetrahedron(p, q, r, s);
   
  // constructs AABB tree
  Tree tree(polyhedron.facets_begin(),polyhedron.facets_end());
   
  // constructs segment query
  Point a(-0.2, 0.2, -0.2);
  Point b(1.3, 0.2, 1.3);
  Segment segment_query(a,b);
   
  // tests intersections with segment query
  if(tree.do_intersect(segment_query))
  std::cout << "intersection(s)" << std::endl;
  else
  std::cout << "no intersection" << std::endl;
   
  // computes #intersections with segment query
  std::cout << tree.number_of_intersected_primitives(segment_query)
  << " intersection(s)" << std::endl;
   
  // computes first encountered intersection with segment query
  // (generally a point)
  boost::optional<Object_and_primitive_id> intersection =
  tree.any_intersection(segment_query);
  if(intersection)
  {
  // gets intersection object
  Object_and_primitive_id op = *intersection;
  CGAL::Object object = op.first;
  Point point;
  if(CGAL::assign(point,object))
  std::cout << "intersection object is a point" << std::endl;
  }
   
  // computes all intersections with segment query (as pairs object - primitive_id)
  std::list<Object_and_primitive_id> intersections;
  tree.all_intersections(segment_query, std::back_inserter(intersections));
   
  // computes all intersected primitives with segment query as primitive ids
  std::list<Primitive_id> primitives;
  tree.all_intersected_primitives(segment_query, std::back_inserter(primitives));
   
  // constructs plane query
  Vector vec(0.0,0.0,1.0);
  Plane plane_query(a,vec);
   
  // computes first encountered intersection with plane query
  // (generally a segment)
  intersection = tree.any_intersection(plane_query);
  if(intersection)
  {
  // gets intersection object
  Object_and_primitive_id op = *intersection;
  CGAL::Object object = op.first;
  Segment segment;
  if(CGAL::assign(segment,object))
  std::cout << "intersection object is a segment" << std::endl;
  }
   
  return EXIT_SUCCESS;
  }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值