⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 circular_arc_point_2.h

📁 很多二维 三维几何计算算法 C++ 类库
💻 H
字号:
// Copyright (c) 2003-2006  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: svn+ssh://scm.gforge.inria.fr/svn/cgal/branches/CGAL-3.3-branch/Circular_kernel_2/include/CGAL/Circular_kernel_2/Circular_arc_point_2.h $// $Id: Circular_arc_point_2.h 33659 2006-08-24 14:20:34Z pmachado $//// Author(s)     : Monique Teillaud, Sylvain Pion// Partially supported by the IST Programme of the EU as a Shared-cost// RTD (FET Open) Project under Contract No  IST-2000-26473 // (ECG - Effective Computational Geometry for Curves and Surfaces) // and a STREP (FET Open) Project under Contract No  IST-006413 // (ACS -- Algorithms for Complex Shapes)#ifndef CGAL_CIRCULAR_KERNEL_CIRCULAR_ARC_POINT_2_H#define CGAL_CIRCULAR_KERNEL_CIRCULAR_ARC_POINT_2_H#include <iostream>#include <cassert>#include <CGAL/Bbox_2.h>#include <CGAL/Interval_nt.h>#include <boost/type_traits/is_same.hpp>#include <CGAL/global_functions_on_circle_2.h>namespace CGAL {namespace CGALi {  template <class CK >  class Circular_arc_point_2  {    typedef typename CK::FT                      FT;    typedef typename CK::Root_of_2               Root_of_2;    typedef typename CK::Point_2                 Point_2;      public: // fixme ?    typedef typename CK::Root_for_circles_2_2 Root_for_circles_2_2;    typedef typename CK::template Handle<Root_for_circles_2_2>::type  Base;        Circular_arc_point_2()     {}        Circular_arc_point_2(const Root_for_circles_2_2 & np)      :  _p(np)    {}    Circular_arc_point_2(const Point_2 & p)      :  _p(p.x(),p.y()/*,1,1,-p.x()-p.y()*/)    {}    const Root_of_2 & x() const     { return get(_p).x(); }        const Root_of_2 & y() const     { return get(_p).y(); }        CGAL::Bbox_2 bbox() const    {      return get(_p).bbox();    }    const Root_for_circles_2_2 & coordinates() const     { return get(_p); }    bool equal_ref(const Circular_arc_point_2 &p) const    {      return CGAL::identical(_p, p._p);          }  private:    Base _p;  };  template < typename CK >  std::ostream &  print(std::ostream & os, const Circular_arc_point_2<CK> &p)  {    return os << "CirclArcEndPoint_2(" << std::endl	      << p.x() << ", " << p.y() << ')';  }} // namespace CGALi} // namespace CGAL#endif // CGAL_CIRCULAR_KERNEL_CIRCULAR_ARC_POINT_2_H

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -