summaryrefslogtreecommitdiff
path: root/inc/BRepApprox_ApproxLineGen.gxx
blob: 0e4f0060056d61f45d9cda12bb9f7f99ff571e44 (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
// File:	BRepApprox_ApproxLineGen.gxx
// Created:	Thu Jul 20 15:25:47 1995
// Author:	Modelistation
//		<model@meteox>

#include <gp_Pnt2d.hxx>

//=======================================================================
//function : BRepApprox_ApproxLineGen
//purpose  : 
//=======================================================================

BRepApprox_ApproxLineGen::BRepApprox_ApproxLineGen
   (const TheCurve&    CurveXYZ,
    const TheCurve2d&  CurveUV1,
    const TheCurve2d&  CurveUV2) 
{ 
  curvxyz = CurveXYZ;
  curvuv1 = CurveUV1;
  curvuv2 = CurveUV2;
}


//=======================================================================
//function : BRepApprox_ApproxLineGen
//purpose  : 
//=======================================================================

BRepApprox_ApproxLineGen::BRepApprox_ApproxLineGen
    (const Handle(IntSurf_LineOn2S)& lin,
     const Standard_Boolean ) 
     :linon2s(lin) 
{ 
}

//=======================================================================
//function : NbPnts
//purpose  : 
//=======================================================================

Standard_Integer BRepApprox_ApproxLineGen::NbPnts() const 
{
  if(!curvxyz.IsNull())
    return(curvxyz->NbPoles());
  if(!curvuv1.IsNull())
    return(curvuv1->NbPoles());
  if(!curvuv2.IsNull())
    return(curvuv2->NbPoles());
  return(linon2s->NbPoints());
}

//=======================================================================
//function : Point
//purpose  : 
//=======================================================================

IntSurf_PntOn2S BRepApprox_ApproxLineGen::Point
   (const Standard_Integer Index)
{
  if(!linon2s.IsNull()) { 
    if(linon2s->NbPoints()) { 
      return(linon2s->Value(Index));
    }
  }
  gp_Pnt2d P1,P2;
  gp_Pnt   P;
  if(!curvxyz.IsNull()) 
    P = curvxyz->Pole(Index);
  if(!curvuv1.IsNull())
    P1 = curvuv1->Pole(Index);
  if(!curvuv2.IsNull())
    P2 = curvuv2->Pole(Index);

  pnton2s.SetValue(P,
		   P1.X(),
		   P1.Y(),
		   P2.X(),
		   P2.Y());
  return(pnton2s);
}