00001 /* 00002 * lib-controler-gmap : Le contrôleur de 3-G-cartes, surcouche de lib-controler. 00003 * Copyright (C) 2004, Moka Team, Université de Poitiers, Laboratoire SIC 00004 * http://www.sic.sp2mi.univ-poitiers.fr/ 00005 * Copyright (C) 2009, Guillaume Damiand, CNRS, LIRIS, 00006 * guillaume.damiand@liris.cnrs.fr, http://liris.cnrs.fr/ 00007 * 00008 * This file is part of lib-controler-gmap 00009 * 00010 * This program is free software: you can redistribute it and/or modify 00011 * it under the terms of the GNU Lesser General Public License as published by 00012 * the Free Software Foundation, either version 3 of the License, or 00013 * (at your option) any later version. 00014 * 00015 * This program is distributed in the hope that it will be useful, 00016 * but WITHOUT ANY WARRANTY; without even the implied warranty of 00017 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 00018 * GNU Lesser General Public License for more details. 00019 * 00020 * You should have received a copy of the GNU Lesser General Public License 00021 * along with this program. If not, see <http://www.gnu.org/licenses/>. 00022 */ 00023 00024 //****************************************************************************** 00025 #ifndef PARAMETER_NORMAL_VECTOR_HH 00026 #define PARAMETER_NORMAL_VECTOR_HH 00027 //****************************************************************************** 00028 #include "parameter.hh" 00029 //****************************************************************************** 00041 namespace GMap3d 00042 { 00043 class CParameterNormalVector : public CParameter 00044 { 00045 public: 00050 00053 CParameterNormalVector(int ANbRef = 0); 00054 CParameterNormalVector(const CParameterNormalVector &); 00055 CParameter * copy() const; 00056 00059 virtual ~CParameterNormalVector(); 00060 00062 00067 00072 virtual void save(std::ostream&); 00073 00078 virtual void load(std::istream&); 00079 00084 virtual void reinit(); 00085 00087 00092 bool getShowAllNormals() const; 00093 void setShowAllNormals(bool AShow); 00095 00100 int getLWNormalVector() const; 00101 void setLWNormalVector(int); 00103 00108 float getLGNormalVector() const; 00109 void setLGNormalVector(float); 00111 00116 float getCLNormalVector(int AIndice) const; 00117 const float * getCLNormalVector() const; 00118 void setCLNormalVector(int AIndice, float AValue); 00119 void setCLNormalVector(float AValue0, 00120 float AValue1, float AValue2); 00121 void setCLNormalVector(const float ATab[3]); 00123 00125 virtual int getType() const; 00126 00128 friend std::ostream& 00129 operator<<(std::ostream&, const CParameterNormalVector &); 00130 00131 friend std::istream& 00132 operator>>(std::istream&, CParameterNormalVector &); 00133 00134 private: 00136 bool FAll; 00137 00139 int FLWNormalVector; 00140 00142 float FLGNormalVector; 00143 00145 float FCLNormalVector[3]; 00146 }; 00147 00148 } // namespace GMap3d 00149 //****************************************************************************** 00150 #endif // PARAMETER_NORMAL_VECTOR_HH 00151 //******************************************************************************