Moka controlers
 All Classes Namespaces Files Functions Variables Typedefs Enumerator Friends Macros
parameter-object-ponderation.hh
Go to the documentation of this file.
1 /*
2  * lib-controler-gmap : Le contrôleur de 3-G-cartes, surcouche de lib-controler.
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-controler-gmap
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 PARAMETER_OBJECT_PONDERATION_HH
26 #define PARAMETER_OBJECT_PONDERATION_HH
27 //******************************************************************************
28 #include "controler-gmap-types.hh"
29 #include "parameter.hh"
30 #include "vertex.hh"
31 #include "transformation-matrix.hh"
32 //******************************************************************************
33 namespace GMap3d
34 {
36  {
37  public:
39  CParameterObjectPonderation(int ANbRef = 0);
42  virtual CParameter * copy() const;
44 
46 
47  virtual void save(std::ostream&);
48  virtual void load(std::istream&);
49  virtual void reinit();
50 
52 
54  virtual int getType() const;
55 
56  /*@name Paramètres de pondération :
57  */
59 
60  void setPonderationType(TPonderationType APonderationType);
62 
64  void setPonderationCenter(const CVertex & APonderationCenter);
65  CVertex getPonderationCenter() const;
66 
67  /* Vecteur directeur de l'axe de pondération, ou vecteur normal du plan
68  * de pondération (inutilisé pour la pondération centrale) :
69  */
70  void setPonderationVector(const CVertex & APonderationVector);
71  CVertex getPonderationVector() const;
72 
73  /* Activation / désactivation de l'étalonnage en entrée (avant l'application
74  * de la fonction de pondération :
75  */
76  void setPonderationStretchIn(bool AActive);
77  bool getPonderationStretchIn() const;
78 
80  void setPonderationStretchInMin(float AMin);
81  float getPonderationStretchInMin() const;
82 
83  void setPonderationStretchInMax(float AMax);
84  float getPonderationStretchInMax() const;
85 
87  void setPonderationFunctionType(TFunctionType AFunctionType);
88  TFunctionType getPonderationFunctionType() const;
89 
90  /* Activation / désactivation de l'étalonnage en sortie (après l'application
91  * de la fonction de pondération :
92  */
93  void setPonderationStretchOut(bool AActive);
94  bool getPonderationStretchOut() const;
95 
97  void setPonderationStretchOutMin(float AMin);
98  float getPonderationStretchOutMin() const;
99 
100  void setPonderationStretchOutMax(float AMax);
101  float getPonderationStretchOutMax() const;
102 
104 
105  private:
107  TPonderationType FPonderationType;
108  CVertex FPonderationCenter;
109  CVertex FPonderationVector;
110  bool FPonderationStretchIn;
111  float FPonderationStretchInMin, FPonderationStretchInMax;
112  TFunctionType FPonderationFunctionType;
113  bool FPonderationStretchOut;
114  float FPonderationStretchOutMin, FPonderationStretchOutMax;
115  };
116 
117 } // namespace GMap3d
118 //******************************************************************************
119 #endif // PARAMETER_OBJECT_PONDERATION_HH
120 //******************************************************************************