fc267ee89377b29c63143751f35f39758f4c6d9c
[occt.git] / src / IntCurveSurface / IntCurveSurface_IntersectionPoint.cxx
1 // Created on: 1993-04-07
2 // Created by: Laurent BUCHARD
3 // Copyright (c) 1993-1999 Matra Datavision
4 // Copyright (c) 1999-2014 OPEN CASCADE SAS
5 //
6 // This file is part of Open CASCADE Technology software library.
7 //
8 // This library is free software; you can redistribute it and/or modify it under
9 // the terms of the GNU Lesser General Public License version 2.1 as published
10 // by the Free Software Foundation, with special exception defined in the file
11 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
12 // distribution for complete text of the license and disclaimer of any warranty.
13 //
14 // Alternatively, this file may be used under the terms of Open CASCADE
15 // commercial license or contractual agreement.
16
17
18 #include <gp_Pnt.hxx>
19 #include <IntCurveSurface_IntersectionPoint.hxx>
20
21 //================================================================================
22 IntCurveSurface_IntersectionPoint::IntCurveSurface_IntersectionPoint() { } 
23 //================================================================================
24 IntCurveSurface_IntersectionPoint::IntCurveSurface_IntersectionPoint(const gp_Pnt& P,
25                                                                      const Standard_Real USurf,
26                                                                      const Standard_Real VSurf,
27                                                                      const Standard_Real UCurv,
28                                                                      const IntCurveSurface_TransitionOnCurve TrOnCurv):
29        myP(P),myUSurf(USurf),myVSurf(VSurf),myUCurv(UCurv),myTrOnCurv(TrOnCurv) 
30
31 }
32 //================================================================================
33 void IntCurveSurface_IntersectionPoint::SetValues(const gp_Pnt& P,
34                                                   const Standard_Real USurf,
35                                                   const Standard_Real VSurf,
36                                                   const Standard_Real UCurv,
37                                                   const IntCurveSurface_TransitionOnCurve TrOnCurv) { 
38   myP=P;
39   myUSurf=USurf;
40   myVSurf=VSurf;
41   myUCurv=UCurv;
42   myTrOnCurv=TrOnCurv;
43 }
44 //================================================================================
45 void IntCurveSurface_IntersectionPoint::Values(gp_Pnt& P,
46                                                Standard_Real& USurf,
47                                                Standard_Real& VSurf,
48                                                Standard_Real& UCurv,
49                                                IntCurveSurface_TransitionOnCurve& TrOnCurv) const 
50
51   P=myP;
52   USurf=myUSurf;
53   VSurf=myVSurf;
54   UCurv=myUCurv;
55   TrOnCurv=myTrOnCurv;
56 }
57 //================================================================================
58 void IntCurveSurface_IntersectionPoint::Dump() const { 
59   std::cout<<"IntersectionPoint: P("<<myP.X()<<","<<myP.Y()<<","<<myP.Z()<<")"<<std::endl;
60   std::cout<<"                 : USurf("<<myUSurf<<")  VSurf("<<myVSurf<<")   UCurve("<<myUCurv<<")"<<std::endl;
61   std::cout<<"                 : TransitionOnSurf ";
62
63   switch(myTrOnCurv) { 
64   case IntCurveSurface_Tangent: std::cout<<" Tangent "; break;
65   case IntCurveSurface_In: std::cout<<" In "; break;
66   case IntCurveSurface_Out: std::cout<<" Out "; break;
67
68   default: std::cout<< " XXXXX ";
69   }  
70   std::cout<<std::endl;
71 }
72
73
74