blob: e702367f79ae0a356cc7c5456504165d66edc4d8 (
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
|
// File: BRepFill_Section.cxx
// Created: Wed Jul 22 10:50:48 1998
// Author: Philippe MANGIN
// <pmn@sgi29>
#include <BRepFill_Section.ixx>
#include <TopoDS.hxx>
#include <BRep_Builder.hxx>
#include <TopoDS_Edge.hxx>
BRepFill_Section::BRepFill_Section() :islaw(0), contact(0), correction(0)
{
}
BRepFill_Section::BRepFill_Section(const TopoDS_Shape& Profile,
const TopoDS_Vertex& V,
const Standard_Boolean WithContact,
const Standard_Boolean WithCorrection)
: vertex(V),
islaw(0),contact(WithContact),
correction(WithCorrection)
{
if (Profile.ShapeType() == TopAbs_WIRE)
wire = TopoDS::Wire(Profile);
else if (Profile.ShapeType() == TopAbs_VERTEX)
{
TopoDS_Vertex aVertex = TopoDS::Vertex(Profile);
BRep_Builder BB;
TopoDS_Edge DegEdge;
BB.MakeEdge( DegEdge );
BB.Add( DegEdge, aVertex.Oriented(TopAbs_FORWARD) );
BB.Add( DegEdge, aVertex.Oriented(TopAbs_REVERSED) );
BB.Degenerated( DegEdge, Standard_True );
DegEdge.Closed( Standard_True );
BB.MakeWire( wire );
BB.Add( wire, DegEdge );
wire.Closed( Standard_True );
}
else
Standard_Failure::Raise("BRepFill_Section: bad shape type of section");
}
void BRepFill_Section::Set(const Standard_Boolean IsLaw)
{
islaw = IsLaw;
}
|