File: AppDef_MultiLine.hxx

package info (click to toggle)
opencascade 6.2-7
  • links: PTS
  • area: non-free
  • in suites: lenny
  • size: 444,652 kB
  • ctags: 256,750
  • sloc: cpp: 1,150,123; ansic: 225,762; tcl: 30,130; makefile: 12,619; sh: 7,958; xml: 3,981; lisp: 283; java: 212; csh: 203; perl: 15
file content (166 lines) | stat: -rw-r--r-- 5,221 bytes parent folder | download | duplicates (2)
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
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
// File generated by CPPExt (Value)
//
//                     Copyright (C) 1991 - 2000 by  
//                      Matra Datavision SA.  All rights reserved.
//  
//                     Copyright (C) 2001 - 2004 by
//                     Open CASCADE SA.  All rights reserved.
// 
// This file is part of the Open CASCADE Technology software.
//
// This software may be distributed and/or modified under the terms and
// conditions of the Open CASCADE Public License as defined by Open CASCADE SA
// and appearing in the file LICENSE included in the packaging of this file.
//  
// This software is distributed on an "AS IS" basis, without warranty of any
// kind, and Open CASCADE SA hereby disclaims all such warranties,
// including without limitation, any warranties of merchantability, fitness
// for a particular purpose or non-infringement. Please see the License for
// the specific terms and conditions governing rights and limitations under the
// License.

#ifndef _AppDef_MultiLine_HeaderFile
#define _AppDef_MultiLine_HeaderFile

#ifndef _Handle_AppDef_HArray1OfMultiPointConstraint_HeaderFile
#include <Handle_AppDef_HArray1OfMultiPointConstraint.hxx>
#endif
#ifndef _Standard_Integer_HeaderFile
#include <Standard_Integer.hxx>
#endif
#ifndef _Standard_Real_HeaderFile
#include <Standard_Real.hxx>
#endif
#ifndef _Standard_OStream_HeaderFile
#include <Standard_OStream.hxx>
#endif
class AppDef_HArray1OfMultiPointConstraint;
class Standard_ConstructionError;
class Standard_DimensionError;
class Standard_OutOfRange;
class AppDef_Array1OfMultiPointConstraint;
class TColgp_Array1OfPnt;
class TColgp_Array1OfPnt2d;
class AppDef_MultiPointConstraint;


#ifndef _Standard_HeaderFile
#include <Standard.hxx>
#endif
#ifndef _Standard_Macro_HeaderFile
#include <Standard_Macro.hxx>
#endif

//! This class describes the organized set of points used in the <br>
//!          approximations. A MultiLine is composed of n <br>
//!          MultiPointConstraints. <br>
//!          The approximation of the MultiLine will be done in the order <br>
//!          of the given n MultiPointConstraints. <br>
class AppDef_MultiLine  {

public:

    void* operator new(size_t,void* anAddress) 
      {
        return anAddress;
      }
    void* operator new(size_t size) 
      { 
        return Standard::Allocate(size); 
      }
    void  operator delete(void *anAddress) 
      { 
        if (anAddress) Standard::Free((Standard_Address&)anAddress); 
      }
 // Methods PUBLIC
 // 

//! creates an undefined MultiLine. <br>
Standard_EXPORT AppDef_MultiLine();

//! given the number NbMult of MultiPointConstraints of this <br>
//!          MultiLine , it initializes all the fields.SetValue must be <br>
//!  called in order for the values of the multipoint <br>
//!  constraint to be taken into account. <br>
//!          An exception is raised if NbMult < 0. <br>
Standard_EXPORT AppDef_MultiLine(const Standard_Integer NbMult);

//! Constructs a MultiLine with an array of MultiPointConstraints. <br>
Standard_EXPORT AppDef_MultiLine(const AppDef_Array1OfMultiPointConstraint& tabMultiP);

//! The MultiLine constructed will have one line of <br>
//!          3d points without their tangencies. <br>
Standard_EXPORT AppDef_MultiLine(const TColgp_Array1OfPnt& tabP3d);

//! The MultiLine constructed will have one line of <br>
//!          2d points without their tangencies. <br>
Standard_EXPORT AppDef_MultiLine(const TColgp_Array1OfPnt2d& tabP2d);

//! returns the number of MultiPointConstraints of the <br>
//!          MultiLine. <br>
Standard_EXPORT   Standard_Integer NbMultiPoints() const;

//! returns the number of Points from MultiPoints composing <br>
//!          the MultiLine. <br>
Standard_EXPORT   Standard_Integer NbPoints() const;

//! Sets the value of the parameter for the <br>
//! MultiPointConstraint at position Index. <br>
//! Exceptions <br>
//! -   Standard_OutOfRange if Index is less <br>
//!   than 0 or Index is greater than the number <br>
//!   of Multipoint constraints in the MultiLine. <br>
Standard_EXPORT   void SetParameter(const Standard_Integer Index,const Standard_Real U) ;

//! It sets the MultiPointConstraint of range Index to the <br>
//!          value MPoint. <br>
//!          An exception is raised if Index < 0 or Index> MPoint. <br>
//!          An exception is raised if the dimensions of the <br>
//!          MultiPoints are different. <br>
Standard_EXPORT   void SetValue(const Standard_Integer Index,const AppDef_MultiPointConstraint& MPoint) ;

//! returns the MultiPointConstraint of range Index <br>
//!          An exception is raised if Index<0 or Index>MPoint. <br>
Standard_EXPORT   AppDef_MultiPointConstraint Value(const Standard_Integer Index) const;

//! Prints on the stream o information on the current <br>
//!          state of the object. <br>
//!          Is used to redefine the operator <<. <br>
Standard_EXPORT   void Dump(Standard_OStream& o) const;





protected:

 // Methods PROTECTED
 // 


 // Fields PROTECTED
 //
Handle_AppDef_HArray1OfMultiPointConstraint tabMult;


private: 

 // Methods PRIVATE
 // 


 // Fields PRIVATE
 //


};





// other Inline functions and methods (like "C++: function call" methods)
//


#endif