// ====================================================================== // // 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 : Circle_2.h // package : _2 // revision : $Revision$ // revision_date : $Date$ // author(s) : Andreas Fabri // Sven Schoenherr // // coordinator : MPI, Saarbruecken () // ====================================================================== #ifndef CGAL_CIRCLE_2_H #define CGAL_CIRCLE_2_H #include CGAL_BEGIN_NAMESPACE template class Circle_2 : public R_::Circle_2_base { public: typedef R_ R; typedef typename R::RT RT; typedef typename R::FT FT; typedef typename R::Circle_2_base RCircle_2; Circle_2() : RCircle_2() {} Circle_2(const CGAL::Circle_2 &t) : RCircle_2((RCircle_2&)t) {} Circle_2(const RCircle_2& t) : RCircle_2(t) {} Circle_2(const CGAL::Point_2 ¢er, const FT &squared_radius, const Orientation &orientation) : RCircle_2(center, squared_radius, orientation) {} Circle_2(const CGAL::Point_2 ¢er, const FT &squared_radius) : RCircle_2(center, squared_radius, COUNTERCLOCKWISE) {} Circle_2(const CGAL::Point_2 &p, const CGAL::Point_2 &q, const CGAL::Point_2 &r) : RCircle_2(p,q,r) {} Circle_2(const CGAL::Point_2 & p, const CGAL::Point_2 & q, const Orientation &orientation) : RCircle_2(p,q,orientation) {} Circle_2(const CGAL::Point_2 & p, const CGAL::Point_2 & q) : RCircle_2(p,q,COUNTERCLOCKWISE) {} Circle_2(const CGAL::Point_2 & center, const Orientation& orientation) : RCircle_2(center,FT(0),orientation) {} Circle_2(const CGAL::Point_2 & center) : RCircle_2(center,FT(0),COUNTERCLOCKWISE) {} CGAL::Point_2 center() const { return RCircle_2::center(); } CGAL::Circle_2 orthogonal_transform(const CGAL::Aff_transformation_2 &t) const { return RCircle_2::orthogonal_transform(t); } CGAL::Circle_2 opposite() const { return CGAL::Circle_2(center(), squared_radius(), CGAL::opposite(orientation())); } }; CGAL_END_NAMESPACE #endif // CGAL_CIRCLE_2_H