// Created on: 1996-07-12 // Created by: Stagiaire Mary FABIEN // Copyright (c) 1996-1999 Matra Datavision // 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 _BRepTools_NurbsConvertModification_HeaderFile #define _BRepTools_NurbsConvertModification_HeaderFile #include #include #include #include #include #include #include #include class TopoDS_Face; class Geom_Surface; class TopLoc_Location; class TopoDS_Edge; class Geom_Curve; class TopoDS_Vertex; class gp_Pnt; class Geom2d_Curve; //! Defines a modification of the geometry by a Trsf //! from gp. All methods return True and transform the //! geometry. class BRepTools_NurbsConvertModification : public BRepTools_CopyModification { public: Standard_EXPORT BRepTools_NurbsConvertModification(); //! Returns true if the face has been //! modified. In this case, is the new geometric //! support of the face, the new location, //! the new tolerance. has to be set to //! true when the modification reverses the //! normal of the surface. (the wires have to be //! reversed). has to be set to //! true if the orientation of the modified //! face changes in the shells which contain it. //! Here, will return true if the //! -- gp_Trsf is negative. Standard_EXPORT bool NewSurface(const TopoDS_Face& F, occ::handle& S, TopLoc_Location& L, double& Tol, bool& RevWires, bool& RevFace) override; //! Returns true if the edge has been //! modified. In this case, is the new geometric //! support of the edge, the new location, //! the new tolerance. Otherwise, returns //! false, and , , are not //! significant. Standard_EXPORT bool NewCurve(const TopoDS_Edge& E, occ::handle& C, TopLoc_Location& L, double& Tol) override; //! Returns true if the vertex has been //! modified. In this case,

is the new geometric //! support of the vertex, the new tolerance. //! Otherwise, returns false, and

, //! are not significant. Standard_EXPORT bool NewPoint(const TopoDS_Vertex& V, gp_Pnt& P, double& Tol) override; //! Returns true if the edge has a new //! curve on surface on the face .In this case, //! is the new geometric support of the edge, the //! new location, the new tolerance. //! Otherwise, returns false, and , , //! are not significant. Standard_EXPORT bool NewCurve2d(const TopoDS_Edge& E, const TopoDS_Face& F, const TopoDS_Edge& NewE, const TopoDS_Face& NewF, occ::handle& C, double& Tol) override; //! Returns true if the Vertex has a new //! parameter on the edge . In this case,

is //! the parameter, the new tolerance. //! Otherwise, returns false, and

, //! are not significant. Standard_EXPORT bool NewParameter(const TopoDS_Vertex& V, const TopoDS_Edge& E, double& P, double& Tol) override; //! Returns the continuity of between //! and . //! //! is the new edge created from . //! (resp. ) is the new face created from //! (resp. ). Standard_EXPORT GeomAbs_Shape Continuity(const TopoDS_Edge& E, const TopoDS_Face& F1, const TopoDS_Face& F2, const TopoDS_Edge& NewE, const TopoDS_Face& NewF1, const TopoDS_Face& NewF2) override; //! Returns true if the face has been modified according to changed triangulation. //! If the face has been modified: //! - theTri is a new triangulation on the face Standard_EXPORT bool NewTriangulation(const TopoDS_Face& theFace, occ::handle& theTri) override; //! Returns true if the edge has been modified according to changed polygon. //! If the edge has been modified: //! - thePoly is a new polygon Standard_EXPORT bool NewPolygon(const TopoDS_Edge& theEdge, occ::handle& thePoly) override; //! Returns true if the edge has been modified according to changed polygon on triangulation. //! If the edge has been modified: //! - thePoly is a new polygon on triangulation Standard_EXPORT bool NewPolygonOnTriangulation( const TopoDS_Edge& theEdge, const TopoDS_Face& theFace, occ::handle& thePoly) override; Standard_EXPORT const NCollection_List& GetUpdatedEdges() const; DEFINE_STANDARD_RTTIEXT(BRepTools_NurbsConvertModification, BRepTools_CopyModification) private: NCollection_List myled; NCollection_List> mylcu; NCollection_IndexedDataMap, occ::handle> myMap; NCollection_List myUpdatedEdges; }; #endif // _BRepTools_NurbsConvertModification_HeaderFile