0024002: Overall code and build procedure refactoring -- automatic
[occt.git] / src / StepGeom / StepGeom_BSplineSurface.hxx
CommitLineData
42cf5bc1 1// Created on: 1995-12-01
2// Created by: EXPRESS->CDL V0.2 Translator
3// Copyright (c) 1995-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 _StepGeom_BSplineSurface_HeaderFile
18#define _StepGeom_BSplineSurface_HeaderFile
19
20#include <Standard.hxx>
21#include <Standard_Type.hxx>
22
23#include <Standard_Integer.hxx>
24#include <StepGeom_HArray2OfCartesianPoint.hxx>
25#include <StepGeom_BSplineSurfaceForm.hxx>
26#include <StepData_Logical.hxx>
27#include <StepGeom_BoundedSurface.hxx>
28class TCollection_HAsciiString;
29class StepGeom_CartesianPoint;
30
31
32class StepGeom_BSplineSurface;
33DEFINE_STANDARD_HANDLE(StepGeom_BSplineSurface, StepGeom_BoundedSurface)
34
35
36class StepGeom_BSplineSurface : public StepGeom_BoundedSurface
37{
38
39public:
40
41
42 //! Returns a BSplineSurface
43 Standard_EXPORT StepGeom_BSplineSurface();
44
45 Standard_EXPORT virtual void Init (const Handle(TCollection_HAsciiString)& aName) Standard_OVERRIDE;
46
47 Standard_EXPORT virtual void Init (const Handle(TCollection_HAsciiString)& aName, const Standard_Integer aUDegree, const Standard_Integer aVDegree, const Handle(StepGeom_HArray2OfCartesianPoint)& aControlPointsList, const StepGeom_BSplineSurfaceForm aSurfaceForm, const StepData_Logical aUClosed, const StepData_Logical aVClosed, const StepData_Logical aSelfIntersect);
48
49 Standard_EXPORT void SetUDegree (const Standard_Integer aUDegree);
50
51 Standard_EXPORT Standard_Integer UDegree() const;
52
53 Standard_EXPORT void SetVDegree (const Standard_Integer aVDegree);
54
55 Standard_EXPORT Standard_Integer VDegree() const;
56
57 Standard_EXPORT void SetControlPointsList (const Handle(StepGeom_HArray2OfCartesianPoint)& aControlPointsList);
58
59 Standard_EXPORT Handle(StepGeom_HArray2OfCartesianPoint) ControlPointsList() const;
60
61 Standard_EXPORT Handle(StepGeom_CartesianPoint) ControlPointsListValue (const Standard_Integer num1, const Standard_Integer num2) const;
62
63 Standard_EXPORT Standard_Integer NbControlPointsListI() const;
64
65 Standard_EXPORT Standard_Integer NbControlPointsListJ() const;
66
67 Standard_EXPORT void SetSurfaceForm (const StepGeom_BSplineSurfaceForm aSurfaceForm);
68
69 Standard_EXPORT StepGeom_BSplineSurfaceForm SurfaceForm() const;
70
71 Standard_EXPORT void SetUClosed (const StepData_Logical aUClosed);
72
73 Standard_EXPORT StepData_Logical UClosed() const;
74
75 Standard_EXPORT void SetVClosed (const StepData_Logical aVClosed);
76
77 Standard_EXPORT StepData_Logical VClosed() const;
78
79 Standard_EXPORT void SetSelfIntersect (const StepData_Logical aSelfIntersect);
80
81 Standard_EXPORT StepData_Logical SelfIntersect() const;
82
83
84
85
86 DEFINE_STANDARD_RTTI(StepGeom_BSplineSurface,StepGeom_BoundedSurface)
87
88protected:
89
90
91
92
93private:
94
95
96 Standard_Integer uDegree;
97 Standard_Integer vDegree;
98 Handle(StepGeom_HArray2OfCartesianPoint) controlPointsList;
99 StepGeom_BSplineSurfaceForm surfaceForm;
100 StepData_Logical uClosed;
101 StepData_Logical vClosed;
102 StepData_Logical selfIntersect;
103
104
105};
106
107
108
109
110
111
112
113#endif // _StepGeom_BSplineSurface_HeaderFile