// Created by: Peter KURNEV // Copyright (c) 1999-2014 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 _BOPTools_AlgoTools2D_HeaderFile #define _BOPTools_AlgoTools2D_HeaderFile #include #include #include #include #include #include #include class TopoDS_Edge; class TopoDS_Face; class gp_Vec; class Geom2d_Curve; class Geom_Curve; class BRepAdaptor_Surface; class ProjLib_ProjectedCurve; class IntTools_Context; //! The class contains handy static functions //! dealing with the topology //! This is the copy of the BOPTools_AlgoTools2D.cdl class BOPTools_AlgoTools2D { public: DEFINE_STANDARD_ALLOC //! Compute P-Curve for the edge on the face .
//! Raises exception Standard_ConstructionError if projection algorithm fails.
//! - storage for caching the geometrical tools Standard_EXPORT static void BuildPCurveForEdgeOnFace (const TopoDS_Edge& aE, const TopoDS_Face& aF, const Handle(IntTools_Context)& theContext = Handle(IntTools_Context)()); //! Compute tangent for the edge [in 3D] at parameter Standard_EXPORT static Standard_Boolean EdgeTangent (const TopoDS_Edge& anE, const Standard_Real aT, gp_Vec& Tau); //! Compute surface parameters of the face //! for the point from the edge at parameter .
//! If has't pcurve on surface, algorithm tries to get it by //! projection and can //! raise exception Standard_ConstructionError if projection algorithm fails.
//! - storage for caching the geometrical tools Standard_EXPORT static void PointOnSurface (const TopoDS_Edge& aE, const TopoDS_Face& aF, const Standard_Real aT, Standard_Real& U, Standard_Real& V, const Handle(IntTools_Context)& theContext = Handle(IntTools_Context)()); //! Get P-Curve for the edge on surface .
//! If the P-Curve does not exist, build it using Make2D().
//! [aToler] - reached tolerance //! Raises exception Standard_ConstructionError if algorithm Make2D() fails.
//! - storage for caching the geometrical tools Standard_EXPORT static void CurveOnSurface (const TopoDS_Edge& aE, const TopoDS_Face& aF, Handle(Geom2d_Curve)& aC, Standard_Real& aToler, const Handle(IntTools_Context)& theContext = Handle(IntTools_Context)()); //! Get P-Curve for the edge on surface .
//! If the P-Curve does not exist, build it using Make2D().
//! [aFirst, aLast] - range of the P-Curve
//! [aToler] - reached tolerance
//! Raises exception Standard_ConstructionError if algorithm Make2D() fails.
//! - storage for caching the geometrical tools Standard_EXPORT static void CurveOnSurface (const TopoDS_Edge& aE, const TopoDS_Face& aF, Handle(Geom2d_Curve)& aC, Standard_Real& aFirst, Standard_Real& aLast, Standard_Real& aToler, const Handle(IntTools_Context)& theContext = Handle(IntTools_Context)()); //! Returns TRUE if the edge has P-Curve //! on surface . //! [aFirst, aLast] - range of the P-Curve //! [aToler] - reached tolerance //! If the P-Curve does not exist, aC.IsNull()=TRUE. Standard_EXPORT static Standard_Boolean HasCurveOnSurface (const TopoDS_Edge& aE, const TopoDS_Face& aF, Handle(Geom2d_Curve)& aC, Standard_Real& aFirst, Standard_Real& aLast, Standard_Real& aToler); //! Returns TRUE if the edge has P-Curve //! on surface . //! If the P-Curve does not exist, aC.IsNull()=TRUE. Standard_EXPORT static Standard_Boolean HasCurveOnSurface (const TopoDS_Edge& aE, const TopoDS_Face& aF); //! Adjust P-Curve (3D-curve ) on surface of the face .
//! - storage for caching the geometrical tools Standard_EXPORT static void AdjustPCurveOnFace (const TopoDS_Face& theF, const Handle(Geom_Curve)& theC3D, const Handle(Geom2d_Curve)& theC2D, Handle(Geom2d_Curve)& theC2DA, const Handle(IntTools_Context)& theContext = Handle(IntTools_Context)()); //! Adjust P-Curve (3D-curve ) on surface .
//! [aT1, aT2] - range to adjust
//! - storage for caching the geometrical tools Standard_EXPORT static void AdjustPCurveOnFace (const TopoDS_Face& theF, const Standard_Real theFirst, const Standard_Real theLast, const Handle(Geom2d_Curve)& theC2D, Handle(Geom2d_Curve)& theC2DA, const Handle(IntTools_Context)& theContext = Handle(IntTools_Context)()); //! Adjust P-Curve (3D-curve ) on surface . //! [aT1, aT2] - range to adjust Standard_EXPORT static void AdjustPCurveOnSurf (const BRepAdaptor_Surface& aF, const Standard_Real aT1, const Standard_Real aT2, const Handle(Geom2d_Curve)& aC2D, Handle(Geom2d_Curve)& aC2DA); //! Compute intermediate value in between [aFirst, aLast] . Standard_EXPORT static Standard_Real IntermediatePoint (const Standard_Real aFirst, const Standard_Real aLast); //! Compute intermediate value of parameter for the edge . Standard_EXPORT static Standard_Real IntermediatePoint (const TopoDS_Edge& anE); //! Build pcurve of edge on face if the surface is plane, and update the edge. Standard_EXPORT static void BuildPCurveForEdgeOnPlane (const TopoDS_Edge& theE, const TopoDS_Face& theF); //! Build pcurve of edge on face if the surface is plane, but do not update the edge. //! The output are the pcurve and the flag telling that pcurve was built. Standard_EXPORT static void BuildPCurveForEdgeOnPlane (const TopoDS_Edge& theE, const TopoDS_Face& theF, Handle(Geom2d_Curve)& aC2D, Standard_Boolean& bToUpdate); Standard_EXPORT static void BuildPCurveForEdgesOnPlane (const BOPCol_ListOfShape& theLE, const TopoDS_Face& theF); //! Make P-Curve for the edge on surface .
//! [aFirst, aLast] - range of the P-Curve
//! [aToler] - reached tolerance
//! Raises exception Standard_ConstructionError if algorithm fails.
//! - storage for caching the geometrical tools Standard_EXPORT static void Make2D (const TopoDS_Edge& aE, const TopoDS_Face& aF, Handle(Geom2d_Curve)& aC, Standard_Real& aFirst, Standard_Real& aLast, Standard_Real& aToler, const Handle(IntTools_Context)& theContext = Handle(IntTools_Context)()); //! Make P-Curve for the 3D-curve on surface .
//! [aToler] - reached tolerance
//! Raises exception Standard_ConstructionError if projection algorithm fails.
//! - storage for caching the geometrical tools Standard_EXPORT static void MakePCurveOnFace (const TopoDS_Face& aF, const Handle(Geom_Curve)& C3D, Handle(Geom2d_Curve)& aC, Standard_Real& aToler, const Handle(IntTools_Context)& theContext = Handle(IntTools_Context)()); //! Make P-Curve for the 3D-curve on surface .
//! [aT1, aT2] - range to build
//! [aToler] - reached tolerance
//! Raises exception Standard_ConstructionError if projection algorithm fails.
//! - storage for caching the geometrical tools Standard_EXPORT static void MakePCurveOnFace (const TopoDS_Face& aF, const Handle(Geom_Curve)& C3D, const Standard_Real aT1, const Standard_Real aT2, Handle(Geom2d_Curve)& aC, Standard_Real& aToler, const Handle(IntTools_Context)& theContext = Handle(IntTools_Context)()); //! Make empty P-Curve of relevant to type Standard_EXPORT static void MakePCurveOfType (const ProjLib_ProjectedCurve& PC, Handle(Geom2d_Curve)& aC); //! Attach P-Curve from the edge on surface //! to the edge //! Returns 0 in case of success Standard_EXPORT static Standard_Integer AttachExistingPCurve (const TopoDS_Edge& aEold, const TopoDS_Edge& aEnew, const TopoDS_Face& aF, const Handle(IntTools_Context)& aCtx); //! Checks if CurveOnSurface of theE on theF matches with isoline of theF surface. //! Sets corresponding values for isTheUIso and isTheVIso variables. //! ATTENTION!!! //! This method is based on comparation between direction of //! surface (which theF is based on) iso-lines and the direction //! of the edge p-curve (on theF) in middle-point of the p-curve. //! This method should be used carefully //! (e.g. BRep_Tool::IsClosed(...) together) in order to //! avoid false classification some p-curves as isoline (e.g. circle //! on a plane). Standard_EXPORT static void IsEdgeIsoline(const TopoDS_Edge& theE, const TopoDS_Face& theF, Standard_Boolean& isTheUIso, Standard_Boolean& isTheVIso); protected: private: }; #endif // _BOPTools_AlgoTools2D_HeaderFile