OLD IMPLEMENTATION, NOT USED ANYMORE! #ifndef FILE_SPLINEGEOMETRY2 #define FILE_SPLINEGEOMETRY2 /**************************************************************************/ /* File: splinegeometry2.hpp */ /* Author: Joachim Schoeberl */ /* Date: 24. Jul. 96 */ /**************************************************************************/ #include "splinegeometry.hpp" #ifdef OLDSPLINEGEOMETRY /// extern void LoadBoundarySplines (const char * filename, Array<GeomPoint2d> & geompoints, Array<SplineSegment*> & splines, double & elto0); /// extern void PartitionBoundary (const Array<SplineSegment*> & splines, double h, double elto0, Mesh & mesh2d); class CSGScanner; class SplineGeometry2d { Array<GeomPoint2d> geompoints; Array<SplineSegment*> splines; double elto0; private: void AppendSegment(SplineSegment * spline, const int leftdomain, const int rightdomain, const int bc, const double reffac, const bool hprefleft, const bool hprefright, const int copyfrom); public: ~SplineGeometry2d(); void Load (const char * filename); void CSGLoad (CSGScanner & scan); void PartitionBoundary (double h, Mesh & mesh2d); void CopyEdgeMesh (int from, int to, Mesh & mesh2d, Point3dTree & searchtree); const Array<SplineSegment*> & GetSplines () const { return splines; } int GetNSplines (void) const { return splines.Size(); } string GetSplineType (const int i) const { return splines[i]->GetType(); } SplineSegment & GetSpline (const int i) {return *splines[i];} const SplineSegment & GetSpline (const int i) const {return *splines[i];} void GetBoundingBox (Box<2> & box) const; int GetNP () const { return geompoints.Size(); } const GeomPoint2d & GetPoint(int i) const { return geompoints[i]; } void SetGrading (const double grading); void AppendPoint (const double x, const double y, const double reffac = 1., const bool hpref = false); void AppendLineSegment (const int n1, const int n2, const int leftdomain, const int rightdomain, const int bc = -1, const double reffac = 1., const bool hprefleft = false, const bool hprefright = false, const int copyfrom = -1); void AppendSplineSegment (const int n1, const int n2, const int n3, const int leftdomain, const int rightdomain, const int bc = -1, const double reffac = 1., const bool hprefleft = false, const bool hprefright = false, const int copyfrom = -1); void AppendCircleSegment (const int n1, const int n2, const int n3, const int leftdomain, const int rightdomain, const int bc = -1, const double reffac = 1., const bool hprefleft = false, const bool hprefright = false, const int copyfrom = -1); void AppendDiscretePointsSegment (const Array< Point<2> > & points, const int leftdomain, const int rightdomain, const int bc = -1, const double reffac = 1., const bool hprefleft = false, const bool hprefright = false, const int copyfrom = -1); }; void MeshFromSpline2D (SplineGeometry2d & geometry, shared_ptr<Mesh> & mesh, MeshingParameters & mp); #endif #endif