QGpCoreWave/TiltPath.h
Go to the documentation of this file.
00001 /***************************************************************************
00002 **
00003 **  This file is part of QGpCoreWave.
00004 **
00005 **  This library is free software; you can redistribute it and/or
00006 **  modify it under the terms of the GNU Lesser General Public
00007 **  License as published by the Free Software Foundation; either
00008 **  version 2.1 of the License, or (at your option) any later version.
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 Lesser General Public
00013 **  License for more details.
00014 **
00015 **  You should have received a copy of the GNU Lesser General Public
00016 **  License along with this library; if not, write to the Free Software
00017 **  Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
00018 **
00019 **  See http://www.geopsy.org for more information.
00020 **
00021 **  Created : 2008-08-06
00022 **  Authors :
00023 **    Marc Wathelet
00024 **    Marc Wathelet (LGIT, Grenoble, France)
00025 **
00026 ***************************************************************************/
00027 
00028 #ifndef TILTPATH_H
00029 #define TILTPATH_H
00030 
00031 #include <QGpCoreTools.h>
00032 
00033 namespace QGpCoreWave {
00034 
00035 class TiltPath
00036 {
00037 public:
00038   double time() const {return _dt;}
00039   double abscissa(int iLayer) const {return _x[iLayer];}
00040 protected:
00041   friend class TiltNode;
00042   TiltPath();
00043 
00044   inline void setOrigin(double x0);
00045   double origin() const {return _x[0];}
00046 
00047   inline void setDeepestLayer(int toLayer);
00048   inline void setIntercept(int iLayer, double x, double dt);
00049 private:
00050   QVector<double> _x;
00051   double _dt;
00052 };
00053 
00054 inline void TiltPath::setOrigin(double x0)
00055 {
00056   TRACE;
00057   _x[0]=x0;
00058 }
00059 
00060 inline void TiltPath::setDeepestLayer(int toLayer)
00061 {
00062   TRACE;
00063   _x.resize(toLayer+1);
00064 }
00065 
00066 inline void TiltPath::setIntercept(int iLayer, double x, double dt)
00067 {
00068   TRACE;
00069   _x[iLayer]=x;
00070   _dt+=dt;
00071 }
00072 
00073 } // namespace QGpCoreWave
00074 
00075 #endif // TILTPATH_H
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Defines