EgtGeomKernel :
- cambiata la chiamata a ModifyJoint - cambiato nome alla ModifySingleCurve - estesa la ModifyJoint con tolleranza - modifiche stilistiche e pulizia codice.
This commit is contained in:
@@ -4502,55 +4502,6 @@ ChangeStartForClosed( PolyLine& plU0, PolyLine& plU1, ICurveComposite* pCrvU0, I
|
||||
return true ;
|
||||
}
|
||||
|
||||
static bool
|
||||
GetEdgeSplitByAngTol( const PolyLine& PL, double dAngTol, BOOLVECTOR& vEdgeSplit)
|
||||
{
|
||||
int nPoints = PL.GetPointNbr() ;
|
||||
vEdgeSplit.clear() ;
|
||||
vEdgeSplit.resize( nPoints) ;
|
||||
fill( vEdgeSplit.begin(), vEdgeSplit.end(), false) ;
|
||||
bool bClosed = PL.IsClosed() ;
|
||||
// Recupero l'insieme di punti associati alla PolyLine
|
||||
PNTVECTOR vPoints ; vPoints.reserve( nPoints) ;
|
||||
Point3d ptCurr = P_INVALID ;
|
||||
// aggiungo come primo punto il penultimo punto della polyline in modo da analizzare direttamente anche la chiusura ( se è una polyline chiusa)
|
||||
PL.GetLastPoint( ptCurr) ;
|
||||
PL.GetPrevPoint( ptCurr) ;
|
||||
vPoints.emplace_back( ptCurr) ;
|
||||
bool bFound = PL.GetFirstPoint( ptCurr) ;
|
||||
while ( bFound) {
|
||||
vPoints.emplace_back( ptCurr) ;
|
||||
bFound = PL.GetNextPoint( ptCurr) ;
|
||||
}
|
||||
Vector3d vtTanCurr = V_INVALID, vtTanNext = V_INVALID ;
|
||||
// cos della tolleranza angolare massima
|
||||
double dCosTol = cos( dAngTol * DEGTORAD) ;
|
||||
for ( int nP = 0 ; nP < nPoints - 2 ; ++ nP) {
|
||||
// Recupero il punto corrente e i due punti successivi
|
||||
Point3d& ptCurr = vPoints[nP] ;
|
||||
Point3d& ptNext = vPoints[nP + 1] ;
|
||||
Point3d& ptNextNext = vPoints[nP + 2] ;
|
||||
// Recupero i versori tangenti definiti dai tre punti ( ptCurr|ptNext e ptNext|ptNextNext)
|
||||
if ( nP == 0) {
|
||||
vtTanCurr = ptNext - ptCurr ;
|
||||
vtTanCurr.Normalize() ;
|
||||
}
|
||||
else
|
||||
vtTanCurr = vtTanNext ;
|
||||
vtTanNext = ptNextNext - ptNext ; vtTanNext.Normalize() ;
|
||||
// Calcolo il Coseno tra i due versori
|
||||
double dCos = vtTanCurr * vtTanNext ;
|
||||
// Se oltre la tolleranza allora ho incontrato un edge
|
||||
if ( dCos < dCosTol)
|
||||
vEdgeSplit[nP] = true ;
|
||||
}
|
||||
|
||||
if ( ! bClosed)
|
||||
vEdgeSplit[0] = false ;
|
||||
|
||||
return true ;
|
||||
}
|
||||
|
||||
static bool
|
||||
GetEdgeSplitByAngTol( const ICurveComposite* pCC, double dAngTol, BOOLVECTOR& vEdgeSplit)
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user