PAL9022. Attach generated mesh elements to whatever meshed shape, SHELL or SOLID

This commit is contained in:
eap 2005-09-07 04:42:49 +00:00
parent f62232e212
commit 2ac338d578
2 changed files with 8 additions and 32 deletions

View File

@ -606,17 +606,7 @@ bool StdMeshers_Hexa_3D::Compute(SMESH_Mesh & aMesh,
// - compute the point 3D
// - store the point 3D in SMESHDS, store its ID in 3D structure
TopoDS_Shell aShell;
TopExp_Explorer exp(aShape, TopAbs_SHELL);
if (exp.More())
{
aShell = TopoDS::Shell(exp.Current());
}
else
{
MESSAGE("no shell...");
ASSERT(0);
}
int shapeID = meshDS->ShapeToIndex( aShape );
Pt3 p000, p001, p010, p011, p100, p101, p110, p111;
Pt3 px00, px01, px10, px11;
@ -690,8 +680,7 @@ bool StdMeshers_Hexa_3D::Compute(SMESH_Mesh & aMesh,
SMDS_MeshNode * node = meshDS->AddNode(X[0], X[1], X[2]);
np[ijk].node = node;
//meshDS->SetNodeInVolume(node, TopoDS::Solid(aShape));
meshDS->SetNodeInVolume(node, aShell);
meshDS->SetNodeInVolume(node, shapeID);
}
}
}
@ -755,9 +744,7 @@ bool StdMeshers_Hexa_3D::Compute(SMESH_Mesh & aMesh,
np[n7].node,
np[n6].node);
meshDS->SetMeshElementOnShape(elt, aShell);
meshDS->SetMeshElementOnShape(elt, shapeID);
}
}
if ( np ) delete [] np;
@ -1062,7 +1049,7 @@ bool ComputePentahedralMesh(SMESH_Mesh & aMesh, const TopoDS_Shape & aShape)
//printf(" ComputePentahedralMesh HERE\n");
//
bool bOK;
int iErr;
//int iErr;
StdMeshers_Penta_3D anAlgo;
//
bOK=anAlgo.Compute(aMesh, aShape);

View File

@ -60,10 +60,6 @@ using namespace std;
typedef map < int, int, less<int> >::iterator \
StdMeshers_IteratorOfDataMapOfIntegerInteger;
//=======================================================================
//
// StdMeshers_Penta_3D
//
//=======================================================================
//function : StdMeshers_Penta_3D
//purpose :
@ -597,17 +593,10 @@ void StdMeshers_Penta_3D::MakeVolumeMesh()
//
int i, j, ij, ik, i1, i2, aSSID;
//
TopoDS_Shell aShell;
TopExp_Explorer aExp;
//
SMESH_Mesh* pMesh =GetMesh();
SMESHDS_Mesh* meshDS=pMesh->GetMeshDS();
//
aExp.Init(myShape, TopAbs_SHELL);
for (; aExp.More(); aExp.Next()){
aShell=TopoDS::Shell(aExp.Current());
break;
}
int shapeID = meshDS->ShapeToIndex( myShape );
//
// 1. Set Node In Volume
ik=myISize-1;
@ -618,7 +607,7 @@ void StdMeshers_Penta_3D::MakeVolumeMesh()
aSSID=aTN.ShapeSupportID();
if (aSSID==SMESH_Block::ID_NONE) {
SMDS_MeshNode* aNode=(SMDS_MeshNode*)aTN.Node();
meshDS->SetNodeInVolume(aNode, aShell);
meshDS->SetNodeInVolume(aNode, shapeID);
}
}
}
@ -714,7 +703,7 @@ void StdMeshers_Penta_3D::MakeVolumeMesh()
default:
continue;
}
meshDS->SetMeshElementOnShape(aV, aShell);
meshDS->SetMeshElementOnShape(aV, shapeID);
}
}
}
@ -873,7 +862,7 @@ void StdMeshers_Penta_3D::CreateNode(const bool bIsUpperLayer,
{
myErrorStatus=0;
//
int iErr;
// int iErr;
double aX, aY, aZ;
//
gp_Pnt aP;