mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-14 02:30:33 +05:00
0022104: EDF 2550 SMESH: 2D viscous layer, allow specifying edges with viscous layer
In addition to implementing IMP, avoid "limiting" _thickness to zero: - _thickness = Min( _hyp->GetTotalThickness(), maxPossibleThick ); + if ( maxPossibleThick > 0. ) + _thickness = Min( _hyp->GetTotalThickness(), maxPossibleThick );
This commit is contained in:
parent
4a87093dce
commit
cb2ff0ef70
@ -495,7 +495,7 @@ _ViscousBuilder2D::_ViscousBuilder2D(SMESH_Mesh& theMesh,
|
|||||||
_mesh( &theMesh ), _face( theFace ), _hyp( theHyp ), _helper( theMesh )
|
_mesh( &theMesh ), _face( theFace ), _hyp( theHyp ), _helper( theMesh )
|
||||||
{
|
{
|
||||||
_helper.SetSubShape( _face );
|
_helper.SetSubShape( _face );
|
||||||
_helper.SetElementsOnShape(true);
|
_helper.SetElementsOnShape( true );
|
||||||
|
|
||||||
//_face.Orientation( TopAbs_FORWARD );
|
//_face.Orientation( TopAbs_FORWARD );
|
||||||
_surface = BRep_Tool::Surface( _face );
|
_surface = BRep_Tool::Surface( _face );
|
||||||
@ -522,7 +522,6 @@ bool _ViscousBuilder2D::error(const string& text )
|
|||||||
_error->myAlgo = smError->myAlgo;
|
_error->myAlgo = smError->myAlgo;
|
||||||
smError = _error;
|
smError = _error;
|
||||||
}
|
}
|
||||||
//makeGroupOfLE(); // debug
|
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
@ -573,7 +572,9 @@ bool _ViscousBuilder2D::findEdgesWithLayers()
|
|||||||
{
|
{
|
||||||
// collect all EDGEs to ignore defined by hyp
|
// collect all EDGEs to ignore defined by hyp
|
||||||
int nbMyEdgesIgnored = 0;
|
int nbMyEdgesIgnored = 0;
|
||||||
vector<TGeomID> ids = _hyp->GetBndShapesToIgnore();
|
vector<TGeomID> ids = _hyp->GetBndShapes();
|
||||||
|
if ( _hyp->IsToIgnoreShapes() ) // EDGEs to ignore are given
|
||||||
|
{
|
||||||
for ( size_t i = 0; i < ids.size(); ++i )
|
for ( size_t i = 0; i < ids.size(); ++i )
|
||||||
{
|
{
|
||||||
const TopoDS_Shape& s = getMeshDS()->IndexToShape( ids[i] );
|
const TopoDS_Shape& s = getMeshDS()->IndexToShape( ids[i] );
|
||||||
@ -582,6 +583,20 @@ bool _ViscousBuilder2D::findEdgesWithLayers()
|
|||||||
nbMyEdgesIgnored += ( _helper.IsSubShape( s, _face ));
|
nbMyEdgesIgnored += ( _helper.IsSubShape( s, _face ));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
else // EDGEs to to make the Viscous Layers on are given
|
||||||
|
{
|
||||||
|
for ( size_t iWire = 0; iWire < _faceSideVec.size(); ++iWire )
|
||||||
|
{
|
||||||
|
StdMeshers_FaceSidePtr wire = _faceSideVec[ iWire ];
|
||||||
|
for ( int iE = 0; iE < wire->NbEdges(); ++iE )
|
||||||
|
_ignoreShapeIds.insert( wire->EdgeID( iE ));
|
||||||
|
}
|
||||||
|
for ( size_t i = 0; i < ids.size(); ++i )
|
||||||
|
_ignoreShapeIds.erase( ids[i] );
|
||||||
|
|
||||||
|
nbMyEdgesIgnored = _ignoreShapeIds.size();
|
||||||
|
}
|
||||||
|
|
||||||
// check all EDGEs of the _face
|
// check all EDGEs of the _face
|
||||||
int totalNbEdges = 0;
|
int totalNbEdges = 0;
|
||||||
@ -613,7 +628,7 @@ bool _ViscousBuilder2D::findEdgesWithLayers()
|
|||||||
|
|
||||||
set<TGeomID> neighbourIgnoreEdges;
|
set<TGeomID> neighbourIgnoreEdges;
|
||||||
if (viscHyp) {
|
if (viscHyp) {
|
||||||
vector<TGeomID> ids = _hyp->GetBndShapesToIgnore();
|
vector<TGeomID> ids = _hyp->GetBndShapes();
|
||||||
neighbourIgnoreEdges.insert( ids.begin(), ids.end() );
|
neighbourIgnoreEdges.insert( ids.begin(), ids.end() );
|
||||||
}
|
}
|
||||||
for ( int iV = 0; iV < 2; ++iV )
|
for ( int iV = 0; iV < 2; ++iV )
|
||||||
@ -773,6 +788,7 @@ bool _ViscousBuilder2D::makePolyLines()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if ( maxPossibleThick > 0. )
|
||||||
_thickness = Min( _hyp->GetTotalThickness(), maxPossibleThick );
|
_thickness = Min( _hyp->GetTotalThickness(), maxPossibleThick );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user