1 // Copyright (c) 1995-1999 Matra Datavision
2 // Copyright (c) 1999-2012 OPEN CASCADE SAS
4 // The content of this file is subject to the Open CASCADE Technology Public
5 // License Version 6.5 (the "License"). You may not use the content of this file
6 // except in compliance with the License. Please obtain a copy of the License
7 // at http://www.opencascade.org and read it completely before using this file.
9 // The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
10 // main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
12 // The Original Code and all software distributed under the License is
13 // distributed on an "AS IS" basis, without warranty of any kind, and the
14 // Initial Developer hereby disclaims all such warranties, including without
15 // limitation, any warranties of merchantability, fitness for a particular
16 // purpose or non-infringement. Please see the License for the specific terms
17 // and conditions governing the rights and limitations under the License.
19 #include <GCPnts_UniformDeflection.ixx>
20 #include <StdFail_NotDone.hxx>
21 #include <Standard_DomainError.hxx>
22 #include <Standard_OutOfRange.hxx>
23 #include <Standard_ConstructionError.hxx>
24 #include <Standard_NotImplemented.hxx>
25 #include <gp_Pnt2d.hxx>
26 // mask the return of a Adaptor2d_Curve2d as a gp_Pnt
27 static gp_Pnt Value(const Adaptor3d_Curve & C,
28 const Standard_Real Parameter)
30 return C.Value(Parameter) ;
32 static gp_Pnt Value(const Adaptor2d_Curve2d & C,
33 const Standard_Real Parameter)
38 aPoint.SetX ( a2dPoint.X()) ;
39 aPoint.SetY ( a2dPoint.Y()) ;
40 aPoint.SetZ ( 0.0e0) ;
43 //=======================================================================
46 //=======================================================================
48 gp_Pnt GCPnts_UniformDeflection::Value
49 (const Standard_Integer Index) const
51 StdFail_NotDone_Raise_if(!myDone,
52 "GCPnts_UniformAbscissa::Parameter()");
53 return myPoints.Value(Index) ;
55 //=======================================================================
56 //function : GCPnts_UniformDeflection
58 //=======================================================================
60 GCPnts_UniformDeflection::GCPnts_UniformDeflection ()
61 :myDone(Standard_False)
65 #include <Geom_BezierCurve.hxx>
66 #include <Geom_BSplineCurve.hxx>
67 #define TheCurve Adaptor3d_Curve
68 #define Handle_TheBezierCurve Handle(Geom_BezierCurve)
69 #define Handle_TheBSplineCurve Handle(Geom_BSplineCurve)
70 #include <GCPnts_UniformDeflection.gxx>
72 #undef Handle_TheBezierCurve
73 #undef Handle_TheBSplineCurve
75 #include <Geom2d_BezierCurve.hxx>
76 #include <Geom2d_BSplineCurve.hxx>
77 #define TheCurve Adaptor2d_Curve2d
78 #define Handle_TheBezierCurve Handle(Geom2d_BezierCurve)
79 #define Handle_TheBSplineCurve Handle(Geom2d_BSplineCurve)
80 #include <GCPnts_UniformDeflection.gxx>
82 #undef Handle_TheBezierCurve
83 #undef Handle_TheBSplineCurve