mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-12 09:40:35 +05:00
#16914 EDF 19401 - Wrong quadratic mesh (bis)
Bug: SetEventListener() not called when a sub-algo assigned
This commit is contained in:
parent
ecea056f61
commit
eacfc191eb
@ -17,7 +17,7 @@ hypothesis.
|
||||
:align: center
|
||||
|
||||
.. centered::
|
||||
A mesh of a river model to the left and of a ring-face to the right
|
||||
A mesh of a river model (to the left) and of a ring-face (to the right)
|
||||
|
||||
The algorithm provides proper shape of quadrangles by constructing Medial
|
||||
Axis between sinuous borders of the face and using it to
|
||||
|
@ -878,7 +878,10 @@ SMESH_Hypothesis::Hypothesis_Status
|
||||
const SMESH_Hypothesis * prevAlgo = _father->GetHypothesis( this, f, true );
|
||||
if (prevAlgo &&
|
||||
string( algo->GetName()) != prevAlgo->GetName())
|
||||
modifiedHyp = true;
|
||||
{
|
||||
oldAlgoState = NO_ALGO; // force setting event listener (#16648)
|
||||
modifiedHyp = true;
|
||||
}
|
||||
}
|
||||
else
|
||||
setAlgoState(MISSING_HYP);
|
||||
|
@ -758,11 +758,23 @@ protected:
|
||||
void StdMeshers_RadialQuadrangle_1D2D::SubmeshRestored(SMESH_subMesh* faceSubMesh)
|
||||
{
|
||||
if ( !faceSubMesh->IsEmpty() )
|
||||
SetEventListener( faceSubMesh );
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
/*!
|
||||
* \brief Sets event listener to a submesh
|
||||
* \param subMesh - submesh where algo is set
|
||||
*
|
||||
* This method is called when a submesh gets HYP_OK algo_state.
|
||||
*/
|
||||
//=======================================================================
|
||||
|
||||
void StdMeshers_RadialQuadrangle_1D2D::SetEventListener(SMESH_subMesh* faceSubMesh)
|
||||
{
|
||||
for ( TopExp_Explorer e( faceSubMesh->GetSubShape(), TopAbs_EDGE ); e.More(); e.Next() )
|
||||
{
|
||||
for ( TopExp_Explorer e( faceSubMesh->GetSubShape(), TopAbs_EDGE ); e.More(); e.Next() )
|
||||
{
|
||||
TEdgeMarker::markEdge( TopoDS::Edge( e.Current() ), faceSubMesh );
|
||||
}
|
||||
TEdgeMarker::markEdge( TopoDS::Edge( e.Current() ), faceSubMesh );
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -50,14 +50,13 @@ public:
|
||||
|
||||
virtual bool Evaluate(SMESH_Mesh & aMesh, const TopoDS_Shape & aShape,
|
||||
MapShapeNbElems& aResMap);
|
||||
/*!
|
||||
* \brief Allow algo to do something after persistent restoration
|
||||
* \param subMesh - restored submesh
|
||||
*
|
||||
* This method is called only if a submesh has HYP_OK algo_state.
|
||||
*/
|
||||
|
||||
// Allow algo to do something after persistent restoration
|
||||
virtual void SubmeshRestored(SMESH_subMesh* subMesh);
|
||||
|
||||
// Sets event listener to a submesh
|
||||
virtual void SetEventListener(SMESH_subMesh* subMesh);
|
||||
|
||||
virtual bool IsApplicableToShape(const TopoDS_Shape & shape, bool toCheckAll) const
|
||||
{
|
||||
return IsApplicable( shape, toCheckAll );
|
||||
|
Loading…
Reference in New Issue
Block a user