Moka libraries
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros
edge-intersection.hh
Go to the documentation of this file.
1 /*
2  * lib-corefinement : Opérations de corafinement.
3  * Copyright (C) 2004, Moka Team, Université de Poitiers, Laboratoire SIC
4  * http://www.sic.sp2mi.univ-poitiers.fr/
5  * Copyright (C) 2009, Guillaume Damiand, CNRS, LIRIS,
6  * guillaume.damiand@liris.cnrs.fr, http://liris.cnrs.fr/
7  *
8  * This file is part of lib-corefinement
9  *
10  * This program is free software: you can redistribute it and/or modify
11  * it under the terms of the GNU Lesser General Public License as published by
12  * the Free Software Foundation, either version 3 of the License, or
13  * (at your option) any later version.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU Lesser General Public License for more details.
19  *
20  * You should have received a copy of the GNU Lesser General Public License
21  * along with this program. If not, see <http://www.gnu.org/licenses/>.
22  */
23 
24 #ifndef EDGE_INTERSECTION_HH
25 #define EDGE_INTERSECTION_HH
26 
27 #include <iostream>
28 
29 #include "inline-macro.hh"
30 #include "g-map-vertex.hh"
31 
32 namespace GMap3d
33 {
37 
48  std::ostream & operator << (std::ostream & AStream, TPositionOnEdge APos);
49 
51 
57  {
58  public:
59 
64 
73  CEdgeIntersection(CDart * AIntersectedCell = NULL,
74  TCoordinate AIntersectionParameter = 0.0,
75  CVertex const & AIntersectionPoint = ORIGIN,
76  int AIntersectedCellDimension = 0,
77  TPositionOnEdge AIntersectionPosition = EP_OutOfEdge);
78 
80 
85 
86  CDart * getCell() const;
87  TCoordinate getParameter() const;
88  CVertex const & getPoint() const;
89  int getCellDimension() const;
91 
92  void setCell(CDart * ADart);
93  void setParameter(TCoordinate AParameter);
94  void setPoint(CVertex const & APoint);
95  void setCellDimension(int ADimension);
96  void setPosition(TPositionOnEdge APosition);
97 
99 
100  private:
101 
106 
107  CDart * FIntersectedCell;
108 
109  TCoordinate FIntersectionParameter;
110 
111  CVertex FIntersectionPoint;
112 
113  int FIntersectedCellDimension;
114 
115  TPositionOnEdge FIntersectionPosition;
116 
118  };
119 
120  std::ostream& operator<<(std::ostream & AStream,
121  const CEdgeIntersection & AInter);
122 
123 } // namespace GMap3d
124 
125 #include INCLUDE_INLINE("edge-intersection.icc")
126 
127 #endif