mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-04-03 17:56:21 +03:00
0032818: Modeling Algorithms - Result of sweep operation is invalid
BRepFill_TrimShellCorner.cxx - setting correct orientation for NewEdge tests/pipe/bugs/bug32818 - new test case added
This commit is contained in:
parent
6c10d4b11a
commit
c0bcd773c5
@ -56,6 +56,7 @@
|
|||||||
#include <TopTools_MapOfShape.hxx>
|
#include <TopTools_MapOfShape.hxx>
|
||||||
#include <TopTools_SequenceOfShape.hxx>
|
#include <TopTools_SequenceOfShape.hxx>
|
||||||
#include <BRepExtrema_ExtCC.hxx>
|
#include <BRepExtrema_ExtCC.hxx>
|
||||||
|
#include <ShapeFix_Edge.hxx>
|
||||||
|
|
||||||
static TopoDS_Edge FindEdgeCloseToBisectorPlane(const TopoDS_Vertex& theVertex,
|
static TopoDS_Edge FindEdgeCloseToBisectorPlane(const TopoDS_Vertex& theVertex,
|
||||||
TopoDS_Compound& theComp,
|
TopoDS_Compound& theComp,
|
||||||
@ -534,6 +535,26 @@ BRepFill_TrimShellCorner::MakeFacesNonSec(const Standard_Integer
|
|||||||
|
|
||||||
if(bHasNewEdge) {
|
if(bHasNewEdge) {
|
||||||
aNewEdge.Orientation(TopAbs_FORWARD);
|
aNewEdge.Orientation(TopAbs_FORWARD);
|
||||||
|
|
||||||
|
// Refer to BrepFill_Sweep.cxx BuildEdge Construct an edge via an iso
|
||||||
|
gp_Pnt P1, P2;
|
||||||
|
Standard_Real p11, p12, p21, p22;
|
||||||
|
P1 = BRep_Tool::Pnt(TopExp::FirstVertex(TopoDS::Edge(aNewEdge)));
|
||||||
|
P2 = BRep_Tool::Pnt(TopExp::LastVertex(TopoDS::Edge(aNewEdge)));
|
||||||
|
|
||||||
|
TopoDS_Edge aERef = TopoDS::Edge(fit == 1 ? aE1 : aE2);
|
||||||
|
p11 = P1.Distance(BRep_Tool::Pnt(TopExp::FirstVertex(aERef)));
|
||||||
|
p22 = P2.Distance(BRep_Tool::Pnt(TopExp::LastVertex(aERef)));
|
||||||
|
p12 = P1.Distance(BRep_Tool::Pnt(TopExp::LastVertex(aERef)));
|
||||||
|
p21 = P2.Distance(BRep_Tool::Pnt(TopExp::FirstVertex(aERef)));
|
||||||
|
|
||||||
|
if (p11 > p12 && p22 > p21) {
|
||||||
|
aNewEdge.Reverse();
|
||||||
|
}
|
||||||
|
|
||||||
|
// for nonPlane surface, we should add pCurve
|
||||||
|
Handle(ShapeFix_Edge) sfe = new ShapeFix_Edge();
|
||||||
|
sfe->FixAddPCurve(aNewEdge, TopoDS::Face(aFace), Standard_False);
|
||||||
}
|
}
|
||||||
|
|
||||||
TopTools_ListOfShape aOrderedList;
|
TopTools_ListOfShape aOrderedList;
|
||||||
|
18
tests/pipe/bugs/bug32818
Normal file
18
tests/pipe/bugs/bug32818
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
puts "========"
|
||||||
|
puts "0032818: Modeling Algorithms - Result of sweep operation is invalid"
|
||||||
|
puts "========"
|
||||||
|
puts ""
|
||||||
|
|
||||||
|
restore [locate_data_file bug32818.brep]
|
||||||
|
explode bug32818
|
||||||
|
renamevar bug32818_1 p
|
||||||
|
renamevar bug32818_2 pr
|
||||||
|
|
||||||
|
mksweep p
|
||||||
|
setsweep -CF
|
||||||
|
addsweep pr
|
||||||
|
|
||||||
|
buildsweep result -R -S
|
||||||
|
|
||||||
|
checkshape result
|
||||||
|
checknbshapes result -vertex 80 -edge 160 -wire 80 -face 80 -shell 1 -solid 1
|
Loading…
x
Reference in New Issue
Block a user