mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-01 12:20:36 +05:00
Fix bug 0020096: EDF 897 GEOM MakeFilling with a compound de wires.
This commit is contained in:
parent
27eae2a6a0
commit
f20d5f5cc0
@ -106,12 +106,19 @@ Standard_Integer GEOMImpl_FillingDriver::Execute(TFunction_Logbook& log) const
|
|||||||
Standard_Real First, Last;
|
Standard_Real First, Last;
|
||||||
Handle(Geom_Curve) C;
|
Handle(Geom_Curve) C;
|
||||||
|
|
||||||
if(!isApprox) {
|
TopoDS_Iterator It (aShape);
|
||||||
|
for (; It.More(); It.Next()) {
|
||||||
|
Scurrent = It.Value();
|
||||||
|
if (Scurrent.ShapeType() != TopAbs_EDGE)
|
||||||
|
Standard_ConstructionError::Raise("The argument compound must contain only edges");
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isApprox) {
|
||||||
// make filling as in old version of SALOME (before 4.1.1)
|
// make filling as in old version of SALOME (before 4.1.1)
|
||||||
GeomFill_SectionGenerator Section;
|
GeomFill_SectionGenerator Section;
|
||||||
Standard_Integer i = 0;
|
Standard_Integer i = 0;
|
||||||
for (Ex.Init(aShape, TopAbs_EDGE); Ex.More(); Ex.Next()) {
|
for (Ex.Init(aShape, TopAbs_EDGE); Ex.More(); Ex.Next()) {
|
||||||
Scurrent = Ex.Current() ;
|
Scurrent = Ex.Current();
|
||||||
if (Scurrent.IsNull() || Scurrent.ShapeType() != TopAbs_EDGE) return 0;
|
if (Scurrent.IsNull() || Scurrent.ShapeType() != TopAbs_EDGE) return 0;
|
||||||
if (BRep_Tool::Degenerated(TopoDS::Edge(Scurrent))) continue;
|
if (BRep_Tool::Degenerated(TopoDS::Edge(Scurrent))) continue;
|
||||||
C = BRep_Tool::Curve(TopoDS::Edge(Scurrent), First, Last);
|
C = BRep_Tool::Curve(TopoDS::Edge(Scurrent), First, Last);
|
||||||
@ -119,14 +126,14 @@ Standard_Integer GEOMImpl_FillingDriver::Execute(TFunction_Logbook& log) const
|
|||||||
Section.AddCurve(C);
|
Section.AddCurve(C);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* a 'tolerance' is used to compare 2 knots : see GeomFill_Generator.cdl */
|
/* a 'tolerance' is used to compare 2 knots : see GeomFill_Generator.cdl */
|
||||||
Section.Perform(Precision::Confusion());
|
Section.Perform(Precision::Confusion());
|
||||||
Handle(GeomFill_Line) Line = new GeomFill_Line(i);
|
Handle(GeomFill_Line) Line = new GeomFill_Line(i);
|
||||||
|
|
||||||
GeomFill_AppSurf App (mindeg, maxdeg, tol3d, tol2d, nbiter); /* user parameters */
|
GeomFill_AppSurf App (mindeg, maxdeg, tol3d, tol2d, nbiter); /* user parameters */
|
||||||
App.Perform(Line, Section);
|
App.Perform(Line, Section);
|
||||||
|
|
||||||
if (!App.IsDone()) return 0;
|
if (!App.IsDone()) return 0;
|
||||||
Standard_Integer UDegree, VDegree, NbUPoles, NbVPoles, NbUKnots, NbVKnots;
|
Standard_Integer UDegree, VDegree, NbUPoles, NbVPoles, NbUKnots, NbVKnots;
|
||||||
App.SurfShape(UDegree, VDegree, NbUPoles, NbVPoles, NbUKnots, NbVKnots);
|
App.SurfShape(UDegree, VDegree, NbUPoles, NbVPoles, NbUKnots, NbVKnots);
|
||||||
@ -146,7 +153,7 @@ Standard_Integer GEOMImpl_FillingDriver::Execute(TFunction_Logbook& log) const
|
|||||||
// add curves from edges to sequence and find maximal
|
// add curves from edges to sequence and find maximal
|
||||||
// number of poles if some of them are bsplines
|
// number of poles if some of them are bsplines
|
||||||
for (Ex.Init(aShape, TopAbs_EDGE); Ex.More(); Ex.Next()) {
|
for (Ex.Init(aShape, TopAbs_EDGE); Ex.More(); Ex.Next()) {
|
||||||
Scurrent = Ex.Current() ;
|
Scurrent = Ex.Current();
|
||||||
if (Scurrent.IsNull() || Scurrent.ShapeType() != TopAbs_EDGE) return 0;
|
if (Scurrent.IsNull() || Scurrent.ShapeType() != TopAbs_EDGE) return 0;
|
||||||
if (BRep_Tool::Degenerated(TopoDS::Edge(Scurrent))) continue;
|
if (BRep_Tool::Degenerated(TopoDS::Edge(Scurrent))) continue;
|
||||||
C = BRep_Tool::Curve(TopoDS::Edge(Scurrent), First, Last);
|
C = BRep_Tool::Curve(TopoDS::Edge(Scurrent), First, Last);
|
||||||
|
Loading…
Reference in New Issue
Block a user