mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-01 04:10:34 +05:00
0020695: EDF 1076 GEOM: Add a new shape in GEOM: T-shape
- Fix problem with group creation for pipe t-shapes with position
This commit is contained in:
parent
db88ad36a7
commit
9da0aeceb7
@ -395,11 +395,13 @@ bool GEOMImpl_IAdvancedOperations::MakeGroups(/*std::vector<GEOM_IOperations*> t
|
|||||||
/////////////////////////
|
/////////////////////////
|
||||||
// Result of propagate
|
// Result of propagate
|
||||||
|
|
||||||
// Apply inverted transformation to shape
|
|
||||||
BRepBuilderAPI_Transform aTransformationShapeInv(theShape->GetValue(), aTrsfInv, Standard_False);
|
|
||||||
TopoDS_Shape aShapeTrsfInv = aTransformationShapeInv.Shape();
|
|
||||||
Handle(GEOM_Function) aFunction = theShape->GetLastFunction();
|
Handle(GEOM_Function) aFunction = theShape->GetLastFunction();
|
||||||
aFunction->SetValue(aShapeTrsfInv);
|
|
||||||
|
|
||||||
|
// Apply inverted transformation to shape
|
||||||
|
// BRepBuilderAPI_Transform aTransformationShapeInv(aShape, aTrsfInv, Standard_False);
|
||||||
|
// TopoDS_Shape aShapeTrsfInv = aTransformationShapeInv.Shape();
|
||||||
|
// aFunction->SetValue(aShapeTrsfInv);
|
||||||
|
|
||||||
TCollection_AsciiString theDesc = aFunction->GetDescription();
|
TCollection_AsciiString theDesc = aFunction->GetDescription();
|
||||||
Handle(TColStd_HSequenceOfTransient) aSeqPropagate = aBlocksOperations->Propagate(theShape);
|
Handle(TColStd_HSequenceOfTransient) aSeqPropagate = aBlocksOperations->Propagate(theShape);
|
||||||
@ -413,9 +415,9 @@ bool GEOMImpl_IAdvancedOperations::MakeGroups(/*std::vector<GEOM_IOperations*> t
|
|||||||
|
|
||||||
|
|
||||||
// Apply transformation to shape
|
// Apply transformation to shape
|
||||||
BRepBuilderAPI_Transform aTransformationShape(theShape->GetValue(), aTrsf, Standard_False);
|
// BRepBuilderAPI_Transform aTransformationShape(theShape->GetValue(), aTrsf, Standard_False);
|
||||||
TopoDS_Shape aShapeTrsf = aTransformationShape.Shape();
|
// TopoDS_Shape aShapeTrsf = aTransformationShape.Shape();
|
||||||
aFunction->SetValue(aShapeTrsf);
|
// aFunction->SetValue(aShapeTrsf);
|
||||||
|
|
||||||
bool addGroup;
|
bool addGroup;
|
||||||
bool circularFoundAndAdded = false;
|
bool circularFoundAndAdded = false;
|
||||||
@ -435,9 +437,11 @@ bool GEOMImpl_IAdvancedOperations::MakeGroups(/*std::vector<GEOM_IOperations*> t
|
|||||||
continue;
|
continue;
|
||||||
|
|
||||||
TopoDS_Shape aGroupShape = aGroup->GetValue();
|
TopoDS_Shape aGroupShape = aGroup->GetValue();
|
||||||
|
BRepBuilderAPI_Transform aTransformationShapeInv(aGroupShape, aTrsfInv, Standard_False);
|
||||||
|
TopoDS_Shape aGroupShapeTrsfInv = aTransformationShapeInv.Shape();
|
||||||
|
|
||||||
TopTools_IndexedMapOfShape anEdgesMap;
|
TopTools_IndexedMapOfShape anEdgesMap;
|
||||||
TopExp::MapShapes(aGroupShape,TopAbs_EDGE, anEdgesMap);
|
TopExp::MapShapes(aGroupShapeTrsfInv,TopAbs_EDGE, anEdgesMap);
|
||||||
nbEdges = anEdgesMap.Extent();
|
nbEdges = anEdgesMap.Extent();
|
||||||
|
|
||||||
if (shapeType == TSHAPE_BASIC) {
|
if (shapeType == TSHAPE_BASIC) {
|
||||||
@ -458,7 +462,7 @@ bool GEOMImpl_IAdvancedOperations::MakeGroups(/*std::vector<GEOM_IOperations*> t
|
|||||||
radialFound =false;
|
radialFound =false;
|
||||||
flangeFound = false;
|
flangeFound = false;
|
||||||
|
|
||||||
TopExp_Explorer Ex(aGroupShape,TopAbs_VERTEX);
|
TopExp_Explorer Ex(aGroupShapeTrsfInv,TopAbs_VERTEX);
|
||||||
while (Ex.More()) {
|
while (Ex.More()) {
|
||||||
gp_Pnt aP = BRep_Tool::Pnt(TopoDS::Vertex(Ex.Current()));
|
gp_Pnt aP = BRep_Tool::Pnt(TopoDS::Vertex(Ex.Current()));
|
||||||
double x=aP.X(), y=aP.Y(), z=aP.Z();
|
double x=aP.X(), y=aP.Y(), z=aP.Z();
|
||||||
@ -524,7 +528,7 @@ bool GEOMImpl_IAdvancedOperations::MakeGroups(/*std::vector<GEOM_IOperations*> t
|
|||||||
mainPipeFound = false;
|
mainPipeFound = false;
|
||||||
flangeFound = false;
|
flangeFound = false;
|
||||||
|
|
||||||
TopExp_Explorer Ex(aGroupShape,TopAbs_VERTEX);
|
TopExp_Explorer Ex(aGroupShapeTrsfInv,TopAbs_VERTEX);
|
||||||
while (Ex.More()) {
|
while (Ex.More()) {
|
||||||
gp_Pnt aP = BRep_Tool::Pnt(TopoDS::Vertex(Ex.Current()));
|
gp_Pnt aP = BRep_Tool::Pnt(TopoDS::Vertex(Ex.Current()));
|
||||||
double x=aP.X(), y=aP.Y(), z=aP.Z();
|
double x=aP.X(), y=aP.Y(), z=aP.Z();
|
||||||
@ -586,55 +590,6 @@ bool GEOMImpl_IAdvancedOperations::MakeGroups(/*std::vector<GEOM_IOperations*> t
|
|||||||
theSeq->Append(aGroup);
|
theSeq->Append(aGroup);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Handle(GEOM_Object) aGroup;
|
|
||||||
// if (shapeType == TSHAPE_BASIC) {
|
|
||||||
// // if (aNbGroups != 11) {
|
|
||||||
// // SetErrorCode("Bad number of propagation groups");
|
|
||||||
// // return false;
|
|
||||||
// // }
|
|
||||||
// aGroup = Handle(GEOM_Object)::DownCast(aSeqPropagate->Value(1));
|
|
||||||
// aGroup->SetName("THICKNESS");
|
|
||||||
// theSeq->Append(aGroup);
|
|
||||||
// aGroup = Handle(GEOM_Object)::DownCast(aSeqPropagate->Value(2));
|
|
||||||
// aGroup->SetName("CIRCULAR_QUARTER_PIPE");
|
|
||||||
// theSeq->Append(aGroup);
|
|
||||||
// aGroup = Handle(GEOM_Object)::DownCast(aSeqPropagate->Value(3));
|
|
||||||
// aGroup->SetName("HALF_LENGTH_MAIN_PIPE");
|
|
||||||
// theSeq->Append(aGroup);
|
|
||||||
// aGroup = Handle(GEOM_Object)::DownCast(aSeqPropagate->Value(6));
|
|
||||||
// aGroup->SetName("HALF_LENGTH_INCIDENT_PIPE");
|
|
||||||
// theSeq->Append(aGroup);
|
|
||||||
// aGroup = Handle(GEOM_Object)::DownCast(aSeqPropagate->Value(5));
|
|
||||||
// aGroup->SetName("FLANGE");
|
|
||||||
// theSeq->Append(aGroup);
|
|
||||||
// } else if (shapeType == TSHAPE_CHAMFER || shapeType == TSHAPE_FILLET) {
|
|
||||||
// if (aNbGroups != 12) {
|
|
||||||
// SetErrorCode("Bad number of propagation groups");
|
|
||||||
// return false;
|
|
||||||
// }
|
|
||||||
// aGroup = Handle(GEOM_Object)::DownCast(aSeqPropagate->Value(3));
|
|
||||||
// aGroup->SetName("THICKNESS");
|
|
||||||
// theSeq->Append(aGroup);
|
|
||||||
// aGroup = Handle(GEOM_Object)::DownCast(aSeqPropagate->Value(1));
|
|
||||||
// aGroup->SetName("CIRCULAR_QUARTER_PIPE");
|
|
||||||
// theSeq->Append(aGroup);
|
|
||||||
// aGroup = Handle(GEOM_Object)::DownCast(aSeqPropagate->Value(4));
|
|
||||||
// aGroup->SetName("HALF_LENGTH_MAIN_PIPE");
|
|
||||||
// theSeq->Append(aGroup);
|
|
||||||
// aGroup = Handle(GEOM_Object)::DownCast(aSeqPropagate->Value(6));
|
|
||||||
// aGroup->SetName("HALF_LENGTH_INCIDENT_PIPE");
|
|
||||||
// theSeq->Append(aGroup);
|
|
||||||
// aGroup = Handle(GEOM_Object)::DownCast(aSeqPropagate->Value(2));
|
|
||||||
// aGroup->SetName("FLANGE");
|
|
||||||
// theSeq->Append(aGroup);
|
|
||||||
// aGroup = Handle(GEOM_Object)::DownCast(aSeqPropagate->Value(7));
|
|
||||||
// if (shapeType == TSHAPE_CHAMFER)
|
|
||||||
// aGroup->SetName("CHAMFER");
|
|
||||||
// else
|
|
||||||
// aGroup->SetName("FILLET");
|
|
||||||
// theSeq->Append(aGroup);
|
|
||||||
// }
|
|
||||||
|
|
||||||
SetErrorCode(OK);
|
SetErrorCode(OK);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user