summaryrefslogtreecommitdiff
path: root/src/GCE2d/GCE2d_MakeSegment.cxx
blob: e51df53a49251128ec1765fffe860293f59ee81b (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
// File:	GCE2d_MakeSegment.cxx
// Created:	Fri Oct  2 16:37:54 1992
// Author:	Remi GILET
//		<reg@topsn3>

#include <GCE2d_MakeSegment.ixx>
#include <GCE2d_MakeLine.hxx>
#include <StdFail_NotDone.hxx>
#include <Geom2d_Line.hxx>
#include <ElCLib.hxx>

GCE2d_MakeSegment::GCE2d_MakeSegment(const gp_Pnt2d& P1 ,
				     const gp_Dir2d& V  ,
				     const gp_Pnt2d& P2 ) 
{
  gp_Lin2d Line(P1,V);
  Standard_Real Ulast = ElCLib::Parameter(Line,P2);
  if (Ulast != 0.0) {
    Handle(Geom2d_Line) L = new Geom2d_Line(Line);
    TheSegment = new Geom2d_TrimmedCurve(L,0.0,Ulast,Standard_True);
    TheError = gce_Done;
  }
  else { TheError = gce_ConfusedPoints; }
}

GCE2d_MakeSegment::GCE2d_MakeSegment(const gp_Pnt2d& P1 ,
				     const gp_Pnt2d& P2 ) 
{
  Standard_Real dist = P1.Distance(P2);
  if (dist != 0.0) {
    Handle(Geom2d_Line) L = GCE2d_MakeLine(P1,P2);
    TheSegment = new Geom2d_TrimmedCurve(L,0.,dist,Standard_True);
    TheError = gce_Done;
  }
  else { TheError = gce_ConfusedPoints; }
}
GCE2d_MakeSegment::GCE2d_MakeSegment(const gp_Lin2d&     Line  ,
				     const gp_Pnt2d&     Point ,
				     const Standard_Real U     ) 
{
  Standard_Real Ufirst = ElCLib::Parameter(Line,Point);
  Handle(Geom2d_Line) L = new Geom2d_Line(Line);
  TheSegment=new Geom2d_TrimmedCurve(L,Ufirst,U,Standard_True);
  TheError = gce_Done;
}

GCE2d_MakeSegment::GCE2d_MakeSegment(const gp_Lin2d& Line  ,
				     const gp_Pnt2d& P1    ,
				     const gp_Pnt2d& P2    ) 
{
  Standard_Real Ufirst = ElCLib::Parameter(Line,P1);
  Standard_Real Ulast = ElCLib::Parameter(Line,P2);
  Handle(Geom2d_Line) L = new Geom2d_Line(Line);
  TheSegment = new Geom2d_TrimmedCurve(L,Ufirst,Ulast,Standard_True);
  TheError = gce_Done;
}

GCE2d_MakeSegment::GCE2d_MakeSegment(const gp_Lin2d&     Line  ,
				     const Standard_Real U1    ,
				     const Standard_Real U2    ) 
{
  Handle(Geom2d_Line) L = new Geom2d_Line(Line);
  TheSegment = new Geom2d_TrimmedCurve(L,U1,U2,Standard_True);
  TheError = gce_Done;
}

const Handle(Geom2d_TrimmedCurve)& GCE2d_MakeSegment::Value() const
{ 
  StdFail_NotDone_Raise_if(!TheError == gce_Done,"");
  return TheSegment;
}

const Handle(Geom2d_TrimmedCurve)& GCE2d_MakeSegment::Operator() const 
{
  return Value();
}

GCE2d_MakeSegment::operator Handle(Geom2d_TrimmedCurve) () const
{
  return Value();
}