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

📄 construct_point_2.h

📁 很多二维 三维几何计算算法 C++ 类库
💻 H
字号:
// Copyright (c) 1997-2001  Utrecht University (The Netherlands),// ETH Zurich (Switzerland), Freie Universitaet Berlin (Germany),// INRIA Sophia-Antipolis (France), Martin-Luther-University Halle-Wittenberg// (Germany), Max-Planck-Institute Saarbruecken (Germany), RISC Linz (Austria),// and Tel-Aviv University (Israel).  All rights reserved.//// This file is part of CGAL (www.cgal.org); you can redistribute it and/or// modify it under the terms of the GNU Lesser General Public License as// published by the Free Software Foundation; version 2.1 of the License.// See the file LICENSE.LGPL 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/Optimisation_basic/include/CGAL/Optimisation/Construct_point_2.h $// $Id: Construct_point_2.h 35787 2007-01-24 17:16:05Z spion $// //// Author(s)     : Sven Schoenherr <sven@inf.ethz.ch>#ifndef CGAL_OPTIMISATION_CONSTRUCT_POINT_2_H#define CGAL_OPTIMISATION_CONSTRUCT_POINT_2_H#include <CGAL/Point_2.h>#include <vector>#include <functional>#include <iterator>CGAL_BEGIN_NAMESPACE// Class declaration// =================template < class K >class _Construct_point_2;// Class interface// ===============template < class K_ >class _Construct_point_2 {  public:    // self    typedef  K_                         K;    typedef  _Construct_point_2<K>      Self;    // types    typedef  typename K::Point_2        Point;    // creation    _Construct_point_2( ) { }    // operations    template < class InputIterator >    Point    operator() ( int, InputIterator first, InputIterator last) const    {        InputIterator i(first);	typename K::RT x = *(i++);	typename K::RT y = *(i++);	typedef typename K::Construct_point_2 Construct_point_2;	Construct_point_2 construct_point_2 = K().construct_point_2_object();	if (i==last) {	    return construct_point_2(x,y);	} else {	    typename K::RT h = *(i++);	    return construct_point_2(x,y,h); 	}    }};CGAL_END_NAMESPACE#endif // CGAL_OPTIMISATION_CONSTRUCT_POINT_2_H// ===== EOF ==================================================================

⌨️ 快捷键说明

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