0031682: Visualization - Prs3d_ShadingAspect::SetTransparency() has no effect with...
[occt.git] / src / StepGeom / StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve.cxx
1 // Copyright (c) 1999-2014 OPEN CASCADE SAS
2 //
3 // This file is part of Open CASCADE Technology software library.
4 //
5 // This library is free software; you can redistribute it and/or modify it under
6 // the terms of the GNU Lesser General Public License version 2.1 as published
7 // by the Free Software Foundation, with special exception defined in the file
8 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
9 // distribution for complete text of the license and disclaimer of any warranty.
10 //
11 // Alternatively, this file may be used under the terms of Open CASCADE
12 // commercial license or contractual agreement.
13
14
15 #include <Standard_Type.hxx>
16 #include <StepGeom_BSplineCurveWithKnots.hxx>
17 #include <StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve.hxx>
18 #include <StepGeom_RationalBSplineCurve.hxx>
19 #include <TCollection_HAsciiString.hxx>
20
21 IMPLEMENT_STANDARD_RTTIEXT(StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve,StepGeom_BSplineCurve)
22
23 StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve ()  {}
24
25 void StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::Init(
26         const Handle(TCollection_HAsciiString)& aName,
27         const Standard_Integer aDegree,
28         const Handle(StepGeom_HArray1OfCartesianPoint)& aControlPointsList,
29         const StepGeom_BSplineCurveForm aCurveForm,
30         const StepData_Logical aClosedCurve,
31         const StepData_Logical aSelfIntersect,
32         const Handle(StepGeom_BSplineCurveWithKnots)& aBSplineCurveWithKnots,
33         const Handle(StepGeom_RationalBSplineCurve)& aRationalBSplineCurve)
34 {
35         // --- classe own fields ---
36         bSplineCurveWithKnots = aBSplineCurveWithKnots;
37         rationalBSplineCurve = aRationalBSplineCurve;
38         // --- classe inherited fields ---
39         StepGeom_BSplineCurve::Init(aName, aDegree, aControlPointsList, aCurveForm, aClosedCurve, aSelfIntersect);
40 }
41
42
43 void StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::Init(
44         const Handle(TCollection_HAsciiString)& aName,
45         const Standard_Integer aDegree,
46         const Handle(StepGeom_HArray1OfCartesianPoint)& aControlPointsList,
47         const StepGeom_BSplineCurveForm aCurveForm,
48         const StepData_Logical aClosedCurve,
49         const StepData_Logical aSelfIntersect,
50         const Handle(TColStd_HArray1OfInteger)& aKnotMultiplicities,
51         const Handle(TColStd_HArray1OfReal)& aKnots,
52         const StepGeom_KnotType aKnotSpec,
53         const Handle(TColStd_HArray1OfReal)& aWeightsData)
54 {
55         // --- classe inherited fields ---
56
57         StepGeom_BSplineCurve::Init(aName, aDegree, aControlPointsList, aCurveForm, aClosedCurve, aSelfIntersect);
58
59         // --- ANDOR componant fields ---
60
61         bSplineCurveWithKnots = new StepGeom_BSplineCurveWithKnots();
62         bSplineCurveWithKnots->Init(aName, aDegree, aControlPointsList, aCurveForm, aClosedCurve, aSelfIntersect, aKnotMultiplicities, aKnots, aKnotSpec);
63
64         // --- ANDOR componant fields ---
65
66         rationalBSplineCurve = new StepGeom_RationalBSplineCurve();
67         rationalBSplineCurve->Init(aName, aDegree, aControlPointsList, aCurveForm, aClosedCurve, aSelfIntersect, aWeightsData);
68 }
69
70
71 void StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::SetBSplineCurveWithKnots(const Handle(StepGeom_BSplineCurveWithKnots)& aBSplineCurveWithKnots)
72 {
73         bSplineCurveWithKnots = aBSplineCurveWithKnots;
74 }
75
76 Handle(StepGeom_BSplineCurveWithKnots) StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::BSplineCurveWithKnots() const
77 {
78         return bSplineCurveWithKnots;
79 }
80
81 void StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::SetRationalBSplineCurve(const Handle(StepGeom_RationalBSplineCurve)& aRationalBSplineCurve)
82 {
83         rationalBSplineCurve = aRationalBSplineCurve;
84 }
85
86 Handle(StepGeom_RationalBSplineCurve) StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::RationalBSplineCurve() const
87 {
88         return rationalBSplineCurve;
89 }
90
91         //--- Specific Methods for AND classe field access ---
92
93
94 void StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::SetKnotMultiplicities(const Handle(TColStd_HArray1OfInteger)& aKnotMultiplicities)
95 {
96         bSplineCurveWithKnots->SetKnotMultiplicities(aKnotMultiplicities);
97 }
98
99 Handle(TColStd_HArray1OfInteger) StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::KnotMultiplicities() const
100 {
101         return bSplineCurveWithKnots->KnotMultiplicities();
102 }
103
104 Standard_Integer StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::KnotMultiplicitiesValue(const Standard_Integer num) const
105 {
106         return bSplineCurveWithKnots->KnotMultiplicitiesValue(num);
107 }
108
109 Standard_Integer StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::NbKnotMultiplicities () const
110 {
111         return bSplineCurveWithKnots->NbKnotMultiplicities();
112 }
113
114 void StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::SetKnots(const Handle(TColStd_HArray1OfReal)& aKnots)
115 {
116         bSplineCurveWithKnots->SetKnots(aKnots);
117 }
118
119 Handle(TColStd_HArray1OfReal) StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::Knots() const
120 {
121         return bSplineCurveWithKnots->Knots();
122 }
123
124 Standard_Real StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::KnotsValue(const Standard_Integer num) const
125 {
126         return bSplineCurveWithKnots->KnotsValue(num);
127 }
128
129 Standard_Integer StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::NbKnots () const
130 {
131         return bSplineCurveWithKnots->NbKnots();
132 }
133
134 void StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::SetKnotSpec(const StepGeom_KnotType aKnotSpec)
135 {
136         bSplineCurveWithKnots->SetKnotSpec(aKnotSpec);
137 }
138
139 StepGeom_KnotType StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::KnotSpec() const
140 {
141         return bSplineCurveWithKnots->KnotSpec();
142 }
143
144         //--- Specific Methods for AND classe field access ---
145
146
147 void StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::SetWeightsData(const Handle(TColStd_HArray1OfReal)& aWeightsData)
148 {
149         rationalBSplineCurve->SetWeightsData(aWeightsData);
150 }
151
152 Handle(TColStd_HArray1OfReal) StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::WeightsData() const
153 {
154         return rationalBSplineCurve->WeightsData();
155 }
156
157 Standard_Real StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::WeightsDataValue(const Standard_Integer num) const
158 {
159         return rationalBSplineCurve->WeightsDataValue(num);
160 }
161
162 Standard_Integer StepGeom_BSplineCurveWithKnotsAndRationalBSplineCurve::NbWeightsData () const
163 {
164         return rationalBSplineCurve->NbWeightsData();
165 }