d2f7b89b04
- unificata proiezione di curve su superfici trimesh e bezier.
59 lines
2.9 KiB
C++
59 lines
2.9 KiB
C++
//----------------------------------------------------------------------------
|
|
// EgalTech 2023-2023
|
|
//----------------------------------------------------------------------------
|
|
// File : EGkProjectCurveSurfTm.h Data : 31.08.23 Versione : 2.5h3
|
|
// Contenuto : Dichiarazione funzioni proiezione curve su superficie Trimesh.
|
|
//
|
|
//
|
|
//
|
|
// Modifiche : 31.08.23 DS Creazione modulo.
|
|
//
|
|
//
|
|
//----------------------------------------------------------------------------
|
|
|
|
#pragma once
|
|
|
|
#include "/EgtDev/Include/EGkGeoPoint3d.h"
|
|
#include "/EgtDev/Include/EGkCurve.h"
|
|
#include "/EgtDev/Include/EGkSurf.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
|
|
|
|
//----------------------------------------------------------------------------
|
|
// Definizione di Punto 5assi e sue raccolte
|
|
struct Point5ax {
|
|
Point3d ptP ;
|
|
Vector3d vtDir ;
|
|
Vector3d vtDir2 ;
|
|
double dPar ;
|
|
int nFlag ;
|
|
Point5ax( void) : ptP(), vtDir(), vtDir2(), dPar(), nFlag() {} ;
|
|
Point5ax( const Point3d& ptBase, const Vector3d& vtTool, double dU, int nData)
|
|
: ptP( ptBase), vtDir( vtTool), vtDir2(), dPar( dU), nFlag( nData) {} ;
|
|
Point5ax( const Point3d& ptBase, const Vector3d& vtTool, const Vector3d& vtTool2, double dU, int nData)
|
|
: ptP( ptBase), vtDir( vtTool), vtDir2( vtTool2), dPar( dU), nFlag( nData) {} ;
|
|
} ;
|
|
typedef std::vector<Point5ax> PNT5AXVECTOR ; // vettore di Punti 5assi
|
|
|
|
//----------------------------------------------------------------------------
|
|
// Proiezione di una curva su una superficie TriMesh lungo la direzione data.
|
|
EGK_EXPORT bool ProjectCurveOnSurf( const ICurve& crCrv, const ISurf& sfSurf, const Vector3d& vtDir,
|
|
double dLinTol, double dMaxSegmLen, PNT5AXVECTOR& vPt5ax) ;
|
|
// Proiezione di una curva su una superficie TriMesh in direzione del punto
|
|
EGK_EXPORT bool ProjectCurveOnSurf( const ICurve& crCrv, const ISurf& sfSurf, const IGeoPoint3d& gpRef,
|
|
double dLinTol, double dMaxSegmLen, PNT5AXVECTOR& vPt5ax) ;
|
|
// Proiezione di una curva su una superficie TriMesh in direzione della curva
|
|
EGK_EXPORT bool ProjectCurveOnSurf( const ICurve& crCrv, const ISurf& sfSurf, const ICurve& crRef,
|
|
double dLinTol, double dMaxSegmLen, PNT5AXVECTOR& vPt5ax) ;
|
|
// Proiezione di una curva su una superficie TriMesh in direzione della superficie
|
|
EGK_EXPORT bool ProjectCurveOnSurf( const ICurve& crCrv, const ISurf& sfSurf, const ISurf& sfRef,
|
|
double dLinTol, double dMaxSegmLen, PNT5AXVECTOR& vPt5ax) ;
|
|
// Eliminazione punti proiettati in eccesso
|
|
EGK_EXPORT bool RemovePointsInExcess( PNT5AXVECTOR& vMyPt5ax, double dLinTol, double dMaxSegmLen, bool bTestDir = true) ;
|