0026377: Passing Handle objects as arguments to functions as non-const reference...
[occt.git] / src / IGESToBRep / IGESToBRep_TopoCurve.hxx
1 // Created on: 1994-04-21
2 // Created by: s:       Christophe GUYOT & Frederic UNTEREINER
3 // Copyright (c) 1994-1999 Matra Datavision
4 // Copyright (c) 1999-2014 OPEN CASCADE SAS
5 //
6 // This file is part of Open CASCADE Technology software library.
7 //
8 // This library is free software; you can redistribute it and/or modify it under
9 // the terms of the GNU Lesser General Public License version 2.1 as published
10 // by the Free Software Foundation, with special exception defined in the file
11 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
12 // distribution for complete text of the license and disclaimer of any warranty.
13 //
14 // Alternatively, this file may be used under the terms of Open CASCADE
15 // commercial license or contractual agreement.
16
17 #ifndef _IGESToBRep_TopoCurve_HeaderFile
18 #define _IGESToBRep_TopoCurve_HeaderFile
19
20 #include <Standard.hxx>
21 #include <Standard_DefineAlloc.hxx>
22 #include <Standard_Handle.hxx>
23
24 #include <TColGeom_SequenceOfCurve.hxx>
25 #include <TColGeom2d_SequenceOfCurve.hxx>
26 #include <Standard_Boolean.hxx>
27 #include <IGESToBRep_CurveAndSurface.hxx>
28 #include <Standard_Real.hxx>
29 #include <Standard_Integer.hxx>
30 class IGESToBRep_CurveAndSurface;
31 class TopoDS_Shape;
32 class IGESData_IGESEntity;
33 class TopoDS_Face;
34 class gp_Trsf2d;
35 class TopoDS_Vertex;
36 class IGESGeom_Point;
37 class IGESGeom_CompositeCurve;
38 class IGESGeom_OffsetCurve;
39 class IGESGeom_CurveOnSurface;
40 class IGESGeom_Boundary;
41 class Geom_BSplineCurve;
42 class Geom_Curve;
43 class Geom2d_BSplineCurve;
44 class Geom2d_Curve;
45
46
47 //! Provides methods to transfer topologic curves entities
48 //! from IGES to CASCADE.
49 class IGESToBRep_TopoCurve  : public IGESToBRep_CurveAndSurface
50 {
51 public:
52
53   DEFINE_STANDARD_ALLOC
54
55   
56   //! Creates  a tool TopoCurve  ready  to  run, with
57   //! epsilons  set  to  1.E-04,  TheModeTopo  to  True,  the
58   //! optimization of  the continuity to False.
59   Standard_EXPORT IGESToBRep_TopoCurve();
60   
61   //! Creates a tool TopoCurve ready to run and sets its
62   //! fields as CS's.
63   Standard_EXPORT IGESToBRep_TopoCurve(const IGESToBRep_CurveAndSurface& CS);
64   
65   //! Creates a tool TopoCurve ready to run and sets its
66   //! fields as CS's.
67   Standard_EXPORT IGESToBRep_TopoCurve(const IGESToBRep_TopoCurve& CS);
68   
69   //! Creates a tool TopoCurve ready to run.
70   Standard_EXPORT IGESToBRep_TopoCurve(const Standard_Real eps, const Standard_Real epsGeom, const Standard_Real epsCoeff, const Standard_Boolean mode, const Standard_Boolean modeapprox, const Standard_Boolean optimized);
71   
72   Standard_EXPORT TopoDS_Shape TransferTopoCurve (const Handle(IGESData_IGESEntity)& start);
73   
74   Standard_EXPORT TopoDS_Shape Transfer2dTopoCurve (const Handle(IGESData_IGESEntity)& start, const TopoDS_Face& face, const gp_Trsf2d& trans, const Standard_Real uFact);
75   
76   Standard_EXPORT TopoDS_Shape TransferTopoBasicCurve (const Handle(IGESData_IGESEntity)& start);
77   
78   Standard_EXPORT TopoDS_Shape Transfer2dTopoBasicCurve (const Handle(IGESData_IGESEntity)& start, const TopoDS_Face& face, const gp_Trsf2d& trans, const Standard_Real uFact);
79   
80   Standard_EXPORT TopoDS_Vertex TransferPoint (const Handle(IGESGeom_Point)& start);
81   
82   Standard_EXPORT TopoDS_Vertex Transfer2dPoint (const Handle(IGESGeom_Point)& start);
83   
84   Standard_EXPORT TopoDS_Shape TransferCompositeCurve (const Handle(IGESGeom_CompositeCurve)& start);
85   
86   Standard_EXPORT TopoDS_Shape Transfer2dCompositeCurve (const Handle(IGESGeom_CompositeCurve)& start, const TopoDS_Face& face, const gp_Trsf2d& trans, const Standard_Real uFact);
87   
88   Standard_EXPORT TopoDS_Shape TransferOffsetCurve (const Handle(IGESGeom_OffsetCurve)& start);
89   
90   Standard_EXPORT TopoDS_Shape Transfer2dOffsetCurve (const Handle(IGESGeom_OffsetCurve)& start, const TopoDS_Face& face, const gp_Trsf2d& trans, const Standard_Real uFact);
91   
92   Standard_EXPORT TopoDS_Shape TransferCurveOnSurface (const Handle(IGESGeom_CurveOnSurface)& start);
93   
94   //! Transfers a CurveOnSurface directly on a face to trim it.
95   //! The CurveOnSurface have to be defined Outer or Inner.
96   Standard_EXPORT TopoDS_Shape TransferCurveOnFace (TopoDS_Face& face, const Handle(IGESGeom_CurveOnSurface)& start, const gp_Trsf2d& trans, const Standard_Real uFact, const Standard_Boolean IsCurv);
97   
98   Standard_EXPORT TopoDS_Shape TransferBoundary (const Handle(IGESGeom_Boundary)& start);
99   
100   //! Transfers a Boundary directly on a face to trim it.
101   Standard_EXPORT TopoDS_Shape TransferBoundaryOnFace (TopoDS_Face& face, const Handle(IGESGeom_Boundary)& start, const gp_Trsf2d& trans, const Standard_Real uFact);
102   
103   Standard_EXPORT void ApproxBSplineCurve (const Handle(Geom_BSplineCurve)& start);
104   
105   //! Returns the count of Curves in "TheCurves"
106   Standard_EXPORT Standard_Integer NbCurves() const;
107   
108   //! Returns a Curve given its rank, by default the first one
109   //! (null Curvee if out of range) in "TheCurves"
110   Standard_EXPORT Handle(Geom_Curve) Curve (const Standard_Integer num = 1) const;
111   
112   Standard_EXPORT void Approx2dBSplineCurve (const Handle(Geom2d_BSplineCurve)& start);
113   
114   //! Returns the count of Curves in "TheCurves2d"
115   Standard_EXPORT Standard_Integer NbCurves2d() const;
116   
117   //! Returns a Curve given its rank, by default the first one
118   //! (null Curvee if out of range) in "TheCurves2d"
119   Standard_EXPORT Handle(Geom2d_Curve) Curve2d (const Standard_Integer num = 1) const;
120   
121   //! Sets TheBadCase flag
122   Standard_EXPORT void SetBadCase (const Standard_Boolean value);
123   
124   //! Returns TheBadCase flag
125   Standard_EXPORT Standard_Boolean BadCase() const;
126
127
128
129
130 protected:
131
132
133
134
135
136 private:
137
138   
139   Standard_EXPORT TopoDS_Shape TransferCompositeCurveGeneral (const Handle(IGESGeom_CompositeCurve)& start, const Standard_Boolean is2d, const TopoDS_Face& face, const gp_Trsf2d& trans, const Standard_Real uFact);
140
141
142   TColGeom_SequenceOfCurve TheCurves;
143   TColGeom2d_SequenceOfCurve TheCurves2d;
144   Standard_Boolean TheBadCase;
145
146
147 };
148
149
150
151
152
153
154
155 #endif // _IGESToBRep_TopoCurve_HeaderFile