mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-12 22:20:35 +05:00
Merge branch 'occ_point_in_surface' into 'master'
[occ] inner point of surface -> surface mesh See merge request jschoeberl/netgen!494
This commit is contained in:
commit
4cc758632d
@ -704,6 +704,16 @@ namespace netgen
|
||||
}
|
||||
}
|
||||
}
|
||||
for(const auto& vert : GetFaceVertices(face))
|
||||
{
|
||||
PointIndex pi = vert->nr + 1;
|
||||
if(glob2loc[pi] == 0)
|
||||
{
|
||||
meshing.AddPoint(mesh[pi], pi);
|
||||
cntp++;
|
||||
glob2loc[pi] = cntp;
|
||||
}
|
||||
}
|
||||
for(auto & seg : segments)
|
||||
{
|
||||
PointGeomInfo gi0, gi1;
|
||||
|
@ -203,6 +203,8 @@ namespace netgen
|
||||
const GeometryEdge & GetEdge(int i) const { return *edges[i]; }
|
||||
const GeometryVertex & GetVertex(int i) const { return *vertices[i]; }
|
||||
|
||||
virtual Array<GeometryVertex*> GetFaceVertices(const GeometryFace& face) const { return Array<GeometryVertex*>{}; }
|
||||
|
||||
void Clear();
|
||||
|
||||
virtual int GenerateMesh (shared_ptr<Mesh> & mesh, MeshingParameters & mparam);
|
||||
|
@ -25,6 +25,7 @@ namespace netgen
|
||||
public:
|
||||
OCCFace(TopoDS_Shape dshape);
|
||||
|
||||
const TopoDS_Face Shape() const { return face; }
|
||||
T_Shape TShape() { return tface; }
|
||||
|
||||
size_t GetHash() const override;
|
||||
|
@ -4,6 +4,7 @@
|
||||
#include <meshing.hpp>
|
||||
|
||||
#include "occgeom.hpp"
|
||||
#include "occ_face.hpp"
|
||||
#include "occmeshsurf.hpp"
|
||||
|
||||
#include <BRepAdaptor_Curve.hxx>
|
||||
@ -250,6 +251,7 @@ namespace netgen
|
||||
|
||||
FaceDescriptor & fd = mesh.GetFaceDescriptor(k);
|
||||
auto face = TopoDS::Face(geom.fmap(k));
|
||||
const auto& occface = dynamic_cast<const OCCFace&>(geom.GetFace(k-1));
|
||||
auto fshape = face.TShape();
|
||||
|
||||
int oldnf = mesh.GetNSE();
|
||||
@ -298,6 +300,20 @@ namespace netgen
|
||||
glob2loc[pi] = cntp;
|
||||
}
|
||||
}
|
||||
for(const auto& vert : geom.GetFaceVertices(geom.GetFace(k-1)))
|
||||
{
|
||||
PointIndex pi = vert->nr + 1;
|
||||
if(glob2loc[pi] == 0)
|
||||
{
|
||||
auto gi = occface.Project(mesh[pi]);
|
||||
MultiPointGeomInfo mgi;
|
||||
mgi.AddPointGeomInfo(gi);
|
||||
meshing.AddPoint(mesh[pi], pi, &mgi);
|
||||
cntp++;
|
||||
glob2loc[pi] = cntp;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
for (int i = 1; i <= mesh.GetNSeg(); i++)
|
||||
@ -323,9 +339,11 @@ namespace netgen
|
||||
else
|
||||
{
|
||||
static Timer t("MeshSurface: Find edges and points - Parameter"); RegionTimer r(t);
|
||||
|
||||
|
||||
Array<PointGeomInfo> gis(2*segments.Size());
|
||||
gis.SetSize (0);
|
||||
glob2loc = 0;
|
||||
int cntpt = 0;
|
||||
|
||||
Box<2> uv_box(Box<2>::EMPTY_BOX);
|
||||
for(auto & seg : segments)
|
||||
@ -357,7 +375,7 @@ namespace netgen
|
||||
{
|
||||
PointIndex pi = seg[j];
|
||||
meshing.AddPoint (mesh.Point(pi), pi);
|
||||
|
||||
glob2loc[pi] = ++cntpt;
|
||||
gis.Append (gi[j]);
|
||||
locpnum[j] = gis.Size();
|
||||
uv_tree.Insert(uv, locpnum[j]);
|
||||
@ -366,6 +384,21 @@ namespace netgen
|
||||
|
||||
meshing.AddBoundaryElement (locpnum[0], locpnum[1], gi[0], gi[1]);
|
||||
}
|
||||
for(const auto& vert : geom.GetFaceVertices(geom.GetFace(k-1)))
|
||||
{
|
||||
PointIndex pi = vert->nr + 1;
|
||||
if(glob2loc[pi] == 0)
|
||||
{
|
||||
auto gi = occface.Project(mesh[pi]);
|
||||
MultiPointGeomInfo mgi;
|
||||
mgi.AddPointGeomInfo(gi);
|
||||
meshing.AddPoint(mesh[pi], pi, &mgi);
|
||||
gis.Append(gi);
|
||||
Point<2> uv = { gi.u, gi.v };
|
||||
uv_tree.Insert(uv, gis.Size());
|
||||
glob2loc[pi] = ++cntpt;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
@ -1316,6 +1316,14 @@ namespace netgen
|
||||
}
|
||||
|
||||
|
||||
Array<GeometryVertex*> OCCGeometry :: GetFaceVertices(const GeometryFace& face) const
|
||||
{
|
||||
Array<GeometryVertex*> verts;
|
||||
const auto& occface = dynamic_cast<const OCCFace&>(face);
|
||||
for(auto& vert : GetVertices(occface.Shape()))
|
||||
verts.Append(vertices[vertex_map.at(vert.TShape())].get());
|
||||
return move(verts);
|
||||
}
|
||||
|
||||
|
||||
void OCCGeometry :: BuildVisualizationMesh (double deflection)
|
||||
|
@ -247,6 +247,8 @@ namespace netgen
|
||||
|
||||
void MakeSolid();
|
||||
|
||||
Array<GeometryVertex*> GetFaceVertices(const GeometryFace& face) const override;
|
||||
|
||||
void HealGeometry();
|
||||
void GlueGeometry();
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user