/usr/include/qgis/LinTriangleInterpolator.h is in libqgis-dev 2.18.17+dfsg-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 | /***************************************************************************
LinTriangleInterpolator.h - description
-------------------
copyright : (C) 2004 by Marco Hugentobler
email : mhugent@geo.unizh.ch
***************************************************************************/
/***************************************************************************
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
***************************************************************************/
#ifndef LINTRIANGLEINTERPOLATOR_H
#define LINTRIANGLEINTERPOLATOR_H
#include "TriangleInterpolator.h"
#include "DualEdgeTriangulation.h"
/** \ingroup analysis
* LinTriangleInterpolator is a class which interpolates linearly on a triangulation*/
class ANALYSIS_EXPORT LinTriangleInterpolator : public TriangleInterpolator
{
public:
/** Default constructor*/
LinTriangleInterpolator();
/** Constructor with reference to a DualEdgeTriangulation object*/
LinTriangleInterpolator( DualEdgeTriangulation* tin );
/** Destructor*/
virtual ~LinTriangleInterpolator();
/** Calculates the normal vector and assigns it to vec*/
virtual bool calcNormVec( double x, double y, Vector3D* result ) override;
/** Performs a linear interpolation in a triangle and assigns the x-,y- and z-coordinates to point*/
virtual bool calcPoint( double x, double y, Point3D* result ) override;
/** Returns a pointer to the current Triangulation object*/
virtual DualEdgeTriangulation* getTriangulation() const;
/** Sets a Triangulation*/
virtual void setTriangulation( DualEdgeTriangulation* tin );
protected:
DualEdgeTriangulation* mTIN;
/** Calculates the first derivative with respect to x for a linear surface and assigns it to vec*/
virtual bool calcFirstDerX( double x, double y, Vector3D* result );
/** Calculates the first derivative with respect to y for a linear surface and assigns it to vec*/
virtual bool calcFirstDerY( double x, double y, Vector3D* result );
};
inline LinTriangleInterpolator::LinTriangleInterpolator()
: mTIN( nullptr )
{
}
inline LinTriangleInterpolator::LinTriangleInterpolator( DualEdgeTriangulation* tin ): mTIN( tin )
{
}
inline LinTriangleInterpolator::~LinTriangleInterpolator()
{
}
inline DualEdgeTriangulation* LinTriangleInterpolator::getTriangulation() const
{
return mTIN;
}
inline void LinTriangleInterpolator::setTriangulation( DualEdgeTriangulation* tin )
{
mTIN = tin;
}
#endif
|