00001 /*************************************************************************** 00002 ** 00003 ** This file is part of DinverDCCore. 00004 ** 00005 ** This file may be distributed and/or modified under the terms of the 00006 ** GNU General Public License version 2 or 3 as published by the Free 00007 ** Software Foundation and appearing in the file LICENSE.GPL included 00008 ** in the packaging of this file. 00009 ** 00010 ** This file is distributed in the hope that it will be useful, but WITHOUT 00011 ** ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 00012 ** FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 00013 ** more details. 00014 ** 00015 ** You should have received a copy of the GNU General Public License 00016 ** along with this program. If not, see <http://www.gnu.org/licenses/>. 00017 ** 00018 ** See http://www.geopsy.org for more information. 00019 ** 00020 ** Created: 2010-04-02 00021 ** Authors: 00022 ** Marc Wathelet (LGIT, Grenoble, France) 00023 ** 00024 ***************************************************************************/ 00025 00026 #ifndef PARAM3DGROUNDMODEL_H 00027 #define PARAM3DGROUNDMODEL_H 00028 00029 #include <DinverCore.h> 00030 00031 #include "DinverDCCoreDLLExport.h" 00032 00033 namespace DinverDCCore { 00034 00035 class ParamGroundModel; 00036 class GroundParameter; 00037 00038 class DINVERDCCORE_EXPORT Param3DGroundModel: public XMLClass 00039 { 00040 public: 00041 Param3DGroundModel(); 00042 Param3DGroundModel(const Param3DGroundModel& o); 00043 ~Param3DGroundModel(); 00044 00045 virtual const QString& xml_tagName() const {return xmlParam3DGroundModelTag;} 00046 static const QString xmlParam3DGroundModelTag; 00047 00048 void addModel(const ParamGroundModel& gm); 00049 void setCustomConditions(const QString& c) {_customConditions.setText(c);} 00050 int modelCount() const {return _models.count();} 00051 ParamGroundModel * model(int index) const {return _models.at(index);} 00052 00053 void initFinalProfiles(); 00054 void updateFinalProfiles(const GroundParameter * from=0); 00055 bool toParameters(RealSpace& ps) const; 00056 bool isValid() const; 00057 void humanInfo() const; 00058 protected: 00059 virtual void xml_writeChildren(XML_WRITECHILDREN_ARGS) const; 00060 virtual XMLMember xml_member(XML_MEMBER_ARGS); 00061 private: 00062 QVector<ParamGroundModel *> _models; 00063 ParamSpaceScript _customConditions; 00064 QHash<const ParamGroundModel *, int> _lookup; 00065 }; 00066 00067 } // namespace DinverDCCore 00068 00069 #endif // PARAM3DGROUNDMODEL_H