0024002: Overall code and build procedure refactoring -- automatic
[occt.git] / src / IntPolyh / IntPolyh_Point.hxx
CommitLineData
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>
27class Adaptor3d_HSurface;
28
29
30
31class IntPolyh_Point
32{
33public:
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);
55void 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;
77IntPolyh_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;
83IntPolyh_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;
89IntPolyh_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;
95IntPolyh_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
119protected:
120
121
122
123
124
125private:
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