Files
Include/EGkCurveByApprox.h
Dario Sassi 20bd63e047 Include :
- modifiche di stile.
2017-11-02 07:31:48 +00:00

57 lines
1.8 KiB
C++

//----------------------------------------------------------------------------
// EgalTech 2015-2015
//----------------------------------------------------------------------------
// File : EGkCurveByApprox.h Data : 23.07.15 Versione : 1.6g7
// Contenuto : Dichiarazione della classe CurveByApprox.
//
//
//
// Modifiche : 23.07.15 DS Creazione modulo.
//
//
//----------------------------------------------------------------------------
#pragma once
#include"/EgtDev/Include/EGkGeoCollection.h"
class ICurve ;
class PolyLine ;
class PolyArc ;
//----------------------- Macro per import/export ----------------------------
#undef EGK_EXPORT
#if defined( I_AM_EGK) // da definirsi solo nella DLL
#define EGK_EXPORT __declspec( dllexport)
#else
#define EGK_EXPORT __declspec( dllimport)
#endif
//----------------------------------------------------------------------------
class CurveByApprox
{
public :
EGK_EXPORT bool Reset( void) ;
EGK_EXPORT bool AddPoint( const Point3d& ptP) ;
EGK_EXPORT ICurve* GetCurve( int nType, double dLinTol, double dAngTolDeg, double dLinFea) ;
EGK_EXPORT bool GetArcs( double dLinTol, double dAngTolDeg, double dLinFea, PolyArc& PA) ;
public :
enum TYPE { ARCS_CORNER = 1, CUBIC_BEZIERS = 2} ;
private :
bool CalcParameterization( void) ;
bool CalcAkimaTangents( bool bCorner) ;
bool CalcBesselTangents( void) ;
bool CalcSplitPoints( double dLinTol, double dAngTolDeg, double dLinFea) ;
bool BiArcOrSplit( int nLev, PolyLine& PL, double dLinTol, double dAngTolDeg, PolyArc& PA) const ;
private :
PNTVECTOR m_vPnt ;
DBLVECTOR m_vPar ;
VCT3DVECTOR m_vPrevDer ;
VCT3DVECTOR m_vNextDer ;
INTVECTOR m_vSplits ;
} ;