//---------------------------------------------------------------------------- // EgalTech 2018-2019 //---------------------------------------------------------------------------- // File : EGkCAvToolSurfTm.h Data : 06.06.19 Versione : 2.1f1 // Contenuto : Dichiarazione della classe ICAvToolSurfTm. // // // // Modifiche : 27.04.18 DS Creazione modulo. // 06.06.19 DS Aggiunta gestione di pił superfici. // //---------------------------------------------------------------------------- #pragma once #include "/EgtDev/Include/EGkSurfTriMesh.h" //----------------------- 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 ICurveComposite ; //----------------------------------------------------------------------------- class __declspec( novtable) ICAvToolSurfTm { public : virtual ~ICAvToolSurfTm( void) {} virtual bool SetSurfTm( const ISurfTriMesh& Stm) = 0 ; virtual bool AddSurfTm( const ISurfTriMesh& Stm) = 0 ; virtual bool SetStdTool( double dH, double dR, double dCornR) = 0 ; virtual bool SetAdvTool( double dH, double dR, double dTipH, double dTipR, double dCornR) = 0 ; virtual bool SetSawTool( double dH, double dR, double dThick, double dStemR, double dCornR) = 0 ; virtual bool SetGenTool( const ICurveComposite* pToolOutline) = 0 ; virtual double GetToolRadius( void) const = 0 ; virtual double GetToolHeight( void) const = 0 ; virtual double GetToolTipHeight( void) const = 0 ; virtual double GetToolTipRadius( void) const = 0 ; virtual double GetToolCornRadius( void) const = 0 ; virtual const ICurveComposite& GetToolOutline( bool bApprox = false) const = 0 ; virtual bool TestPosition( const Point3d& ptT, const Vector3d& vtDir, const Vector3d& vtMove, double& dTotDist, Vector3d* pvtTriaN = nullptr) const = 0 ; virtual bool TestPositionAdv( const Point3d& ptT, const Vector3d& vtDir, const Vector3d& vtMove, double& dTotDist, VCT3DVECTOR& vVtN) const = 0 ; virtual bool TestSeries( PNTUVECTOR& vPntM, const Vector3d& vtDir, const Vector3d& vtMove, double dProgCoeff = 1) = 0 ; virtual bool TestSeriesAdv( PNTUVVECTVECTOR& vPntM, const Vector3d& vtDir, const Vector3d& vtMove, double dProgCoeff = 1) = 0 ; virtual bool TestPath( PNTULIST& lPntM, const Vector3d& vtDir, const Vector3d& vtMove, double dLinTol, double dProgCoeff = 1) = 0 ; } ; //----------------------------------------------------------------------------- EGK_EXPORT ICAvToolSurfTm* CreateCAvToolSurfTm( void) ;