0026576: Wrong result obtained by intersection algorithm.
[occt.git] / src / IntTools / IntTools_Curve.cxx
CommitLineData
973c2be1 1// Copyright (c) 1999-2014 OPEN CASCADE SAS
b311480e 2//
973c2be1 3// This file is part of Open CASCADE Technology software library.
b311480e 4//
d5f74e42 5// This library is free software; you can redistribute it and/or modify it under
6// the terms of the GNU Lesser General Public License version 2.1 as published
973c2be1 7// by the Free Software Foundation, with special exception defined in the file
8// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
9// distribution for complete text of the license and disclaimer of any warranty.
b311480e 10//
973c2be1 11// Alternatively, this file may be used under the terms of Open CASCADE
12// commercial license or contractual agreement.
b311480e 13
42cf5bc1 14
15#include <Geom2d_Curve.hxx>
7fd59977 16#include <Geom_BoundedCurve.hxx>
42cf5bc1 17#include <Geom_Curve.hxx>
7fd59977 18#include <GeomAdaptor_Curve.hxx>
42cf5bc1 19#include <gp_Pnt.hxx>
20#include <IntTools_Curve.hxx>
7fd59977 21
22//=======================================================================
23//function : IntTools_Curve::IntTools_Curve
24//purpose :
25//=======================================================================
b311480e 26IntTools_Curve::IntTools_Curve()
7fd59977 27{
28}
29//=======================================================================
30//function : IntTools_Curve::IntTools_Curve
31//purpose :
32//=======================================================================
33 IntTools_Curve::IntTools_Curve(const Handle(Geom_Curve)& Curve3d,
34 const Handle(Geom2d_Curve)& FirstCurve2d,
35 const Handle(Geom2d_Curve)& SecondCurve2d)
36{
37 SetCurves(Curve3d, FirstCurve2d, SecondCurve2d);
38}
39//=======================================================================
40//function : SetCurves
41//purpose :
42//=======================================================================
43 void IntTools_Curve::SetCurves(const Handle(Geom_Curve)& Curve3d,
44 const Handle(Geom2d_Curve)& FirstCurve2d,
45 const Handle(Geom2d_Curve)& SecondCurve2d)
46{
47 SetCurve(Curve3d);
48 SetFirstCurve2d(FirstCurve2d);
49 SetSecondCurve2d(SecondCurve2d);
50}
51
52//=======================================================================
53//function : HasBounds
54//purpose :
55//=======================================================================
56 Standard_Boolean IntTools_Curve::HasBounds() const
57{
58 Standard_Boolean bBounded;
59
60 Handle(Geom_BoundedCurve) aC3DBounded =
61 Handle(Geom_BoundedCurve)::DownCast(my3dCurve);
62
63 bBounded=!aC3DBounded.IsNull();
64
65 return bBounded ;
66}
67
68//=======================================================================
69//function : Bounds
70//purpose :
71//=======================================================================
72 void IntTools_Curve::Bounds(Standard_Real& aT1,
73 Standard_Real& aT2,
74 gp_Pnt& aP1,
75 gp_Pnt& aP2) const
76{
77 aT1=0.;
78 aT2=0.;
79 aP1.SetCoord(0.,0.,0.);
80 aP2.SetCoord(0.,0.,0.);
81 if (HasBounds()) {
82 aT1=my3dCurve->FirstParameter();
83 aT2=my3dCurve->LastParameter();
84 my3dCurve->D0(aT1, aP1);
85 my3dCurve->D0(aT2, aP2);
86 }
87}
88
89//=======================================================================
90//function : D0
91//purpose :
92//=======================================================================
93 Standard_Boolean IntTools_Curve::D0(Standard_Real& aT,
94 gp_Pnt& aP) const
95{
96 Standard_Real aF, aL;
97
98 aF=my3dCurve->FirstParameter();
99 aL=my3dCurve->LastParameter();
100 if (aT<aF || aT>aL) {
101 return Standard_False;
102 }
103 my3dCurve->D0(aT, aP);
104 return Standard_True;
105}
106
107//=======================================================================
108//function : D0
109//purpose :
110//=======================================================================
111 GeomAbs_CurveType IntTools_Curve::Type() const
112{
113 GeomAdaptor_Curve aGAC(my3dCurve);
114 GeomAbs_CurveType aType=aGAC.GetType();
115 return aType;
116}