9577094c3d
- Semplificazione funzioni per CAvToolSilhouette e CAvToolSurfTm.
55 lines
2.8 KiB
C++
55 lines
2.8 KiB
C++
//----------------------------------------------------------------------------
|
|
// 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) ;
|