picking geometry with mesh (CSG only by now)

This commit is contained in:
Joachim Schöberl 2018-05-12 09:16:02 +02:00
parent ec1bcd8799
commit d9219e6f05
6 changed files with 33 additions and 105 deletions

View File

@ -19,6 +19,6 @@ endif(USE_GUI)
install(FILES install(FILES
geom2dmesh.hpp geometry2d.hpp spline2d.hpp geom2dmesh.hpp geometry2d.hpp spline2d.hpp
splinegeometry2.hpp vsgeom2d.hpp vsgeom2d.hpp
DESTINATION ${NG_INSTALL_DIR_INCLUDE}/geom2d COMPONENT netgen_devel DESTINATION ${NG_INSTALL_DIR_INCLUDE}/geom2d COMPONENT netgen_devel
) )

View File

@ -1,103 +0,0 @@
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

View File

@ -10,6 +10,17 @@ namespace netgen
GeometryRegister :: ~GeometryRegister() GeometryRegister :: ~GeometryRegister()
{ ; } { ; }
shared_ptr<NetgenGeometry> GeometryRegisterArray :: LoadFromMeshFile (istream & ist) const
{
for (int i = 0; i < Size(); i++)
{
NetgenGeometry * hgeom = (*this)[i]->LoadFromMeshFile (ist);
if (hgeom)
return shared_ptr<NetgenGeometry>(hgeom);
}
return nullptr;
}

View File

@ -49,6 +49,8 @@ namespace netgen
for (int i = 0; i < Size(); i++) for (int i = 0; i < Size(); i++)
delete (*this)[i]; delete (*this)[i];
} }
virtual shared_ptr<NetgenGeometry> LoadFromMeshFile (istream & ist) const;
}; };
// extern DLL_HEADER Array<GeometryRegister*> geometryregister; // extern DLL_HEADER Array<GeometryRegister*> geometryregister;

View File

@ -1314,6 +1314,23 @@ namespace netgen
archive & materials & bcnames & cd2names; archive & materials & bcnames & cd2names;
archive & *ident; archive & *ident;
// archive geometry
if (archive.Output())
{
ostringstream ost;
if (geometry)
geometry -> SaveToMeshFile (ost);
archive << ost.str();
}
else
{
string str;
archive & str;
istringstream ist(str);
geometry = geometryregister.LoadFromMeshFile (ist);
}
if (archive.Input()) if (archive.Input())
{ {

View File

@ -154,7 +154,8 @@ namespace netgen
& edgenr & singedge_left & singedge_right & edgenr & singedge_left & singedge_right
& si & cd2i & domin & domout & tlosurf & si & cd2i & domin & domout & tlosurf
& surfnr1 & surfnr2 & surfnr1 & surfnr2
& bcname; & bcname
& epgeominfo[0].edgenr & epgeominfo[1].edgenr;
} }