mirror of
https://git.salome-platform.org/gitpub/modules/smesh.git
synced 2025-01-27 07:40:34 +05:00
Fix regression of SMESH_TEST/Grids/smesh/3D_mesh_Extrusion/A3
+ static bool isStraight( const TopoDS_Edge & E, const bool degenResult=false );
This commit is contained in:
parent
4d6cb35b78
commit
2d070665a5
@ -529,6 +529,57 @@ GeomAbs_Shape SMESH_Algo::Continuity(TopoDS_Edge E1,
|
||||
return GeomAbs_C0;
|
||||
}
|
||||
|
||||
//================================================================================
|
||||
/*!
|
||||
* \brief Return true if an edge can be considered straight
|
||||
*/
|
||||
//================================================================================
|
||||
|
||||
bool SMESH_Algo::isStraight( const TopoDS_Edge & E,
|
||||
const bool degenResult)
|
||||
{
|
||||
{
|
||||
double f,l;
|
||||
if ( BRep_Tool::Curve( E, f, l ).IsNull())
|
||||
return degenResult;
|
||||
}
|
||||
BRepAdaptor_Curve curve( E );
|
||||
switch( curve.GetType() )
|
||||
{
|
||||
case GeomAbs_Line:
|
||||
return true;
|
||||
case GeomAbs_Circle:
|
||||
case GeomAbs_Ellipse:
|
||||
case GeomAbs_Hyperbola:
|
||||
case GeomAbs_Parabola:
|
||||
return false;
|
||||
// case GeomAbs_BezierCurve:
|
||||
// case GeomAbs_BSplineCurve:
|
||||
// case GeomAbs_OtherCurve:
|
||||
default:;
|
||||
}
|
||||
const double f = curve.FirstParameter();
|
||||
const double l = curve.LastParameter();
|
||||
const gp_Pnt pf = curve.Value( f );
|
||||
const gp_Pnt pl = curve.Value( l );
|
||||
const gp_Vec v1( pf, pl );
|
||||
const double v1Len = v1.Magnitude();
|
||||
if ( v1Len < std::numeric_limits< double >::min() )
|
||||
return false; // E seems closed
|
||||
const double tol = Min( 10 * curve.Tolerance(), v1Len * 1e-2 );
|
||||
const int nbSamples = 7;
|
||||
for ( int i = 0; i < nbSamples; ++i )
|
||||
{
|
||||
const double r = ( i + 1 ) / nbSamples;
|
||||
const gp_Pnt pi = curve.Value( f * r + l * ( 1 - r ));
|
||||
const gp_Vec vi( pf, pi );
|
||||
const double h = 0.5 * v1.Crossed( vi ).Magnitude() / v1Len;
|
||||
if ( h > tol )
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
//================================================================================
|
||||
/*!
|
||||
* \brief Return the node built on a vertex
|
||||
|
@ -357,6 +357,10 @@ public:
|
||||
static bool IsContinuous(const TopoDS_Edge & E1, const TopoDS_Edge & E2) {
|
||||
return ( Continuity( E1, E2 ) >= GeomAbs_G1 );
|
||||
}
|
||||
/*!
|
||||
* \brief Return true if an edge can be considered straight
|
||||
*/
|
||||
static bool isStraight( const TopoDS_Edge & E, const bool degenResult=false );
|
||||
|
||||
/*!
|
||||
* \brief Return the node built on a vertex
|
||||
|
Loading…
Reference in New Issue
Block a user