blob: f213becb92f9319d241560bf9adfb65d603cc0d9 (
plain)
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
|
//--------------------------------------------------------------------
//
// File Name : IGESSolid_ManifoldSolid.cxx
// Date :
// Author : CKY / Contract Toubro-Larsen
// Copyright : MATRA-DATAVISION 1993
//
//--------------------------------------------------------------------
#include <IGESSolid_ManifoldSolid.ixx>
IGESSolid_ManifoldSolid::IGESSolid_ManifoldSolid () { }
void IGESSolid_ManifoldSolid::Init
(const Handle(IGESSolid_Shell)& aShell,
const Standard_Boolean Shellflag,
const Handle(IGESSolid_HArray1OfShell)& VoidShells,
const Handle(TColStd_HArray1OfInteger)& VoidShellFlags)
{
if (!VoidShells.IsNull())
if (VoidShells->Lower() != 1 || VoidShellFlags->Lower() != 1 ||
VoidShells->Length() != VoidShellFlags->Length())
Standard_DimensionError::Raise("IGESSolid_ManifoldSolid : Init");
theShell = aShell;
theOrientationFlag = Shellflag;
theVoidShells = VoidShells;
theOrientFlags = VoidShellFlags;
InitTypeAndForm(186,0);
}
Handle(IGESSolid_Shell) IGESSolid_ManifoldSolid::Shell () const
{
return theShell;
}
Standard_Boolean IGESSolid_ManifoldSolid::OrientationFlag () const
{
return theOrientationFlag;
}
Standard_Integer IGESSolid_ManifoldSolid::NbVoidShells () const
{
return (theVoidShells.IsNull() ? 0 : theVoidShells->Length());
}
Handle(IGESSolid_Shell) IGESSolid_ManifoldSolid::VoidShell
(const Standard_Integer index) const
{
Handle(IGESSolid_Shell) ashell; // par defaut sera Null
if (!theVoidShells.IsNull()) ashell = theVoidShells->Value(index);
return ashell;
}
Standard_Boolean IGESSolid_ManifoldSolid::VoidOrientationFlag
(const Standard_Integer index) const
{
if (!theOrientFlags.IsNull()) return (theOrientFlags->Value(index) != 0);
else return Standard_False; // pour retourner qqchose ...
}
|