// Created by: Eugeny MALTCHIKOV // Copyright (c) 2017 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // // This library is free software; you can redistribute it and/or modify it under // the terms of the GNU Lesser General Public License version 2.1 as published // by the Free Software Foundation, with special exception defined in the file // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT // distribution for complete text of the license and disclaimer of any warranty. // // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. #ifndef _IntPolyh_Tools_HeaderFile #define _IntPolyh_Tools_HeaderFile #include #include class Adaptor3d_HSurface; //! The class provides tools for surface sampling. class IntPolyh_Tools { public: //! Checks if the surface can be enlarged in U or V direction. Standard_EXPORT static void IsEnlargePossible(const Handle(Adaptor3d_HSurface)& theSurf, Standard_Boolean& theUEnlarge, Standard_Boolean& theVEnlarge); //! Makes the sampling of the given surface //! making the net of x sampling points. //! The flag controls the enlargement of the //! sampling zone on the surface. //! The parameters of the sampling points are stored into //! and arrays. Standard_EXPORT static void MakeSampling(const Handle(Adaptor3d_HSurface)& theSurf, const Standard_Integer theNbSU, const Standard_Integer theNbSV, const Standard_Boolean theEnlargeZone, TColStd_Array1OfReal& theUPars, TColStd_Array1OfReal& theVPars); //! Computes the deflection tolerance on the surface for the given sampling. Standard_EXPORT static Standard_Real ComputeDeflection(const Handle(Adaptor3d_HSurface)& theSurf, const TColStd_Array1OfReal& theUPars, const TColStd_Array1OfReal& theVPars); //! Fills the array with the points (triangulation nodes) on the surface //! and normal directions of the surface in these points. Standard_EXPORT static void FillArrayOfPointNormal(const Handle(Adaptor3d_HSurface)& theSurf, const TColStd_Array1OfReal& theUPars, const TColStd_Array1OfReal& theVPars, IntPolyh_ArrayOfPointNormal& thePoints); }; #endif // _IntPolyh_Tools_HeaderFile