1 // Created on: 1995-07-18
2 // Created by: Modelistation
3 // Copyright (c) 1995-1999 Matra Datavision
4 // Copyright (c) 1999-2014 OPEN CASCADE SAS
6 // This file is part of Open CASCADE Technology software library.
8 // This library is free software; you can redistribute it and / or modify it
9 // under the terms of the GNU Lesser General Public 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.
14 // Alternatively, this file may be used under the terms of Open CASCADE
15 // commercial license or contractual agreement.
17 #include <gp_Lin2d.hxx>
18 #include <gp_Elips2d.hxx>
19 #include <gp_Circ2d.hxx>
20 #include <gp_Hypr2d.hxx>
21 #include <gp_Parab2d.hxx>
22 #include <Geom2d_BezierCurve.hxx>
23 #include <Geom2d_BSplineCurve.hxx>
24 #include <Adaptor2d_Curve2d.hxx>
26 //=======================================================================
27 //function : FirstParameter
29 //=======================================================================
31 inline Standard_Real Extrema_Curve2dTool::FirstParameter(const Adaptor2d_Curve2d& C)
33 return C.FirstParameter();
36 //=======================================================================
37 //function : LastParameter
39 //=======================================================================
41 inline Standard_Real Extrema_Curve2dTool::LastParameter(const Adaptor2d_Curve2d& C)
43 return C.LastParameter();
46 //=======================================================================
47 //function : Continuity
49 //=======================================================================
51 inline GeomAbs_Shape Extrema_Curve2dTool::Continuity(const Adaptor2d_Curve2d& C)
53 return C.Continuity();
56 //=======================================================================
57 //function : NbIntervals
59 //=======================================================================
61 inline Standard_Integer Extrema_Curve2dTool::NbIntervals(const Adaptor2d_Curve2d& C,
62 const GeomAbs_Shape S)
64 return C.NbIntervals(S);
67 //=======================================================================
68 //function : Intervals
70 //=======================================================================
72 inline void Extrema_Curve2dTool::Intervals(const Adaptor2d_Curve2d& C,
73 TColStd_Array1OfReal& T,
74 const GeomAbs_Shape S)
79 //=======================================================================
82 //=======================================================================
84 inline Standard_Boolean Extrema_Curve2dTool::IsClosed(const Adaptor2d_Curve2d& C)
89 //=======================================================================
90 //function : IsPeriodic
92 //=======================================================================
94 inline Standard_Boolean Extrema_Curve2dTool::IsPeriodic(const Adaptor2d_Curve2d& C)
96 return C.IsPeriodic();
99 //=======================================================================
102 //=======================================================================
104 inline Standard_Real Extrema_Curve2dTool::Period(const Adaptor2d_Curve2d& C)
109 //=======================================================================
112 //=======================================================================
114 inline gp_Pnt2d Extrema_Curve2dTool::Value(const Adaptor2d_Curve2d& C,
115 const Standard_Real U)
120 //=======================================================================
123 //=======================================================================
125 inline void Extrema_Curve2dTool::D0(const Adaptor2d_Curve2d& C,
126 const Standard_Real U,
132 //=======================================================================
135 //=======================================================================
137 inline void Extrema_Curve2dTool::D1(const Adaptor2d_Curve2d& C,
138 const Standard_Real U,
145 //=======================================================================
148 //=======================================================================
150 inline void Extrema_Curve2dTool::D2(const Adaptor2d_Curve2d& C,
151 const Standard_Real U,
159 //=======================================================================
162 //=======================================================================
164 inline void Extrema_Curve2dTool::D3(const Adaptor2d_Curve2d& C,
165 const Standard_Real U,
171 C.D3(U, P, V1, V2, V3);
174 //=======================================================================
177 //=======================================================================
179 inline gp_Vec2d Extrema_Curve2dTool::DN(const Adaptor2d_Curve2d& C,
180 const Standard_Real U,
181 const Standard_Integer N)
186 //=======================================================================
187 //function : Resolution
189 //=======================================================================
191 inline Standard_Real Extrema_Curve2dTool::Resolution(const Adaptor2d_Curve2d& C,
192 const Standard_Real R3d)
194 return C.Resolution(R3d);
197 //=======================================================================
200 //=======================================================================
202 inline GeomAbs_CurveType Extrema_Curve2dTool::GetType(const Adaptor2d_Curve2d& C)
207 //=======================================================================
210 //=======================================================================
212 inline gp_Lin2d Extrema_Curve2dTool::Line(const Adaptor2d_Curve2d& C)
217 //=======================================================================
220 //=======================================================================
222 inline gp_Circ2d Extrema_Curve2dTool::Circle(const Adaptor2d_Curve2d& C)
227 //=======================================================================
230 //=======================================================================
232 inline gp_Elips2d Extrema_Curve2dTool::Ellipse(const Adaptor2d_Curve2d& C)
237 //=======================================================================
238 //function : Hyperbola
240 //=======================================================================
242 inline gp_Hypr2d Extrema_Curve2dTool::Hyperbola(const Adaptor2d_Curve2d& C)
244 return C.Hyperbola();
247 //=======================================================================
248 //function : Parabola
250 //=======================================================================
252 inline gp_Parab2d Extrema_Curve2dTool::Parabola(const Adaptor2d_Curve2d& C)
257 //=======================================================================
260 //=======================================================================
262 inline Standard_Integer Extrema_Curve2dTool::NbPoles(const Adaptor2d_Curve2d& C)
267 //=======================================================================
270 //=======================================================================
272 inline Standard_Integer Extrema_Curve2dTool::Degree(const Adaptor2d_Curve2d& C)
277 //=======================================================================
278 //function : IsRational
280 //=======================================================================
282 inline Standard_Boolean Extrema_Curve2dTool::IsRational(const Adaptor2d_Curve2d& C)
288 //=======================================================================
291 //=======================================================================
293 inline Standard_Integer Extrema_Curve2dTool::NbKnots(const Adaptor2d_Curve2d& C)
298 //=======================================================================
301 //=======================================================================
303 inline Handle(Geom2d_BezierCurve) Extrema_Curve2dTool::Bezier(const Adaptor2d_Curve2d& C)
308 //=======================================================================
311 //=======================================================================
313 inline Handle(Geom2d_BSplineCurve) Extrema_Curve2dTool::BSpline(const Adaptor2d_Curve2d& C)