BWAPI
|
00001 // Copyright (c) 2000 Utrecht University (The Netherlands), 00002 // ETH Zurich (Switzerland), Freie Universitaet Berlin (Germany), 00003 // INRIA Sophia-Antipolis (France), Martin-Luther-University Halle-Wittenberg 00004 // (Germany), Max-Planck-Institute Saarbruecken (Germany), RISC Linz (Austria), 00005 // and Tel-Aviv University (Israel). All rights reserved. 00006 // 00007 // This file is part of CGAL (www.cgal.org); you can redistribute it and/or 00008 // modify it under the terms of the GNU Lesser General Public License as 00009 // published by the Free Software Foundation; version 2.1 of the License. 00010 // See the file LICENSE.LGPL distributed with CGAL. 00011 // 00012 // Licensees holding a valid commercial license may use this file in 00013 // accordance with the commercial license agreement provided with the software. 00014 // 00015 // This file is provided AS IS with NO WARRANTY OF ANY KIND, INCLUDING THE 00016 // WARRANTY OF DESIGN, MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. 00017 // 00018 // $URL: svn+ssh://scm.gforge.inria.fr/svn/cgal/branches/CGAL-3.5-branch/Cartesian_kernel/include/CGAL/Cartesian/Point_2.h $ 00019 // $Id: Point_2.h 45156 2008-08-26 13:40:26Z spion $ 00020 // 00021 // 00022 // Author(s) : Andreas Fabri, Herve Bronnimann 00023 00024 #ifndef CGAL_CARTESIAN_POINT_2_H 00025 #define CGAL_CARTESIAN_POINT_2_H 00026 00027 #include <CGAL/Origin.h> 00028 00029 CGAL_BEGIN_NAMESPACE 00030 00031 template < class R_ > 00032 class PointC2 00033 { 00034 typedef PointC2<R_> Self; 00035 typedef typename R_::FT FT; 00036 typedef typename R_::Vector_2 Vector_2; 00037 typedef typename R_::Point_2 Point_2; 00038 00039 // We do not use reference counting here as it is done at the Vector_2 level. 00040 Vector_2 base; 00041 00042 public: 00043 00044 typedef typename Vector_2::Cartesian_const_iterator Cartesian_const_iterator; 00045 00046 typedef R_ R; 00047 00048 PointC2() {} 00049 00050 PointC2(const Origin &) 00051 : base(NULL_VECTOR) {} 00052 00053 PointC2(const FT &x, const FT &y) 00054 : base(x, y) {} 00055 00056 PointC2(const FT &hx, const FT &hy, const FT &hw) 00057 : base(hx, hy, hw) {} 00058 00059 const FT& x() const 00060 { 00061 return base.x(); 00062 } 00063 00064 const FT& y() const 00065 { 00066 return base.y(); 00067 } 00068 00069 const FT& hx() const 00070 { 00071 return base.hx(); 00072 } 00073 const FT& hy() const 00074 { 00075 return base.hy(); 00076 } 00077 const FT& hw() const 00078 { 00079 return base.hw(); 00080 } 00081 00082 Cartesian_const_iterator cartesian_begin() const 00083 { 00084 return base.cartesian_begin(); 00085 } 00086 00087 Cartesian_const_iterator cartesian_end() const 00088 { 00089 return base.cartesian_end(); 00090 } 00091 00092 typename R_::Boolean operator==(const PointC2 &p) const 00093 { 00094 return base == p.base; 00095 } 00096 typename R_::Boolean operator!=(const PointC2 &p) const 00097 { 00098 return !(*this == p); 00099 } 00100 00101 }; 00102 00103 CGAL_END_NAMESPACE 00104 00105 #endif // CGAL_CARTESIAN_POINT_2_H