1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-04-05 18:16:23 +03:00

0025228: Wrong result of General Fuse operation for an edge and a face.

Changes:

class BOPTools_AlgoTools3D
method:
void BOPTools_AlgoTools3D::DoSplitSEAMOnFace
(const TopoDS_Edge& aSplit,
 const TopoDS_Face& aF)

The treatment of seam edges for the periodic surfaces has been changed.

Test case for issue CR25228
This commit is contained in:
pkv 2014-09-18 14:50:37 +04:00 committed by bugmaster
parent 963532f8a2
commit 6303cb1205
2 changed files with 100 additions and 45 deletions

View File

@ -14,22 +14,8 @@
#include <BOPTools_AlgoTools3D.ixx> #include <BOPTools_AlgoTools3D.ixx>
#include <TopExp.hxx> #include <Bnd_Box.hxx>
#include <TopExp_Explorer.hxx> #include <Poly_Triangulation.hxx>
#include <TopoDS.hxx>
#include <TopoDS_Shape.hxx>
#include <TopoDS_Edge.hxx>
#include <TopoDS_Face.hxx>
#include <TopoDS_Vertex.hxx>
#include <BOPCol_IndexedMapOfShape.hxx>
#include <BOPCol_IndexedDataMapOfShapeListOfShape.hxx>
#include <BRep_Builder.hxx>
#include <BRep_Tool.hxx>
#include <BRepTools.hxx>
#include <BRepAdaptor_Surface.hxx>
#include <gp_Vec2d.hxx> #include <gp_Vec2d.hxx>
#include <gp_Pnt2d.hxx> #include <gp_Pnt2d.hxx>
@ -38,6 +24,7 @@
#include <gp_Vec.hxx> #include <gp_Vec.hxx>
#include <gp_Dir.hxx> #include <gp_Dir.hxx>
#include <gp_Pln.hxx> #include <gp_Pln.hxx>
#include <gp_Cylinder.hxx>
#include <Geom2d_Curve.hxx> #include <Geom2d_Curve.hxx>
#include <Geom2d_TrimmedCurve.hxx> #include <Geom2d_TrimmedCurve.hxx>
@ -47,18 +34,21 @@
#include <Geom_Surface.hxx> #include <Geom_Surface.hxx>
#include <Geom_BSplineSurface.hxx> #include <Geom_BSplineSurface.hxx>
#include <Geom_BezierSurface.hxx> #include <Geom_BezierSurface.hxx>
#include <Geom_RectangularTrimmedSurface.hxx>
#include <GeomAdaptor_Surface.hxx> #include <GeomAdaptor_Surface.hxx>
#include <Geom2dAdaptor_Curve.hxx>
#include <Geom2dHatch_Hatcher.hxx>
#include <HatchGen_Domain.hxx>
#include <IntTools_Tools.hxx> #include <TopoDS.hxx>
#include <TopoDS_Shape.hxx>
#include <TopoDS_Edge.hxx>
#include <TopoDS_Face.hxx>
#include <TopoDS_Vertex.hxx>
#include <BOPTools_AlgoTools2D.hxx> #include <BRep_Builder.hxx>
#include <BRep_Tool.hxx>
#include <GProp_GProps.hxx>
#include <BRepGProp.hxx>
#include <BRepBndLib.hxx>
#include <Bnd_Box.hxx>
#include <gp_Cylinder.hxx>
#include <BRep_TVertex.hxx> #include <BRep_TVertex.hxx>
#include <BRep_ListIteratorOfListOfPointRepresentation.hxx> #include <BRep_ListIteratorOfListOfPointRepresentation.hxx>
#include <BRep_PointRepresentation.hxx> #include <BRep_PointRepresentation.hxx>
@ -66,12 +56,24 @@
#include <BRep_ListIteratorOfListOfCurveRepresentation.hxx> #include <BRep_ListIteratorOfListOfCurveRepresentation.hxx>
#include <BRep_CurveRepresentation.hxx> #include <BRep_CurveRepresentation.hxx>
#include <BRep_TFace.hxx> #include <BRep_TFace.hxx>
#include <Poly_Triangulation.hxx>
#include <BRep_Builder.hxx> #include <BRepTools.hxx>
#include <BRepBndLib.hxx>
#include <BRepAdaptor_Surface.hxx>
#include <TopExp.hxx>
#include <TopExp_Explorer.hxx>
#include <GProp_GProps.hxx>
#include <BRepGProp.hxx>
#include <BOPCol_IndexedMapOfShape.hxx>
#include <BOPCol_IndexedDataMapOfShapeListOfShape.hxx>
#include <IntTools_Tools.hxx>
#include <IntTools_Context.hxx> #include <IntTools_Context.hxx>
#include <Geom2dAdaptor_Curve.hxx>
#include <Geom2dHatch_Hatcher.hxx> #include <BOPTools_AlgoTools2D.hxx>
#include <HatchGen_Domain.hxx>
static void Add(const TopoDS_Shape& aS, static void Add(const TopoDS_Shape& aS,
BOPCol_IndexedMapOfShape& myShapes, BOPCol_IndexedMapOfShape& myShapes,
@ -89,6 +91,7 @@ void BOPTools_AlgoTools3D::DoSplitSEAMOnFace (const TopoDS_Edge& aSplit,
Standard_Boolean bIsUPeriodic, bIsVPeriodic, bIsLeft; Standard_Boolean bIsUPeriodic, bIsVPeriodic, bIsLeft;
Standard_Real aTol, a, b, anUPeriod, anVPeriod, aT, anU, dU, anU1; Standard_Real aTol, a, b, anUPeriod, anVPeriod, aT, anU, dU, anU1;
Standard_Real aScPr, anV, dV, anV1; Standard_Real aScPr, anV, dV, anV1;
Standard_Real aUmin, aUmax, aVmin, aVmax;
gp_Pnt2d aP2D; gp_Pnt2d aP2D;
gp_Vec2d aVec2D; gp_Vec2d aVec2D;
Handle(Geom2d_Curve) aTmpC1, aTmpC2; Handle(Geom2d_Curve) aTmpC1, aTmpC2;
@ -104,6 +107,9 @@ void BOPTools_AlgoTools3D::DoSplitSEAMOnFace (const TopoDS_Edge& aSplit,
aTol=BRep_Tool::Tolerance(aSp); aTol=BRep_Tool::Tolerance(aSp);
// //
aS=BRep_Tool::Surface(aF); aS=BRep_Tool::Surface(aF);
//
aS->Bounds(aUmin, aUmax, aVmin, aVmax);
//
bIsUPeriodic=aS->IsUPeriodic(); bIsUPeriodic=aS->IsUPeriodic();
bIsVPeriodic=aS->IsVPeriodic(); bIsVPeriodic=aS->IsVPeriodic();
// //
@ -112,37 +118,53 @@ void BOPTools_AlgoTools3D::DoSplitSEAMOnFace (const TopoDS_Edge& aSplit,
// //
if (!bIsUPeriodic && !bIsVPeriodic) { if (!bIsUPeriodic && !bIsVPeriodic) {
Standard_Boolean bIsUClosed, bIsVClosed; Standard_Boolean bIsUClosed, bIsVClosed;
Standard_Real aUmin = 0., aUmax = 0., aVmin = 0., aVmax = 0.;
Handle(Geom_BSplineSurface) aBS; Handle(Geom_BSplineSurface) aBS;
Handle(Geom_BezierSurface) aBZ; Handle(Geom_BezierSurface) aBZ;
Handle(Geom_RectangularTrimmedSurface) aRTS;
// //
bIsUClosed=Standard_False; bIsUClosed=Standard_False;
bIsVClosed=Standard_False; bIsVClosed=Standard_False;
aBS=Handle(Geom_BSplineSurface)::DownCast(aS); aBS=Handle(Geom_BSplineSurface)::DownCast(aS);
aBZ=Handle(Geom_BezierSurface) ::DownCast(aS); aBZ=Handle(Geom_BezierSurface) ::DownCast(aS);
aRTS=Handle(Geom_RectangularTrimmedSurface)::DownCast(aS);
// //
if (!aBS.IsNull()) { if (!aBS.IsNull()) {
bIsUClosed=aBS->IsUClosed(); bIsUClosed=aBS->IsUClosed();
bIsVClosed=aBS->IsVClosed(); bIsVClosed=aBS->IsVClosed();
aBS->Bounds(aUmin, aUmax, aVmin, aVmax);
} }
else if (!aBZ.IsNull()) { else if (!aBZ.IsNull()) {
bIsUClosed=aBZ->IsUClosed(); bIsUClosed=aBZ->IsUClosed();
bIsVClosed=aBZ->IsVClosed(); bIsVClosed=aBZ->IsVClosed();
aBZ->Bounds(aUmin, aUmax, aVmin, aVmax);
} }
if (!bIsUClosed && !bIsVClosed) { else if (!aRTS.IsNull()) {
return; Handle(Geom_Surface) aSB;
//
aSB=aRTS->BasisSurface();
bIsUPeriodic=aSB->IsUPeriodic();
bIsVPeriodic=aSB->IsVPeriodic();
//
if (!(bIsUPeriodic || bIsVPeriodic)) {
return;
}
anUPeriod = bIsUPeriodic ? aSB->UPeriod() : 0.;
anVPeriod = bIsVPeriodic ? aSB->VPeriod() : 0.;
} }
// //
if (bIsUClosed) { if (aRTS.IsNull()) {
anUPeriod=aUmax-aUmin; if (!bIsUClosed && !bIsVClosed) {
} return;
if (bIsVClosed) { }
anVPeriod=aVmax-aVmin; //
if (bIsUClosed) {
anUPeriod=aUmax-aUmin;
}
if (bIsVClosed) {
anVPeriod=aVmax-aVmin;
}
} }
} }
// //
//---------------------------------------------------
C2D1=BRep_Tool::CurveOnSurface(aSp, aF, a, b); C2D1=BRep_Tool::CurveOnSurface(aSp, aF, a, b);
// //
aT=BOPTools_AlgoTools2D::IntermediatePoint(a, b); aT=BOPTools_AlgoTools2D::IntermediatePoint(a, b);
@ -160,22 +182,22 @@ void BOPTools_AlgoTools3D::DoSplitSEAMOnFace (const TopoDS_Edge& aSplit,
dV = aGAS.VResolution(aTol); dV = aGAS.VResolution(aTol);
// //
if (anUPeriod > 0.){ if (anUPeriod > 0.){
if (fabs (anU) < dU) { if (fabs (anU-aUmin) < dU) {
bIsLeft=Standard_True; bIsLeft=Standard_True;
anU1=anU+anUPeriod; anU1=anU+anUPeriod;
} }
else if (fabs (anU-anUPeriod) < dU) { else if (fabs (anU-aUmax) < dU) {
bIsLeft=Standard_False; bIsLeft=Standard_False;
anU1=anU-anUPeriod; anU1=anU-anUPeriod;
} }
} }
// //
if (anVPeriod > 0.) { if (anVPeriod > 0.) {
if (fabs (anV) < dV) { if (fabs (anV-aVmin) < dV) {
bIsLeft=Standard_True; bIsLeft=Standard_True;
anV1=anV+anVPeriod; anV1=anV+anVPeriod;
} }
else if (fabs (anV-anVPeriod) < dV) { else if (fabs (anV-aVmax) < dV) {
bIsLeft=Standard_False; bIsLeft=Standard_False;
anV1=anV-anVPeriod; anV1=anV-anVPeriod;
} }
@ -429,8 +451,7 @@ void BOPTools_AlgoTools3D::PointNearEdge (const TopoDS_Edge& aE,
} }
} }
if( aETol > 1.e-5 || aFTol > 1.e-5 ) { if( aETol > 1.e-5 || aFTol > 1.e-5 ) {
//if( aETol > 1.e-5 && aFTol > 1.e-5 ) { //
//pkv/103/D7
if(aTS!=GeomAbs_Sphere) { if(aTS!=GeomAbs_Sphere) {
gp_Vec2d transVec( aDP ); gp_Vec2d transVec( aDP );
transVal = aDt2D + aETol + aFTol; transVal = aDt2D + aETol + aFTol;

34
tests/bugs/modalg_5/bug25228 Executable file
View File

@ -0,0 +1,34 @@
puts "================"
puts "OCC25228"
puts "================"
puts ""
#######################################################################
# Wrong result of General Fuse operation for an edge and a face.
#######################################################################
restore [locate_data_file bug25228_qs.brep] qs
explode qs
copy qs_1 b1
copy qs_2 b2
bclearobjects
bcleartools
baddobjects b1 b2
bfillds
bbuild result
set square 227.765
set nb_v_good 2
set nb_e_good 3
set nb_w_good 1
set nb_f_good 1
set nb_sh_good 0
set nb_sol_good 0
set nb_compsol_good 0
set nb_compound_good 1
set nb_shape_good 8
set 3dviewer 1