22419: EDF SMESH Regression: 3D Extrusion fails

FaceQuadStruct::Ptr CheckNbEdges(SMESH_Mesh&         aMesh,
                                    const TopoDS_Shape& aShape,
+                                   const bool          considerMesh=false);
This commit is contained in:
eap 2013-11-27 10:00:34 +00:00
parent c8c04435db
commit d9d385cc06
2 changed files with 13 additions and 7 deletions

View File

@ -218,7 +218,7 @@ bool StdMeshers_Quadrangle_2D::Compute (SMESH_Mesh& aMesh,
_quadraticMesh = myHelper->IsQuadraticSubMesh(aShape); _quadraticMesh = myHelper->IsQuadraticSubMesh(aShape);
myNeedSmooth = false; myNeedSmooth = false;
FaceQuadStruct::Ptr quad = CheckNbEdges( aMesh, F ); FaceQuadStruct::Ptr quad = CheckNbEdges( aMesh, F, /*considerMesh=*/true );
if (!quad) if (!quad)
return false; return false;
myQuadStruct = quad; myQuadStruct = quad;
@ -819,7 +819,8 @@ static bool twoEdgesMeatAtVertex(const TopoDS_Edge& e1,
//============================================================================= //=============================================================================
FaceQuadStruct::Ptr StdMeshers_Quadrangle_2D::CheckNbEdges(SMESH_Mesh & aMesh, FaceQuadStruct::Ptr StdMeshers_Quadrangle_2D::CheckNbEdges(SMESH_Mesh & aMesh,
const TopoDS_Shape & aShape) const TopoDS_Shape & aShape,
const bool considerMesh)
{ {
if ( myQuadStruct && myQuadStruct->face.IsSame( aShape )) if ( myQuadStruct && myQuadStruct->face.IsSame( aShape ))
return myQuadStruct; return myQuadStruct;
@ -839,7 +840,7 @@ FaceQuadStruct::Ptr StdMeshers_Quadrangle_2D::CheckNbEdges(SMESH_Mesh &
// find corner vertices of the quad // find corner vertices of the quad
vector<TopoDS_Vertex> corners; vector<TopoDS_Vertex> corners;
int nbDegenEdges, nbSides = getCorners( F, aMesh, edges, corners, nbDegenEdges ); int nbDegenEdges, nbSides = getCorners( F, aMesh, edges, corners, nbDegenEdges, considerMesh );
if ( nbSides == 0 ) if ( nbSides == 0 )
{ {
return FaceQuadStruct::Ptr(); return FaceQuadStruct::Ptr();
@ -3459,6 +3460,8 @@ void StdMeshers_Quadrangle_2D::smooth (FaceQuadStruct::Ptr quad)
* \param [out] theVertices - the found corner vertices in the order corresponding to * \param [out] theVertices - the found corner vertices in the order corresponding to
* the order of EDGEs in \a theWire * the order of EDGEs in \a theWire
* \param [out] theNbDegenEdges - nb of degenerated EDGEs in theFace * \param [out] theNbDegenEdges - nb of degenerated EDGEs in theFace
* \param [in] theConsiderMesh - if \c true, only meshed VERTEXes are considered
* as possible corners
* \return int - number of quad sides found: 0, 3 or 4 * \return int - number of quad sides found: 0, 3 or 4
*/ */
//================================================================================ //================================================================================
@ -3467,7 +3470,8 @@ int StdMeshers_Quadrangle_2D::getCorners(const TopoDS_Face& theFace,
SMESH_Mesh & theMesh, SMESH_Mesh & theMesh,
std::list<TopoDS_Edge>& theWire, std::list<TopoDS_Edge>& theWire,
std::vector<TopoDS_Vertex>& theVertices, std::vector<TopoDS_Vertex>& theVertices,
int & theNbDegenEdges) int & theNbDegenEdges,
const bool theConsiderMesh)
{ {
theNbDegenEdges = 0; theNbDegenEdges = 0;
@ -3495,7 +3499,7 @@ int StdMeshers_Quadrangle_2D::getCorners(const TopoDS_Face& theFace,
continue; continue;
} }
TopoDS_Vertex v = helper.IthVertex( 0, *edge ); TopoDS_Vertex v = helper.IthVertex( 0, *edge );
if ( SMESH_Algo::VertexNode( v, helper.GetMeshDS() )) if ( !theConsiderMesh || SMESH_Algo::VertexNode( v, helper.GetMeshDS() ))
{ {
double angle = SMESH_MesherHelper::GetAngle( prevE, *edge, theFace ); double angle = SMESH_MesherHelper::GetAngle( prevE, *edge, theFace );
vertexByAngle.insert( make_pair( angle, v )); vertexByAngle.insert( make_pair( angle, v ));

View File

@ -78,7 +78,8 @@ public:
const bool CreateQuadratic); const bool CreateQuadratic);
FaceQuadStruct::Ptr CheckNbEdges(SMESH_Mesh& aMesh, FaceQuadStruct::Ptr CheckNbEdges(SMESH_Mesh& aMesh,
const TopoDS_Shape& aShape); const TopoDS_Shape& aShape,
const bool considerMesh=false);
protected: protected:
@ -125,7 +126,8 @@ protected:
SMESH_Mesh & theMesh, SMESH_Mesh & theMesh,
std::list<TopoDS_Edge>& theWire, std::list<TopoDS_Edge>& theWire,
std::vector<TopoDS_Vertex>& theVertices, std::vector<TopoDS_Vertex>& theVertices,
int & theNbDegenEdges); int & theNbDegenEdges,
const bool considerMesh);
// true if QuadranglePreference hypothesis is assigned that forces // true if QuadranglePreference hypothesis is assigned that forces