95a4395ab31ce378ae13deb05e17a2ab4fe5e8da
[occt.git] / src / IntPolyh / IntPolyh_Point.hxx
1 // Created on: 1999-03-05
2 // Created by: Fabrice SERVANT
3 // Copyright (c) 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 #ifndef _IntPolyh_Point_HeaderFile
18 #define _IntPolyh_Point_HeaderFile
19
20 #include <Standard.hxx>
21 #include <Standard_DefineAlloc.hxx>
22 #include <Standard_Handle.hxx>
23
24 #include <Standard_Real.hxx>
25 #include <Standard_Integer.hxx>
26 #include <Standard_Boolean.hxx>
27 class Adaptor3d_HSurface;
28
29
30
31 class IntPolyh_Point 
32 {
33 public:
34
35   DEFINE_STANDARD_ALLOC
36
37   
38   Standard_EXPORT IntPolyh_Point();
39   
40   Standard_EXPORT IntPolyh_Point(const Standard_Real xx, const Standard_Real yy, const Standard_Real zz, const Standard_Real uu, const Standard_Real vv);
41   
42   Standard_EXPORT Standard_Real X() const;
43   
44   Standard_EXPORT Standard_Real Y() const;
45   
46   Standard_EXPORT Standard_Real Z() const;
47   
48   Standard_EXPORT Standard_Real U() const;
49   
50   Standard_EXPORT Standard_Real V() const;
51   
52   Standard_EXPORT Standard_Integer PartOfCommon() const;
53   
54   Standard_EXPORT void Equal (const IntPolyh_Point& Pt);
55 void operator = (const IntPolyh_Point& Pt)
56 {
57   Equal(Pt);
58 }
59   
60   Standard_EXPORT void Set (const Standard_Real v1, const Standard_Real v2, const Standard_Real v3, const Standard_Real v4, const Standard_Real v5, const Standard_Integer II = 1);
61   
62   Standard_EXPORT void SetX (const Standard_Real v);
63   
64   Standard_EXPORT void SetY (const Standard_Real v);
65   
66   Standard_EXPORT void SetZ (const Standard_Real v);
67   
68   Standard_EXPORT void SetU (const Standard_Real v);
69   
70   Standard_EXPORT void SetV (const Standard_Real v);
71   
72   Standard_EXPORT void SetPartOfCommon (const Standard_Integer ii);
73   
74   Standard_EXPORT void Middle (const Handle(Adaptor3d_HSurface)& MySurface, const IntPolyh_Point& P1, const IntPolyh_Point& P2);
75   
76   Standard_EXPORT IntPolyh_Point Add (const IntPolyh_Point& P1) const;
77 IntPolyh_Point operator + (const IntPolyh_Point& P1) const
78 {
79   return Add(P1);
80 }
81   
82   Standard_EXPORT IntPolyh_Point Sub (const IntPolyh_Point& P1) const;
83 IntPolyh_Point operator - (const IntPolyh_Point& P1) const
84 {
85   return Sub(P1);
86 }
87   
88   Standard_EXPORT IntPolyh_Point Divide (const Standard_Real rr) const;
89 IntPolyh_Point operator / (const Standard_Real rr) const
90 {
91   return Divide(rr);
92 }
93   
94   Standard_EXPORT IntPolyh_Point Multiplication (const Standard_Real rr) const;
95 IntPolyh_Point operator * (const Standard_Real rr) const
96 {
97   return Multiplication(rr);
98 }
99   
100   Standard_EXPORT Standard_Real SquareModulus() const;
101   
102   Standard_EXPORT Standard_Real SquareDistance (const IntPolyh_Point& P2) const;
103   
104   Standard_EXPORT Standard_Real Dot (const IntPolyh_Point& P2) const;
105   
106   Standard_EXPORT void Cross (const IntPolyh_Point& P1, const IntPolyh_Point& P2);
107   
108   Standard_EXPORT void Dump() const;
109   
110   Standard_EXPORT void Dump (const Standard_Integer i) const;
111   
112   Standard_EXPORT void SetDegenerated (const Standard_Boolean theFlag);
113   
114   Standard_EXPORT Standard_Boolean Degenerated() const;
115
116
117
118
119 protected:
120
121
122
123
124
125 private:
126
127
128
129   Standard_Real x;
130   Standard_Real y;
131   Standard_Real z;
132   Standard_Real u;
133   Standard_Real v;
134   Standard_Integer POC;
135   Standard_Boolean myDegenerated;
136
137
138 };
139
140
141
142
143
144
145
146 #endif // _IntPolyh_Point_HeaderFile