summaryrefslogtreecommitdiff
path: root/src/IntTools/IntTools_Curve.cxx
blob: 891e90b53ff06e87002794520b4ac6389b1efaa4 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
#include <IntTools_Curve.ixx>
#include <Geom_BoundedCurve.hxx>
#include <GeomAdaptor_Curve.hxx>

//=======================================================================
//function : IntTools_Curve::IntTools_Curve
//purpose  : 
//=======================================================================
  IntTools_Curve::IntTools_Curve()
{
}
//=======================================================================
//function : IntTools_Curve::IntTools_Curve
//purpose  : 
//=======================================================================
  IntTools_Curve::IntTools_Curve(const Handle(Geom_Curve)& Curve3d,
				 const Handle(Geom2d_Curve)& FirstCurve2d,
				 const Handle(Geom2d_Curve)& SecondCurve2d)
{
  SetCurves(Curve3d, FirstCurve2d, SecondCurve2d);
}
//=======================================================================
//function : SetCurves
//purpose  : 
//=======================================================================
  void IntTools_Curve::SetCurves(const Handle(Geom_Curve)& Curve3d,
				 const Handle(Geom2d_Curve)& FirstCurve2d,
				 const Handle(Geom2d_Curve)& SecondCurve2d) 
{
  SetCurve(Curve3d);
  SetFirstCurve2d(FirstCurve2d);
  SetSecondCurve2d(SecondCurve2d);
}

//=======================================================================
//function : HasBounds
//purpose  : 
//=======================================================================
  Standard_Boolean IntTools_Curve::HasBounds() const 
{
  Standard_Boolean bBounded;

  Handle(Geom_BoundedCurve) aC3DBounded =
    Handle(Geom_BoundedCurve)::DownCast(my3dCurve);
  
  bBounded=!aC3DBounded.IsNull();
  
  return bBounded ;
}

//=======================================================================
//function : Bounds
//purpose  : 
//=======================================================================
  void IntTools_Curve::Bounds(Standard_Real& aT1,
			      Standard_Real& aT2,
			      gp_Pnt& aP1,
			      gp_Pnt& aP2) const 
{
  aT1=0.;
  aT2=0.;
  aP1.SetCoord(0.,0.,0.);
  aP2.SetCoord(0.,0.,0.);
  if (HasBounds()) {
    aT1=my3dCurve->FirstParameter();
    aT2=my3dCurve->LastParameter();
    my3dCurve->D0(aT1, aP1);
    my3dCurve->D0(aT2, aP2);
  }
}

//=======================================================================
//function : D0
//purpose  : 
//=======================================================================
  Standard_Boolean IntTools_Curve::D0(Standard_Real& aT,
				      gp_Pnt& aP) const 
{
  Standard_Real aF, aL;

  aF=my3dCurve->FirstParameter();
  aL=my3dCurve->LastParameter();
  if (aT<aF || aT>aL) {
    return Standard_False;
  }
  my3dCurve->D0(aT, aP);
  return Standard_True;
}

//=======================================================================
//function : D0
//purpose  : 
//=======================================================================
   GeomAbs_CurveType IntTools_Curve::Type() const 
{
  GeomAdaptor_Curve aGAC(my3dCurve);
  GeomAbs_CurveType aType=aGAC.GetType();
  return aType;
}