//---------------------------------------------------------------------------- // EgalTech 2014-2019 //---------------------------------------------------------------------------- // File : EGkSurf.h Data : 06.06.19 Versione : 2.1f1 // Contenuto : Dichiarazione della interfaccia ISurf. // // // // Modifiche : 26.03.14 DS Creazione modulo. // // //---------------------------------------------------------------------------- #pragma once #include "/EgtDev/Include/EGkGeoObj.h" #include "/EgtDev/Include/EgtPointerOwner.h" #include #include //---------------------------------------------------------------------------- class __declspec( novtable) ISurf : public IGeoObj { public : // IGeoObj ISurf* Clone( void) const override = 0 ; public : virtual bool IsSimple( void) const = 0 ; virtual bool IsClosed( void) const = 0 ; virtual bool GetArea( double& dArea) const = 0 ; virtual bool GetVolume( double& dVolume) const = 0 ; virtual bool GetCentroid( Point3d& ptCen) const = 0 ; virtual bool Invert( void) = 0 ; } ; //---------------------------------------------------------------------------- inline const ISurf* GetSurf( const IGeoObj* pGObj) { if ( pGObj == nullptr || ( pGObj->GetType() & GEO_SURF) == 0) return nullptr ; return (static_cast(pGObj)) ; } inline ISurf* GetSurf( IGeoObj* pGObj) { if ( pGObj == nullptr || ( pGObj->GetType() & GEO_SURF) == 0) return nullptr ; return (static_cast(pGObj)) ; } //---------------------------------------------------------------------------- // Raccolte di puntatori a ISurf typedef std::vector CISURFPVECTOR ; // vettore di puntatori a const ISurf typedef std::vector ISURFPVECTOR ; // vettore di puntatori a ISurf typedef std::list ISURFPLIST ; // lista di puntatori a ISurf typedef std::vector> ISURFPOVECTOR ; // vettore di puntatori esclusivi a ISurf