From 982a90fcba5d61b214841d9ab36fa047b92876a9 Mon Sep 17 00:00:00 2001 From: GKA <> Date: Fri, 17 Feb 2012 11:25:29 +0000 Subject: [PATCH] 0022968: RebuildShape exchanges 2d-curves --- src/SWDRAW/SWDRAW_ShapeUpgrade.cxx | 51 ++++++++++++++++++- .../ShapeUpgrade_RemoveLocations.cxx | 2 +- 2 files changed, 51 insertions(+), 2 deletions(-) diff --git a/src/SWDRAW/SWDRAW_ShapeUpgrade.cxx b/src/SWDRAW/SWDRAW_ShapeUpgrade.cxx index 893d4f0d32..07d81f4cf7 100755 --- a/src/SWDRAW/SWDRAW_ShapeUpgrade.cxx +++ b/src/SWDRAW/SWDRAW_ShapeUpgrade.cxx @@ -65,6 +65,9 @@ #include #include #include +#include +#include + // the plane (equation z=0) shared by PlaneDividedFaceContinuity and PlaneGridShell //static Handle(Geom_Plane) ThePlane= new Geom_Plane(0,0,1,0); @@ -447,7 +450,7 @@ static Standard_Integer DT_SplitAngle(Draw_Interpretor& di, if ( maxangle <1 ) maxangle = 1; } - ShapeUpgrade_ShapeDivideAngle tool(maxangle*M_PI/180,inputShape); + ShapeUpgrade_ShapeDivideAngle tool(maxangle * M_PI/180,inputShape); tool.Perform(); TopoDS_Shape res = tool.Result(); @@ -1403,6 +1406,49 @@ static Standard_Integer removeinternalwires (Draw_Interpretor& di, return 0; } +static Standard_Integer removeloc (Draw_Interpretor& di, + Standard_Integer argc, + const char** argv) +{ + if (argc<3) { + di << "bad number of arguments. Should be: removeloc res shape" <<"\n"; + return 1; + } + + TopoDS_Shape aShape = DBRep::Get(argv[2]); + if(aShape.IsNull()) + return 1; + ShapeUpgrade_RemoveLocations aRemLoc; + aRemLoc.Remove(aShape); + TopoDS_Shape aNewShape = aRemLoc.GetResult(); + + DBRep::Set(argv[1],aNewShape); + return 0; +} +static Standard_Integer copytranslate(Draw_Interpretor& di, + Standard_Integer argc, + const char** argv) +{ + if (argc<6) { + di << "bad number of arguments. Should be: removeloc res shape dx dyy dz" <<"\n"; + return 1; + } + TopoDS_Shape aShape = DBRep::Get(argv[2]); + if(aShape.IsNull()) + return 1; + Standard_Real aDx = atof(argv[3]); + Standard_Real aDy = atof(argv[4]); + Standard_Real aDz = atof(argv[5]); + gp_Trsf aTrsf; + aTrsf.SetTranslation(gp_Vec(aDx, aDy, aDz)); + BRepBuilderAPI_Transform builderTransform(aTrsf); + builderTransform.Perform (aShape, true); + TopoDS_Shape aNewShape = builderTransform.Shape(); + DBRep::Set(argv[1],aNewShape); + return 0; + +} + //======================================================================= //function : InitCommands //purpose : @@ -1497,4 +1543,7 @@ static Standard_Integer removeinternalwires (Draw_Interpretor& di, theCommands.Add ("RemoveIntWires","result minarea wholeshape [faces or wires] [moderemoveface ]", __FILE__,removeinternalwires,g); + + theCommands.Add ("removeloc","result shape",__FILE__,removeloc,g); + theCommands.Add ("copytranslate","result shape dx dy dz",__FILE__,copytranslate,g); } diff --git a/src/ShapeUpgrade/ShapeUpgrade_RemoveLocations.cxx b/src/ShapeUpgrade/ShapeUpgrade_RemoveLocations.cxx index 33c16f7209..210f11a983 100755 --- a/src/ShapeUpgrade/ShapeUpgrade_RemoveLocations.cxx +++ b/src/ShapeUpgrade/ShapeUpgrade_RemoveLocations.cxx @@ -118,7 +118,7 @@ static Standard_Boolean RebuildShape(const TopoDS_Edge& theEdge, TopoDS_Edge& th c2d1= BRep_Tool::CurveOnSurface(tmpE,theFace,First2d,Last2d); TopAbs_Orientation OrEdge = theNewEdge.Orientation(); - if(theNewFace.Orientation() == TopAbs_REVERSED) + if(theFace.Orientation() == TopAbs_REVERSED) OrEdge = ( OrEdge == TopAbs_FORWARD ? TopAbs_REVERSED : TopAbs_FORWARD); if(OrEdge == TopAbs_FORWARD)