// Copyright (c) 2009 INRIA Sophia-Antipolis (France). // All rights reserved. // // This file is part of CGAL (www.cgal.org); you may redistribute it under // the terms of the Q Public License version 1.0. // See the file LICENSE.QPL distributed with CGAL. // // Licensees holding a valid commercial license may use this file in // accordance with the commercial license agreement provided with the software. // // This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE // WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. // // $URL: $ // $Id: $ // // // Author(s) : Stéphane Tayeb, Pierre Alliez // //****************************************************************************** // File Description : // //****************************************************************************** #ifndef AABB_POLYHEDRON_TRIANGLE_PRIMITIVE_H_ #define AABB_POLYHEDRON_TRIANGLE_PRIMITIVE_H_ namespace CGAL { /** * @class AABB_polyhedron_triangle_primitive * * */ template class AABB_polyhedron_triangle_primitive { public: /// AABBTrianglePrimitive types typedef typename GeomTraits::Triangle_3 Object; typedef typename Polyhedron_::Facet_const_iterator Id; /// Self typedef AABB_polyhedron_triangle_primitive Self; /// Constructors //AABB_polyhedron_triangle_primitive() { }; AABB_polyhedron_triangle_primitive(const Id& handle) : m_handle(handle) { }; // Default copy constructor and assignment operator are ok /// Destructor ~AABB_polyhedron_triangle_primitive() {}; /// Returns by constructing on the fly the geometric object wrapped by the primitive Object object() const; /// Returns the identifier const Id id() const { return m_handle; } private: /// The handle Id m_handle; }; // end class AABB_polyhedron_triangle_primitive template typename AABB_polyhedron_triangle_primitive::Object AABB_polyhedron_triangle_primitive::object() const { typedef typename GT::Point_3 Point; typedef typename GT::Triangle_3 Triangle; const Point& a = m_handle->halfedge()->vertex()->point(); const Point& b = m_handle->halfedge()->next()->vertex()->point(); const Point& c = m_handle->halfedge()->next()->next()->vertex()->point(); return Object(a,b,c); } } // end namespace CGAL #endif // AABB_POLYHEDRON_TRIANGLE_PRIMITIVE_H_