// ====================================================================== // // Copyright (c) 1999 The CGAL Consortium // // This software and related documentation is part of an INTERNAL release // of the Computational Geometry Algorithms Library (CGAL). It is not // intended for general use. // // ---------------------------------------------------------------------- // // release : // release_date : // // file : Direction_3.h // package : _3 // revision : $Revision$ // revision_date : $Date$ // author(s) : Andreas Fabri // Stefan Schirra // // coordinator : MPI, Saarbruecken () // ====================================================================== #ifndef CGAL_DIRECTION_3_H #define CGAL_DIRECTION_3_H #ifndef CGAL_REP_CLASS_DEFINED #error no representation class defined #endif #if defined CGAL_HOMOGENEOUS_H || defined CGAL_SIMPLE_HOMOGENEOUS_H #include #endif #if defined CGAL_CARTESIAN_H || defined CGAL_SIMPLE_CARTESIAN_H #include #endif #include CGAL_BEGIN_NAMESPACE template class Direction_3 : public R_::Direction_3_base { public: typedef R_ R; typedef typename R::RT RT; typedef typename R::FT FT; typedef typename R::Direction_3_base RDirection_3; typedef typename R::Vector_3_base RVector_3; Direction_3() {} Direction_3(const CGAL::Direction_3& d) : RDirection_3( static_cast(d) ) {} Direction_3(const RDirection_3& d) : RDirection_3(d) {} Direction_3(const RVector_3& v) : RDirection_3(v) {} Direction_3(const RT& hx, const RT& hy, const RT& hz) : RDirection_3(hx, hy, hz) {} bool operator==(const CGAL::Direction_3 & d) const { return RDirection_3::operator==(d); } bool operator!=(const CGAL::Direction_3 & d) const { return !(*this == d); } CGAL::Vector_3 vector() const { return static_cast >(RDirection_3::to_vector()); } CGAL::Vector_3 to_vector() const { return static_cast >(RDirection_3::to_vector()); } CGAL::Direction_3 transform(const CGAL::Aff_transformation_3 & t) const { return RDirection_3::transform(t); } CGAL::Direction_3 operator-() const { return RDirection_3::operator-(); } RT delta(int i) const { return RDirection_3::delta(i); } RT dx() const { return RDirection_3::dx(); } RT dy() const { return RDirection_3::dy(); } RT dz() const { return RDirection_3::dz(); } }; #ifndef CGAL_NO_OSTREAM_INSERT_DIRECTION_3 template < class R > std::ostream& operator<<(std::ostream& os, const Direction_3& d) { typedef typename R::Direction_3_base RDirection_3; return os << static_cast(d); } #endif // CGAL_NO_OSTREAM_INSERT_DIRECTION_3 #ifndef CGAL_NO_ISTREAM_EXTRACT_DIRECTION_3 template < class R > std::istream& operator>>(std::istream& is, Direction_3& p) { typedef typename R::Direction_3_base RDirection_3; return is >> static_cast(p); } #endif // CGAL_NO_ISTREAM_EXTRACT_DIRECTION_3 CGAL_END_NAMESPACE #endif // CGAL_DIRECTION_3_H