Moka libraries
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros
rounding-generic.hh
Go to the documentation of this file.
1 /*
2  * lib-rounding : Opérations de chamfreinage.
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-rounding
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 //******************************************************************************
25 #ifndef ROUNDING_GENERIC_HH
26 #define ROUNDING_GENERIC_HH
27 //******************************************************************************
28 namespace GMap3d
29 {
30  class CDart;
31  class CGMapGeneric;
32 
34  {
35  public:
37  CRoundingGeneric(CGMapGeneric* AMap);
38 
41 
50  void chamferCell(CDart* ADart, int ACellDim, int AMaxDim);
51 
59  void chamferVertex(CDart* ADart, int AMaxDim);
60 
68  void chamferEdge(CDart* ADart, int AMaxDim);
69 
70  protected:
71 
86  void addDartChain(CDart* ADart, int ADimMin, int ADimMax);
87 
100  void chamfreinLink(CDart* ADart1, CDart* ADart2,
101  int ADim, int ADimMin, int ADimMax);
102 
112  int getVertexRoundingDimension(CDart* ADart, int ACellDim);
113 
123  int getEdgeRoundingDimension(CDart* ADart, int ACellDim);
124 
130  void removeEdge(CDart* ADart);
131 
132  private:
133  CGMapGeneric* FMap;
134  };
135 }
136 //******************************************************************************
137 #endif // ROUNDING_GENERIC_HH
138 //******************************************************************************