Files
EgtGeomKernel/DistLineLine.h
T
Dario Sassi 3020d9579e EgtGeomKernel 2.2h1 :
- richiesta licenza livello 22
- aggiunta distanza tra linee
- migliorato calcolo intersezione tra linea e TriMesh nel caso di linea appena esterna ad un bordo
- migliorata creazione Zmap da TriMesh.
2020-08-04 09:30:04 +00:00

57 lines
1.8 KiB
C++

// File : DistLineLine.h Data : Versione :
// Contenuto : Dichiarazione della classe distanza fra elementi lineari.
//
//
//
// Modifiche :
//
//
//----------------------------------------------------------------------------
#pragma once
#include "/EgtDev/Include/EGkVector3d.h"
#include "/EgtDev/Include/EGkPoint3d.h"
class DistLineLine
{
public :
DistLineLine( const Point3d& ptSt1, const Point3d& ptEn1,
const Point3d& ptSt2, const Point3d& ptEn2,
bool bIsSegment1 = true, bool bIsSegment2 = true) ;
DistLineLine( const Point3d& ptSt1, const Vector3d& vtD1, double dLen1,
const Point3d& ptSt2, const Vector3d& vtD2, double dLen2,
bool bIsSegment1 = true, bool bIsSegment2 = true) ;
public :
bool GetSqDist( double& dSqDist) ;
bool GetDist( double& dDist) ;
bool IsEpsilon( double dTol)
{
double dSqDist ;
return ( GetSqDist( dSqDist) && ( dSqDist < SQ_EPS_ZERO || dSqDist < dTol * dTol)) ;
}
bool IsSmall( void)
{
return IsEpsilon( EPS_SMALL) ;
}
bool IsZero( void)
{
return IsEpsilon( EPS_ZERO) ;
}
bool GetMinDistPoints( Point3d& ptMinDist1, Point3d& ptMinDist2) ;
bool GetParamsAtMinDistPoints( double& dPar1, double& dPar2) ;
private :
void Calculate( const Point3d& ptSt1, const Vector3d& vtD1, double dLen1,
const Point3d& ptSt2, const Vector3d& vtD2, double dLen2,
bool bIsSegment1 = true, bool bIsSegment2 = true) ;
private:
double m_dSqDist ;
double m_dDist ;
double m_dPar1 ;
double m_dPar2 ;
Point3d m_ptMinDist1 ;
Point3d m_ptMinDist2 ;
} ;