mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-12 14:10:34 +05:00
74 lines
1.7 KiB
C++
74 lines
1.7 KiB
C++
/*
|
|
|
|
|
|
JS, Nov 2007
|
|
|
|
|
|
The 2D/3D template-base classes should go into the libsrc/gprim directory
|
|
|
|
in geom2d only 2D - Geometry classes (with material properties etc.)
|
|
|
|
|
|
*/
|
|
|
|
#include "spline.hpp"
|
|
|
|
|
|
#ifndef _FILE_SPLINEGEOMETRY
|
|
#define _FILE_SPLINEGEOMETRY
|
|
|
|
namespace netgen
|
|
{
|
|
|
|
|
|
template < int D >
|
|
class SplineGeometry
|
|
{
|
|
// protected:
|
|
public:
|
|
NgArray < GeomPoint<D> > geompoints;
|
|
NgArray < SplineSeg<D>* > splines;
|
|
|
|
SplineGeometry() : geompoints{}, splines{} { ; }
|
|
virtual DLL_HEADER ~SplineGeometry();
|
|
|
|
DLL_HEADER int Load (const NgArray<double> & raw_data, const int startpos = 0);
|
|
|
|
virtual void DoArchive(Archive& ar)
|
|
{
|
|
ar & geompoints & splines;
|
|
}
|
|
|
|
DLL_HEADER void GetRawData (NgArray<double> & raw_data) const;
|
|
|
|
|
|
const NgArray<SplineSeg<D>*> & GetSplines () const
|
|
{ return splines; }
|
|
|
|
int GetNSplines (void) const { return splines.Size(); }
|
|
string GetSplineType (const int i) const { return splines[i]->GetType(); }
|
|
SplineSeg<D> & GetSpline (const int i) {return *splines[i];}
|
|
const SplineSeg<D> & GetSpline (const int i) const {return *splines[i];}
|
|
|
|
DLL_HEADER void GetBoundingBox (Box<D> & box) const;
|
|
Box<D> GetBoundingBox () const
|
|
{ Box<D> box; GetBoundingBox (box); return box; }
|
|
|
|
int GetNP () const { return geompoints.Size(); }
|
|
const GeomPoint<D> & GetPoint(int i) const { return geompoints[i]; }
|
|
|
|
// void SetGrading (const double grading);
|
|
DLL_HEADER void AppendPoint (const Point<D> & p, const double reffac = 1., const bool hpref = false);
|
|
|
|
void AppendSegment(SplineSeg<D> * spline)
|
|
{
|
|
splines.Append (spline);
|
|
}
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
#endif // _FILE_SPLINEGEOMETRY
|