mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2024-12-25 17:00:35 +05:00
0052436: MakePipeWithDifferentsSections does not work correctly
This commit is contained in:
parent
12122ec111
commit
b5261a9818
@ -681,6 +681,7 @@ TopoDS_Shape GEOMImpl_PipeDriver::CreatePipeWithDifferentSections
|
||||
TopTools_SequenceOfShape aSeqBases;
|
||||
TopTools_SequenceOfShape aSeqLocs;
|
||||
TopTools_SequenceOfShape aSeqFaces;
|
||||
Standard_Boolean NeedCreateSolid = Standard_False;
|
||||
|
||||
Standard_Integer i = 1;
|
||||
for (i = 1; i <= nbBases; i++) {
|
||||
@ -697,7 +698,6 @@ TopoDS_Shape GEOMImpl_PipeDriver::CreatePipeWithDifferentSections
|
||||
|
||||
//if for section was specified face with a few wires then a few
|
||||
// pipes were build and make solid
|
||||
Standard_Boolean NeedCreateSolid = Standard_False;
|
||||
if (aTypeBase == TopAbs_SHELL) {
|
||||
// create wire as boundary contour if shell is no closed
|
||||
// get free boundary shapes
|
||||
@ -1015,21 +1015,21 @@ TopoDS_Shape GEOMImpl_PipeDriver::CreatePipeWithDifferentSections
|
||||
aBuilder.SetTolerance(aTolConf, aTolConf, aTolAng);
|
||||
|
||||
aBuilder.Build();
|
||||
|
||||
Standard_Boolean isDone = aBuilder.IsDone();
|
||||
|
||||
if (isDone && NeedCreateSolid) {
|
||||
isDone = aBuilder.MakeSolid();
|
||||
}
|
||||
|
||||
if (!isDone) {
|
||||
Standard_ConstructionError::Raise("Pipe construction failure");
|
||||
}
|
||||
aShape = aBuilder.Shape();
|
||||
aSeqFaces.Append(aShape);
|
||||
for (j = 1; j <=usedBases.Length(); j++)
|
||||
aBuilder.Delete(usedBases.Value(j));
|
||||
}
|
||||
|
||||
//for case if section is face
|
||||
if (aSeqFaces.Length() >1) {
|
||||
BRep_Builder aB;
|
||||
TopoDS_Compound aComp;
|
||||
aB.MakeCompound(aComp);
|
||||
for (i = 1; i <= aSeqFaces.Length(); i++)
|
||||
aB.Add(aComp,aSeqFaces.Value(i));
|
||||
aShape = aComp;
|
||||
}
|
||||
}
|
||||
|
||||
return aShape;
|
||||
|
@ -165,6 +165,8 @@ void GenerationGUI_PipeDlg::Init()
|
||||
connect(GroupMakePoints->PushButton1, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
|
||||
connect(GroupMakePoints->PushButton2, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
|
||||
connect(GroupMakePoints->PushButton3, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument()));
|
||||
connect(GroupMakePoints->CheckBox1, SIGNAL(clicked()), this, SLOT(processPreview()));
|
||||
connect(GroupMakePoints->CheckBox2, SIGNAL(clicked()), this, SLOT(processPreview()));
|
||||
|
||||
initName(tr("GEOM_PIPE"));
|
||||
resize(100,100);
|
||||
@ -264,10 +266,7 @@ bool GenerationGUI_PipeDlg::ClickOnApply()
|
||||
return false;
|
||||
|
||||
initName();
|
||||
if ( getConstructorId() != 1 )
|
||||
ConstructorsClicked( getConstructorId() );
|
||||
// activate selection and connect selection manager
|
||||
// GroupPoints->PushButton1->click();
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user