mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-12 22:20:35 +05:00
* Enable Windows DLL / lib creation for the nglib system.
* Implemented by adding a dllexport / dllimport header for all exported functions to indicate to windows which functions are to be made available via the library. * System change driven via WIN32 define, making it transparent to Linux builds.
This commit is contained in:
parent
a42ecab606
commit
1f258e5dab
106
nglib/nglib.cpp
106
nglib/nglib.cpp
@ -63,7 +63,7 @@ using namespace netgen;
|
|||||||
namespace nglib
|
namespace nglib
|
||||||
{
|
{
|
||||||
// initialize, deconstruct Netgen library:
|
// initialize, deconstruct Netgen library:
|
||||||
void Ng_Init ()
|
DLL_HEADER void Ng_Init ()
|
||||||
{
|
{
|
||||||
mycout = &cout;
|
mycout = &cout;
|
||||||
myerr = &cerr;
|
myerr = &cerr;
|
||||||
@ -71,35 +71,35 @@ void Ng_Init ()
|
|||||||
testout = new ofstream ("test.out");
|
testout = new ofstream ("test.out");
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ng_Exit ()
|
DLL_HEADER void Ng_Exit ()
|
||||||
{
|
{
|
||||||
;
|
;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Ng_Mesh * Ng_NewMesh ()
|
DLL_HEADER Ng_Mesh * Ng_NewMesh ()
|
||||||
{
|
{
|
||||||
Mesh * mesh = new Mesh;
|
Mesh * mesh = new Mesh;
|
||||||
mesh->AddFaceDescriptor (FaceDescriptor (1, 1, 0, 1));
|
mesh->AddFaceDescriptor (FaceDescriptor (1, 1, 0, 1));
|
||||||
return (Ng_Mesh*)(void*)mesh;
|
return (Ng_Mesh*)(void*)mesh;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ng_DeleteMesh (Ng_Mesh * mesh)
|
DLL_HEADER void Ng_DeleteMesh (Ng_Mesh * mesh)
|
||||||
{
|
{
|
||||||
delete (Mesh*)mesh;
|
delete (Mesh*)mesh;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// feeds points, surface elements and volume elements to the mesh
|
// feeds points, surface elements and volume elements to the mesh
|
||||||
void Ng_AddPoint (Ng_Mesh * mesh, double * x)
|
DLL_HEADER void Ng_AddPoint (Ng_Mesh * mesh, double * x)
|
||||||
{
|
{
|
||||||
Mesh * m = (Mesh*)mesh;
|
Mesh * m = (Mesh*)mesh;
|
||||||
m->AddPoint (Point3d (x[0], x[1], x[2]));
|
m->AddPoint (Point3d (x[0], x[1], x[2]));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ng_AddSurfaceElement (Ng_Mesh * mesh, Ng_Surface_Element_Type et,
|
DLL_HEADER void Ng_AddSurfaceElement (Ng_Mesh * mesh, Ng_Surface_Element_Type et,
|
||||||
int * pi)
|
int * pi)
|
||||||
{
|
{
|
||||||
Mesh * m = (Mesh*)mesh;
|
Mesh * m = (Mesh*)mesh;
|
||||||
Element2d el (3);
|
Element2d el (3);
|
||||||
@ -110,8 +110,8 @@ void Ng_AddSurfaceElement (Ng_Mesh * mesh, Ng_Surface_Element_Type et,
|
|||||||
m->AddSurfaceElement (el);
|
m->AddSurfaceElement (el);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ng_AddVolumeElement (Ng_Mesh * mesh, Ng_Volume_Element_Type et,
|
DLL_HEADER void Ng_AddVolumeElement (Ng_Mesh * mesh, Ng_Volume_Element_Type et,
|
||||||
int * pi)
|
int * pi)
|
||||||
{
|
{
|
||||||
Mesh * m = (Mesh*)mesh;
|
Mesh * m = (Mesh*)mesh;
|
||||||
Element el (4);
|
Element el (4);
|
||||||
@ -124,24 +124,24 @@ void Ng_AddVolumeElement (Ng_Mesh * mesh, Ng_Volume_Element_Type et,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// ask for number of points, surface and volume elements
|
// ask for number of points, surface and volume elements
|
||||||
int Ng_GetNP (Ng_Mesh * mesh)
|
DLL_HEADER int Ng_GetNP (Ng_Mesh * mesh)
|
||||||
{
|
{
|
||||||
return ((Mesh*)mesh) -> GetNP();
|
return ((Mesh*)mesh) -> GetNP();
|
||||||
}
|
}
|
||||||
|
|
||||||
int Ng_GetNSE (Ng_Mesh * mesh)
|
DLL_HEADER int Ng_GetNSE (Ng_Mesh * mesh)
|
||||||
{
|
{
|
||||||
return ((Mesh*)mesh) -> GetNSE();
|
return ((Mesh*)mesh) -> GetNSE();
|
||||||
}
|
}
|
||||||
|
|
||||||
int Ng_GetNE (Ng_Mesh * mesh)
|
DLL_HEADER int Ng_GetNE (Ng_Mesh * mesh)
|
||||||
{
|
{
|
||||||
return ((Mesh*)mesh) -> GetNE();
|
return ((Mesh*)mesh) -> GetNE();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
// return point coordinates
|
// return point coordinates
|
||||||
void Ng_GetPoint (Ng_Mesh * mesh, int num, double * x)
|
DLL_HEADER void Ng_GetPoint (Ng_Mesh * mesh, int num, double * x)
|
||||||
{
|
{
|
||||||
const Point3d & p = ((Mesh*)mesh)->Point(num);
|
const Point3d & p = ((Mesh*)mesh)->Point(num);
|
||||||
x[0] = p.X();
|
x[0] = p.X();
|
||||||
@ -150,7 +150,7 @@ void Ng_GetPoint (Ng_Mesh * mesh, int num, double * x)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// return surface and volume element in pi
|
// return surface and volume element in pi
|
||||||
Ng_Surface_Element_Type
|
DLL_HEADER Ng_Surface_Element_Type
|
||||||
Ng_GetSurfaceElement (Ng_Mesh * mesh, int num, int * pi)
|
Ng_GetSurfaceElement (Ng_Mesh * mesh, int num, int * pi)
|
||||||
{
|
{
|
||||||
const Element2d & el = ((Mesh*)mesh)->SurfaceElement(num);
|
const Element2d & el = ((Mesh*)mesh)->SurfaceElement(num);
|
||||||
@ -166,7 +166,7 @@ Ng_GetSurfaceElement (Ng_Mesh * mesh, int num, int * pi)
|
|||||||
return et;
|
return et;
|
||||||
}
|
}
|
||||||
|
|
||||||
Ng_Volume_Element_Type
|
DLL_HEADER Ng_Volume_Element_Type
|
||||||
Ng_GetVolumeElement (Ng_Mesh * mesh, int num, int * pi)
|
Ng_GetVolumeElement (Ng_Mesh * mesh, int num, int * pi)
|
||||||
{
|
{
|
||||||
const Element & el = ((Mesh*)mesh)->VolumeElement(num);
|
const Element & el = ((Mesh*)mesh)->VolumeElement(num);
|
||||||
@ -183,17 +183,17 @@ Ng_GetVolumeElement (Ng_Mesh * mesh, int num, int * pi)
|
|||||||
return et;
|
return et;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ng_RestrictMeshSizeGlobal (Ng_Mesh * mesh, double h)
|
DLL_HEADER void Ng_RestrictMeshSizeGlobal (Ng_Mesh * mesh, double h)
|
||||||
{
|
{
|
||||||
((Mesh*)mesh) -> SetGlobalH (h);
|
((Mesh*)mesh) -> SetGlobalH (h);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ng_RestrictMeshSizePoint (Ng_Mesh * mesh, double * p, double h)
|
DLL_HEADER void Ng_RestrictMeshSizePoint (Ng_Mesh * mesh, double * p, double h)
|
||||||
{
|
{
|
||||||
((Mesh*)mesh) -> RestrictLocalH (Point3d (p[0], p[1], p[2]), h);
|
((Mesh*)mesh) -> RestrictLocalH (Point3d (p[0], p[1], p[2]), h);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ng_RestrictMeshSizeBox (Ng_Mesh * mesh, double * pmin, double * pmax, double h)
|
DLL_HEADER void Ng_RestrictMeshSizeBox (Ng_Mesh * mesh, double * pmin, double * pmax, double h)
|
||||||
{
|
{
|
||||||
for (double x = pmin[0]; x < pmax[0]; x += h)
|
for (double x = pmin[0]; x < pmax[0]; x += h)
|
||||||
for (double y = pmin[1]; y < pmax[1]; y += h)
|
for (double y = pmin[1]; y < pmax[1]; y += h)
|
||||||
@ -203,7 +203,7 @@ void Ng_RestrictMeshSizeBox (Ng_Mesh * mesh, double * pmin, double * pmax, doubl
|
|||||||
|
|
||||||
|
|
||||||
// generates volume mesh from surface mesh
|
// generates volume mesh from surface mesh
|
||||||
Ng_Result Ng_GenerateVolumeMesh (Ng_Mesh * mesh, Ng_Meshing_Parameters * mp)
|
DLL_HEADER Ng_Result Ng_GenerateVolumeMesh (Ng_Mesh * mesh, Ng_Meshing_Parameters * mp)
|
||||||
{
|
{
|
||||||
Mesh * m = (Mesh*)mesh;
|
Mesh * m = (Mesh*)mesh;
|
||||||
|
|
||||||
@ -227,14 +227,14 @@ Ng_Result Ng_GenerateVolumeMesh (Ng_Mesh * mesh, Ng_Meshing_Parameters * mp)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void Ng_AddPoint_2D (Ng_Mesh * mesh, double * x)
|
DLL_HEADER void Ng_AddPoint_2D (Ng_Mesh * mesh, double * x)
|
||||||
{
|
{
|
||||||
Mesh * m = (Mesh*)mesh;
|
Mesh * m = (Mesh*)mesh;
|
||||||
|
|
||||||
m->AddPoint (Point3d (x[0], x[1], 0));
|
m->AddPoint (Point3d (x[0], x[1], 0));
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ng_AddBoundarySeg_2D (Ng_Mesh * mesh, int pi1, int pi2)
|
DLL_HEADER void Ng_AddBoundarySeg_2D (Ng_Mesh * mesh, int pi1, int pi2)
|
||||||
{
|
{
|
||||||
Mesh * m = (Mesh*)mesh;
|
Mesh * m = (Mesh*)mesh;
|
||||||
|
|
||||||
@ -245,25 +245,25 @@ void Ng_AddBoundarySeg_2D (Ng_Mesh * mesh, int pi1, int pi2)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int Ng_GetNP_2D (Ng_Mesh * mesh)
|
DLL_HEADER int Ng_GetNP_2D (Ng_Mesh * mesh)
|
||||||
{
|
{
|
||||||
Mesh * m = (Mesh*)mesh;
|
Mesh * m = (Mesh*)mesh;
|
||||||
return m->GetNP();
|
return m->GetNP();
|
||||||
}
|
}
|
||||||
|
|
||||||
int Ng_GetNE_2D (Ng_Mesh * mesh)
|
DLL_HEADER int Ng_GetNE_2D (Ng_Mesh * mesh)
|
||||||
{
|
{
|
||||||
Mesh * m = (Mesh*)mesh;
|
Mesh * m = (Mesh*)mesh;
|
||||||
return m->GetNSE();
|
return m->GetNSE();
|
||||||
}
|
}
|
||||||
|
|
||||||
int Ng_GetNSeg_2D (Ng_Mesh * mesh)
|
DLL_HEADER int Ng_GetNSeg_2D (Ng_Mesh * mesh)
|
||||||
{
|
{
|
||||||
Mesh * m = (Mesh*)mesh;
|
Mesh * m = (Mesh*)mesh;
|
||||||
return m->GetNSeg();
|
return m->GetNSeg();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ng_GetPoint_2D (Ng_Mesh * mesh, int num, double * x)
|
DLL_HEADER void Ng_GetPoint_2D (Ng_Mesh * mesh, int num, double * x)
|
||||||
{
|
{
|
||||||
Mesh * m = (Mesh*)mesh;
|
Mesh * m = (Mesh*)mesh;
|
||||||
|
|
||||||
@ -272,7 +272,7 @@ void Ng_GetPoint_2D (Ng_Mesh * mesh, int num, double * x)
|
|||||||
x[1] = p(1);
|
x[1] = p(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ng_GetElement_2D (Ng_Mesh * mesh, int num, int * pi, int * matnum)
|
DLL_HEADER void Ng_GetElement_2D (Ng_Mesh * mesh, int num, int * pi, int * matnum)
|
||||||
{
|
{
|
||||||
const Element2d & el = ((Mesh*)mesh)->SurfaceElement(num);
|
const Element2d & el = ((Mesh*)mesh)->SurfaceElement(num);
|
||||||
for (int i = 1; i <= 3; i++)
|
for (int i = 1; i <= 3; i++)
|
||||||
@ -282,7 +282,7 @@ void Ng_GetElement_2D (Ng_Mesh * mesh, int num, int * pi, int * matnum)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Ng_GetSegment_2D (Ng_Mesh * mesh, int num, int * pi, int * matnum)
|
DLL_HEADER void Ng_GetSegment_2D (Ng_Mesh * mesh, int num, int * pi, int * matnum)
|
||||||
{
|
{
|
||||||
const Segment & seg = ((Mesh*)mesh)->LineSegment(num);
|
const Segment & seg = ((Mesh*)mesh)->LineSegment(num);
|
||||||
pi[0] = seg.p1;
|
pi[0] = seg.p1;
|
||||||
@ -295,16 +295,16 @@ void Ng_GetSegment_2D (Ng_Mesh * mesh, int num, int * pi, int * matnum)
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
Ng_Geometry_2D * Ng_LoadGeometry_2D (const char * filename)
|
DLL_HEADER Ng_Geometry_2D * Ng_LoadGeometry_2D (const char * filename)
|
||||||
{
|
{
|
||||||
SplineGeometry2d * geom = new SplineGeometry2d();
|
SplineGeometry2d * geom = new SplineGeometry2d();
|
||||||
geom -> Load (filename);
|
geom -> Load (filename);
|
||||||
return (Ng_Geometry_2D *)geom;
|
return (Ng_Geometry_2D *)geom;
|
||||||
}
|
}
|
||||||
|
|
||||||
Ng_Result Ng_GenerateMesh_2D (Ng_Geometry_2D * geom,
|
DLL_HEADER Ng_Result Ng_GenerateMesh_2D (Ng_Geometry_2D * geom,
|
||||||
Ng_Mesh ** mesh,
|
Ng_Mesh ** mesh,
|
||||||
Ng_Meshing_Parameters * mp)
|
Ng_Meshing_Parameters * mp)
|
||||||
{
|
{
|
||||||
// use global variable mparam
|
// use global variable mparam
|
||||||
// MeshingParameters mparam;
|
// MeshingParameters mparam;
|
||||||
@ -321,17 +321,17 @@ Ng_Result Ng_GenerateMesh_2D (Ng_Geometry_2D * geom,
|
|||||||
return NG_OK;
|
return NG_OK;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ng_HP_Refinement (Ng_Geometry_2D * geom,
|
DLL_HEADER void Ng_HP_Refinement (Ng_Geometry_2D * geom,
|
||||||
Ng_Mesh * mesh,
|
Ng_Mesh * mesh,
|
||||||
int levels)
|
int levels)
|
||||||
{
|
{
|
||||||
Refinement2d ref(*(SplineGeometry2d*)geom);
|
Refinement2d ref(*(SplineGeometry2d*)geom);
|
||||||
HPRefinement (*(Mesh*)mesh, &ref, levels);
|
HPRefinement (*(Mesh*)mesh, &ref, levels);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Ng_HP_Refinement (Ng_Geometry_2D * geom,
|
DLL_HEADER void Ng_HP_Refinement (Ng_Geometry_2D * geom,
|
||||||
Ng_Mesh * mesh,
|
Ng_Mesh * mesh,
|
||||||
int levels, double parameter)
|
int levels, double parameter)
|
||||||
{
|
{
|
||||||
Refinement2d ref(*(SplineGeometry2d*)geom);
|
Refinement2d ref(*(SplineGeometry2d*)geom);
|
||||||
HPRefinement (*(Mesh*)mesh, &ref, levels, parameter);
|
HPRefinement (*(Mesh*)mesh, &ref, levels, parameter);
|
||||||
@ -354,12 +354,12 @@ void Ng_HP_Refinement (Ng_Geometry_2D * geom,
|
|||||||
Array<STLReadTriangle> readtrias; //only before initstlgeometry
|
Array<STLReadTriangle> readtrias; //only before initstlgeometry
|
||||||
Array<Point<3> > readedges; //only before init stlgeometry
|
Array<Point<3> > readedges; //only before init stlgeometry
|
||||||
|
|
||||||
void Ng_SaveMesh(Ng_Mesh * mesh, const char* filename)
|
DLL_HEADER void Ng_SaveMesh(Ng_Mesh * mesh, const char* filename)
|
||||||
{
|
{
|
||||||
((Mesh*)mesh)->Save(filename);
|
((Mesh*)mesh)->Save(filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
Ng_Mesh * Ng_LoadMesh(const char* filename)
|
DLL_HEADER Ng_Mesh * Ng_LoadMesh(const char* filename)
|
||||||
{
|
{
|
||||||
Mesh * mesh = new Mesh;
|
Mesh * mesh = new Mesh;
|
||||||
mesh->Load(filename);
|
mesh->Load(filename);
|
||||||
@ -367,7 +367,7 @@ Ng_Mesh * Ng_LoadMesh(const char* filename)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// loads geometry from STL file
|
// loads geometry from STL file
|
||||||
Ng_STL_Geometry * Ng_STL_LoadGeometry (const char * filename, int binary)
|
DLL_HEADER Ng_STL_Geometry * Ng_STL_LoadGeometry (const char * filename, int binary)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
STLGeometry geom;
|
STLGeometry geom;
|
||||||
@ -414,13 +414,13 @@ Ng_STL_Geometry * Ng_STL_LoadGeometry (const char * filename, int binary)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// generate new STL Geometry
|
// generate new STL Geometry
|
||||||
Ng_STL_Geometry * Ng_STL_NewGeometry ()
|
DLL_HEADER Ng_STL_Geometry * Ng_STL_NewGeometry ()
|
||||||
{
|
{
|
||||||
return (Ng_STL_Geometry*)(void*)new STLGeometry;
|
return (Ng_STL_Geometry*)(void*)new STLGeometry;
|
||||||
}
|
}
|
||||||
|
|
||||||
// after adding triangles (and edges) initialize
|
// after adding triangles (and edges) initialize
|
||||||
Ng_Result Ng_STL_InitSTLGeometry (Ng_STL_Geometry * geom)
|
DLL_HEADER Ng_Result Ng_STL_InitSTLGeometry (Ng_STL_Geometry * geom)
|
||||||
{
|
{
|
||||||
STLGeometry* geo = (STLGeometry*)geom;
|
STLGeometry* geo = (STLGeometry*)geom;
|
||||||
geo->InitSTLGeometry(readtrias);
|
geo->InitSTLGeometry(readtrias);
|
||||||
@ -443,9 +443,9 @@ Ng_Result Ng_STL_InitSTLGeometry (Ng_STL_Geometry * geom)
|
|||||||
}
|
}
|
||||||
|
|
||||||
// automatically generates edges:
|
// automatically generates edges:
|
||||||
Ng_Result Ng_STL_MakeEdges (Ng_STL_Geometry * geom,
|
DLL_HEADER Ng_Result Ng_STL_MakeEdges (Ng_STL_Geometry * geom,
|
||||||
Ng_Mesh* mesh,
|
Ng_Mesh* mesh,
|
||||||
Ng_Meshing_Parameters * mp)
|
Ng_Meshing_Parameters * mp)
|
||||||
{
|
{
|
||||||
STLGeometry* stlgeometry = (STLGeometry*)geom;
|
STLGeometry* stlgeometry = (STLGeometry*)geom;
|
||||||
Mesh* me = (Mesh*)mesh;
|
Mesh* me = (Mesh*)mesh;
|
||||||
@ -482,9 +482,9 @@ Ng_Result Ng_STL_MakeEdges (Ng_STL_Geometry * geom,
|
|||||||
|
|
||||||
|
|
||||||
// generates mesh, empty mesh be already created.
|
// generates mesh, empty mesh be already created.
|
||||||
Ng_Result Ng_STL_GenerateSurfaceMesh (Ng_STL_Geometry * geom,
|
DLL_HEADER Ng_Result Ng_STL_GenerateSurfaceMesh (Ng_STL_Geometry * geom,
|
||||||
Ng_Mesh* mesh,
|
Ng_Mesh* mesh,
|
||||||
Ng_Meshing_Parameters * mp)
|
Ng_Meshing_Parameters * mp)
|
||||||
{
|
{
|
||||||
STLGeometry* stlgeometry = (STLGeometry*)geom;
|
STLGeometry* stlgeometry = (STLGeometry*)geom;
|
||||||
Mesh* me = (Mesh*)mesh;
|
Mesh* me = (Mesh*)mesh;
|
||||||
@ -539,8 +539,8 @@ Ng_Result Ng_STL_GenerateSurfaceMesh (Ng_STL_Geometry * geom,
|
|||||||
// fills STL Geometry
|
// fills STL Geometry
|
||||||
// positive orientation
|
// positive orientation
|
||||||
// normal vector may be null-pointer
|
// normal vector may be null-pointer
|
||||||
void Ng_STL_AddTriangle (Ng_STL_Geometry * geom,
|
DLL_HEADER void Ng_STL_AddTriangle (Ng_STL_Geometry * geom,
|
||||||
double * p1, double * p2, double * p3, double * nv)
|
double * p1, double * p2, double * p3, double * nv)
|
||||||
{
|
{
|
||||||
Point<3> apts[3];
|
Point<3> apts[3];
|
||||||
apts[0] = Point<3>(p1[0],p1[1],p1[2]);
|
apts[0] = Point<3>(p1[0],p1[1],p1[2]);
|
||||||
@ -557,8 +557,8 @@ void Ng_STL_AddTriangle (Ng_STL_Geometry * geom,
|
|||||||
}
|
}
|
||||||
|
|
||||||
// add (optional) edges:
|
// add (optional) edges:
|
||||||
void Ng_STL_AddEdge (Ng_STL_Geometry * geom,
|
DLL_HEADER void Ng_STL_AddEdge (Ng_STL_Geometry * geom,
|
||||||
double * p1, double * p2)
|
double * p1, double * p2)
|
||||||
{
|
{
|
||||||
readedges.Append(Point3d(p1[0],p1[1],p1[2]));
|
readedges.Append(Point3d(p1[0],p1[1],p1[2]));
|
||||||
readedges.Append(Point3d(p2[0],p2[1],p2[2]));
|
readedges.Append(Point3d(p2[0],p2[1],p2[2]));
|
||||||
@ -566,7 +566,7 @@ void Ng_STL_AddEdge (Ng_STL_Geometry * geom,
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
Ng_Meshing_Parameters :: Ng_Meshing_Parameters()
|
DLL_HEADER Ng_Meshing_Parameters :: Ng_Meshing_Parameters()
|
||||||
{
|
{
|
||||||
maxh = 1000;
|
maxh = 1000;
|
||||||
fineness = 0.5;
|
fineness = 0.5;
|
||||||
|
109
nglib/nglib.h
109
nglib/nglib.h
@ -13,6 +13,19 @@ Interface to the netgen meshing kernel
|
|||||||
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
// Philippose - 14.02.2009
|
||||||
|
// Modifications for creating a DLL in Windows
|
||||||
|
#ifdef WIN32
|
||||||
|
#ifdef NGLIB_EXPORTS
|
||||||
|
#define DLL_HEADER __declspec(dllexport)
|
||||||
|
#else
|
||||||
|
#define DLL_HEADER __declspec(dllimport)
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
|
#define DLL_HEADER
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/// Data type for NETGEN mesh
|
/// Data type for NETGEN mesh
|
||||||
typedef void * Ng_Mesh;
|
typedef void * Ng_Mesh;
|
||||||
|
|
||||||
@ -53,7 +66,7 @@ class Ng_Meshing_Parameters
|
|||||||
char * meshsize_filename;
|
char * meshsize_filename;
|
||||||
int quad_dominated;
|
int quad_dominated;
|
||||||
|
|
||||||
Ng_Meshing_Parameters();
|
DLL_HEADER Ng_Meshing_Parameters();
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
@ -69,49 +82,49 @@ enum Ng_Result { NG_OK = 0,
|
|||||||
|
|
||||||
|
|
||||||
// initialize, deconstruct Netgen library:
|
// initialize, deconstruct Netgen library:
|
||||||
void Ng_Init ();
|
DLL_HEADER void Ng_Init ();
|
||||||
void Ng_Exit ();
|
DLL_HEADER void Ng_Exit ();
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// Generates new mesh structure
|
// Generates new mesh structure
|
||||||
Ng_Mesh * Ng_NewMesh ();
|
DLL_HEADER Ng_Mesh * Ng_NewMesh ();
|
||||||
void Ng_DeleteMesh (Ng_Mesh * mesh);
|
DLL_HEADER void Ng_DeleteMesh (Ng_Mesh * mesh);
|
||||||
|
|
||||||
// feeds points, surface elements and volume elements to the mesh
|
// feeds points, surface elements and volume elements to the mesh
|
||||||
void Ng_AddPoint (Ng_Mesh * mesh, double * x);
|
DLL_HEADER void Ng_AddPoint (Ng_Mesh * mesh, double * x);
|
||||||
void Ng_AddSurfaceElement (Ng_Mesh * mesh, Ng_Surface_Element_Type et,
|
DLL_HEADER void Ng_AddSurfaceElement (Ng_Mesh * mesh, Ng_Surface_Element_Type et,
|
||||||
int * pi);
|
int * pi);
|
||||||
void Ng_AddVolumeElement (Ng_Mesh * mesh, Ng_Volume_Element_Type et,
|
DLL_HEADER void Ng_AddVolumeElement (Ng_Mesh * mesh, Ng_Volume_Element_Type et,
|
||||||
int * pi);
|
int * pi);
|
||||||
|
|
||||||
// ask for number of points, surface and volume elements
|
// ask for number of points, surface and volume elements
|
||||||
int Ng_GetNP (Ng_Mesh * mesh);
|
DLL_HEADER int Ng_GetNP (Ng_Mesh * mesh);
|
||||||
int Ng_GetNSE (Ng_Mesh * mesh);
|
DLL_HEADER int Ng_GetNSE (Ng_Mesh * mesh);
|
||||||
int Ng_GetNE (Ng_Mesh * mesh);
|
DLL_HEADER int Ng_GetNE (Ng_Mesh * mesh);
|
||||||
|
|
||||||
|
|
||||||
// return point coordinates
|
// return point coordinates
|
||||||
void Ng_GetPoint (Ng_Mesh * mesh, int num, double * x);
|
DLL_HEADER void Ng_GetPoint (Ng_Mesh * mesh, int num, double * x);
|
||||||
|
|
||||||
// return surface and volume element in pi
|
// return surface and volume element in pi
|
||||||
Ng_Surface_Element_Type
|
DLL_HEADER Ng_Surface_Element_Type
|
||||||
Ng_GetSurfaceElement (Ng_Mesh * mesh, int num, int * pi);
|
Ng_GetSurfaceElement (Ng_Mesh * mesh, int num, int * pi);
|
||||||
|
|
||||||
Ng_Volume_Element_Type
|
DLL_HEADER Ng_Volume_Element_Type
|
||||||
Ng_GetVolumeElement (Ng_Mesh * mesh, int num, int * pi);
|
Ng_GetVolumeElement (Ng_Mesh * mesh, int num, int * pi);
|
||||||
|
|
||||||
|
|
||||||
// Defines MeshSize Functions
|
// Defines MeshSize Functions
|
||||||
void Ng_RestrictMeshSizeGlobal (Ng_Mesh * mesh, double h);
|
DLL_HEADER void Ng_RestrictMeshSizeGlobal (Ng_Mesh * mesh, double h);
|
||||||
void Ng_RestrictMeshSizePoint (Ng_Mesh * mesh, double * p, double h);
|
DLL_HEADER void Ng_RestrictMeshSizePoint (Ng_Mesh * mesh, double * p, double h);
|
||||||
void Ng_RestrictMeshSizeBox (Ng_Mesh * mesh, double * pmin, double * pmax, double h);
|
DLL_HEADER void Ng_RestrictMeshSizeBox (Ng_Mesh * mesh, double * pmin, double * pmax, double h);
|
||||||
|
|
||||||
// generates volume mesh from surface mesh
|
// generates volume mesh from surface mesh
|
||||||
Ng_Result Ng_GenerateVolumeMesh (Ng_Mesh * mesh, Ng_Meshing_Parameters * mp);
|
DLL_HEADER Ng_Result Ng_GenerateVolumeMesh (Ng_Mesh * mesh, Ng_Meshing_Parameters * mp);
|
||||||
|
|
||||||
void Ng_SaveMesh(Ng_Mesh * mesh, const char* filename);
|
DLL_HEADER void Ng_SaveMesh(Ng_Mesh * mesh, const char* filename);
|
||||||
Ng_Mesh * Ng_LoadMesh(const char* filename);
|
DLL_HEADER Ng_Mesh * Ng_LoadMesh(const char* filename);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -124,35 +137,35 @@ Ng_Mesh * Ng_LoadMesh(const char* filename);
|
|||||||
|
|
||||||
// feeds points and boundary to mesh
|
// feeds points and boundary to mesh
|
||||||
|
|
||||||
void Ng_AddPoint_2D (Ng_Mesh * mesh, double * x);
|
DLL_HEADER void Ng_AddPoint_2D (Ng_Mesh * mesh, double * x);
|
||||||
void Ng_AddBoundarySeg_2D (Ng_Mesh * mesh, int pi1, int pi2);
|
DLL_HEADER void Ng_AddBoundarySeg_2D (Ng_Mesh * mesh, int pi1, int pi2);
|
||||||
|
|
||||||
// ask for number of points, elements and boundary segments
|
// ask for number of points, elements and boundary segments
|
||||||
int Ng_GetNP_2D (Ng_Mesh * mesh);
|
DLL_HEADER int Ng_GetNP_2D (Ng_Mesh * mesh);
|
||||||
int Ng_GetNE_2D (Ng_Mesh * mesh);
|
DLL_HEADER int Ng_GetNE_2D (Ng_Mesh * mesh);
|
||||||
int Ng_GetNSeg_2D (Ng_Mesh * mesh);
|
DLL_HEADER int Ng_GetNSeg_2D (Ng_Mesh * mesh);
|
||||||
|
|
||||||
// return point coordinates
|
// return point coordinates
|
||||||
void Ng_GetPoint_2D (Ng_Mesh * mesh, int num, double * x);
|
DLL_HEADER void Ng_GetPoint_2D (Ng_Mesh * mesh, int num, double * x);
|
||||||
|
|
||||||
// return 2d triangles
|
// return 2d triangles
|
||||||
void Ng_GetElement_2D (Ng_Mesh * mesh, int num, int * pi, int * matnum = NULL);
|
DLL_HEADER void Ng_GetElement_2D (Ng_Mesh * mesh, int num, int * pi, int * matnum = NULL);
|
||||||
|
|
||||||
// return 2d boundary segment
|
// return 2d boundary segment
|
||||||
void Ng_GetSegment_2D (Ng_Mesh * mesh, int num, int * pi, int * matnum = NULL);
|
DLL_HEADER void Ng_GetSegment_2D (Ng_Mesh * mesh, int num, int * pi, int * matnum = NULL);
|
||||||
|
|
||||||
|
|
||||||
// load 2d netgen spline geometry
|
// load 2d netgen spline geometry
|
||||||
Ng_Geometry_2D * Ng_LoadGeometry_2D (const char * filename);
|
DLL_HEADER Ng_Geometry_2D * Ng_LoadGeometry_2D (const char * filename);
|
||||||
|
|
||||||
// generate 2d mesh, mesh is allocated by function
|
// generate 2d mesh, mesh is allocated by function
|
||||||
Ng_Result Ng_GenerateMesh_2D (Ng_Geometry_2D * geom,
|
DLL_HEADER Ng_Result Ng_GenerateMesh_2D (Ng_Geometry_2D * geom,
|
||||||
Ng_Mesh ** mesh,
|
Ng_Mesh ** mesh,
|
||||||
Ng_Meshing_Parameters * mp);
|
Ng_Meshing_Parameters * mp);
|
||||||
|
|
||||||
void Ng_HP_Refinement (Ng_Geometry_2D * geom,
|
DLL_HEADER void Ng_HP_Refinement (Ng_Geometry_2D * geom,
|
||||||
Ng_Mesh * mesh,
|
Ng_Mesh * mesh,
|
||||||
int levels);
|
int levels);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -164,35 +177,35 @@ void Ng_HP_Refinement (Ng_Geometry_2D * geom,
|
|||||||
|
|
||||||
|
|
||||||
// loads geometry from STL file
|
// loads geometry from STL file
|
||||||
Ng_STL_Geometry * Ng_STL_LoadGeometry (const char * filename, int binary = 0);
|
DLL_HEADER Ng_STL_Geometry * Ng_STL_LoadGeometry (const char * filename, int binary = 0);
|
||||||
|
|
||||||
|
|
||||||
// generate new STL Geometry
|
// generate new STL Geometry
|
||||||
Ng_STL_Geometry * Ng_STL_NewGeometry ();
|
DLL_HEADER Ng_STL_Geometry * Ng_STL_NewGeometry ();
|
||||||
|
|
||||||
|
|
||||||
// fills STL Geometry
|
// fills STL Geometry
|
||||||
// positive orientation
|
// positive orientation
|
||||||
// normal vector may be null-pointer
|
// normal vector may be null-pointer
|
||||||
void Ng_STL_AddTriangle (Ng_STL_Geometry * geom,
|
DLL_HEADER void Ng_STL_AddTriangle (Ng_STL_Geometry * geom,
|
||||||
double * p1, double * p2, double * p3,
|
double * p1, double * p2, double * p3,
|
||||||
double * nv = NULL);
|
double * nv = NULL);
|
||||||
|
|
||||||
// add (optional) edges :
|
// add (optional) edges :
|
||||||
void Ng_STL_AddEdge (Ng_STL_Geometry * geom,
|
DLL_HEADER void Ng_STL_AddEdge (Ng_STL_Geometry * geom,
|
||||||
double * p1, double * p2);
|
double * p1, double * p2);
|
||||||
|
|
||||||
// after adding triangles (and edges) initialize
|
// after adding triangles (and edges) initialize
|
||||||
Ng_Result Ng_STL_InitSTLGeometry (Ng_STL_Geometry * geom);
|
DLL_HEADER Ng_Result Ng_STL_InitSTLGeometry (Ng_STL_Geometry * geom);
|
||||||
|
|
||||||
// automatically generates edges:
|
// automatically generates edges:
|
||||||
Ng_Result Ng_STL_MakeEdges (Ng_STL_Geometry * geom,
|
DLL_HEADER Ng_Result Ng_STL_MakeEdges (Ng_STL_Geometry * geom,
|
||||||
Ng_Mesh* mesh,
|
Ng_Mesh* mesh,
|
||||||
Ng_Meshing_Parameters * mp);
|
Ng_Meshing_Parameters * mp);
|
||||||
|
|
||||||
|
|
||||||
// generates mesh, empty mesh must be already created.
|
// generates mesh, empty mesh must be already created.
|
||||||
Ng_Result Ng_STL_GenerateSurfaceMesh (Ng_STL_Geometry * geom,
|
DLL_HEADER Ng_Result Ng_STL_GenerateSurfaceMesh (Ng_STL_Geometry * geom,
|
||||||
Ng_Mesh * mesh,
|
Ng_Mesh * mesh,
|
||||||
Ng_Meshing_Parameters * mp);
|
Ng_Meshing_Parameters * mp);
|
||||||
|
|
||||||
@ -207,12 +220,12 @@ Ng_Result Ng_STL_GenerateSurfaceMesh (Ng_STL_Geometry * geom,
|
|||||||
typedef void * Ng_ACIS_Geometry;
|
typedef void * Ng_ACIS_Geometry;
|
||||||
|
|
||||||
// loads geometry from STL file
|
// loads geometry from STL file
|
||||||
Ng_ACIS_Geometry * Ng_ACIS_LoadGeometry (const char * filename);
|
DLL_HEADER Ng_ACIS_Geometry * Ng_ACIS_LoadGeometry (const char * filename);
|
||||||
|
|
||||||
// generates mesh, empty mesh must be already created.
|
// generates mesh, empty mesh must be already created.
|
||||||
Ng_Result Ng_ACIS_GenerateSurfaceMesh (Ng_ACIS_Geometry * geom,
|
DLL_HEADER Ng_Result Ng_ACIS_GenerateSurfaceMesh (Ng_ACIS_Geometry * geom,
|
||||||
Ng_Mesh * mesh,
|
Ng_Mesh * mesh,
|
||||||
Ng_Meshing_Parameters * mp);
|
Ng_Meshing_Parameters * mp);
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user