42cf5bc1 |
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 |