// Created on: 1996-12-30 // 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_GTrsfModification_HeaderFile #define _BRepTools_GTrsfModification_HeaderFile #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; class BRepTools_GTrsfModification; DEFINE_STANDARD_HANDLE(BRepTools_GTrsfModification, BRepTools_Modification) //! Defines a modification of the geometry by a GTrsf //! from gp. All methods return True and transform the //! geometry. class BRepTools_GTrsfModification : public BRepTools_Modification { public: Standard_EXPORT BRepTools_GTrsfModification(const gp_GTrsf& T); //! Gives an access on the GTrsf. Standard_EXPORT gp_GTrsf& GTrsf(); //! Returns Standard_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 //! Standard_True when the modification reverses the //! normal of the surface.(the wires have to be //! reversed). has to be set to //! Standard_True if the orientation of the modified //! face changes in the shells which contain it. -- //! Here, will return Standard_True if the //! -- gp_Trsf is negative. Standard_EXPORT Standard_Boolean NewSurface (const TopoDS_Face& F, Handle(Geom_Surface)& S, TopLoc_Location& L, Standard_Real& Tol, Standard_Boolean& RevWires, Standard_Boolean& RevFace) Standard_OVERRIDE; //! Returns Standard_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 //! Standard_False, and , , are not //! significant. Standard_EXPORT Standard_Boolean NewCurve (const TopoDS_Edge& E, Handle(Geom_Curve)& C, TopLoc_Location& L, Standard_Real& Tol) Standard_OVERRIDE; //! Returns Standard_True if the vertex has been //! modified. In this case,

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

, //! are not significant. Standard_EXPORT Standard_Boolean NewPoint (const TopoDS_Vertex& V, gp_Pnt& P, Standard_Real& Tol) Standard_OVERRIDE; //! Returns Standard_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 Standard_False, and , , //! are not significant. Standard_EXPORT Standard_Boolean NewCurve2d (const TopoDS_Edge& E, const TopoDS_Face& F, const TopoDS_Edge& NewE, const TopoDS_Face& NewF, Handle(Geom2d_Curve)& C, Standard_Real& Tol) Standard_OVERRIDE; //! Returns Standard_True if the Vertex has a new //! parameter on the edge . In this case,

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

, //! are not significant. Standard_EXPORT Standard_Boolean NewParameter (const TopoDS_Vertex& V, const TopoDS_Edge& E, Standard_Real& P, Standard_Real& Tol) Standard_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) Standard_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 Standard_Boolean NewTriangulation(const TopoDS_Face& theFace, Handle(Poly_Triangulation)& theTri) Standard_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 Standard_Boolean NewPolygon(const TopoDS_Edge& theEdge, Handle(Poly_Polygon3D)& thePoly) Standard_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 Standard_Boolean NewPolygonOnTriangulation(const TopoDS_Edge& theEdge, const TopoDS_Face& theFace, Handle(Poly_PolygonOnTriangulation)& thePoly) Standard_OVERRIDE; DEFINE_STANDARD_RTTIEXT(BRepTools_GTrsfModification,BRepTools_Modification) protected: private: gp_GTrsf myGTrsf; Standard_Real myGScale; }; #endif // _BRepTools_GTrsfModification_HeaderFile