mirror of
https://git.salome-platform.org/gitpub/modules/geom.git
synced 2025-01-22 19:00:34 +05:00
Mantis issue 0021414: There is a difference between vectors and other edges in Geometry.
This commit is contained in:
parent
502948884b
commit
d9b43f0941
@ -1828,7 +1828,7 @@ Handle(GEOM_Object) GEOMImpl_IShapesOperations::ReverseShape(Handle(GEOM_Object)
|
|||||||
if (aGen) {
|
if (aGen) {
|
||||||
GEOMImpl_IHealingOperations* anIHealingOperations =
|
GEOMImpl_IHealingOperations* anIHealingOperations =
|
||||||
aGen->GetIHealingOperations(GetDocID());
|
aGen->GetIHealingOperations(GetDocID());
|
||||||
aReversed = anIHealingOperations->ChangeOrientation(theShape);
|
aReversed = anIHealingOperations->ChangeOrientationCopy(theShape);
|
||||||
SetErrorCode(anIHealingOperations->GetErrorCode());
|
SetErrorCode(anIHealingOperations->GetErrorCode());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -18,15 +18,16 @@
|
|||||||
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
//
|
//
|
||||||
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
|
||||||
//
|
|
||||||
|
|
||||||
// File: ShHealOper_ChangeOrientation.cxx
|
// File: ShHealOper_ChangeOrientation.cxx
|
||||||
// Created: 11.07.06 11:46:45
|
// Created: 11.07.06 11:46:45
|
||||||
// Author: Sergey KUUL
|
// Author: Sergey KUUL
|
||||||
//
|
|
||||||
#include <ShHealOper_ChangeOrientation.hxx>
|
#include <ShHealOper_ChangeOrientation.hxx>
|
||||||
|
|
||||||
#include <BRep_Builder.hxx>
|
#include <BRep_Builder.hxx>
|
||||||
|
#include <BRepBuilderAPI_Copy.hxx>
|
||||||
|
|
||||||
#include <TopoDS_Iterator.hxx>
|
#include <TopoDS_Iterator.hxx>
|
||||||
|
|
||||||
//=======================================================================
|
//=======================================================================
|
||||||
@ -59,7 +60,7 @@ Standard_Boolean ShHealOper_ChangeOrientation::Perform()
|
|||||||
BRep_Builder B;
|
BRep_Builder B;
|
||||||
if (myInitShape.ShapeType() == TopAbs_SHELL) {
|
if (myInitShape.ShapeType() == TopAbs_SHELL) {
|
||||||
myResultShape = myInitShape.EmptyCopied();
|
myResultShape = myInitShape.EmptyCopied();
|
||||||
TopoDS_Iterator itr(myInitShape);
|
TopoDS_Iterator itr (myInitShape);
|
||||||
while (itr.More()) {
|
while (itr.More()) {
|
||||||
B.Add(myResultShape,itr.Value().Reversed());
|
B.Add(myResultShape,itr.Value().Reversed());
|
||||||
itr.Next();
|
itr.Next();
|
||||||
@ -67,7 +68,7 @@ Standard_Boolean ShHealOper_ChangeOrientation::Perform()
|
|||||||
}
|
}
|
||||||
else if (myInitShape.ShapeType() == TopAbs_FACE) {
|
else if (myInitShape.ShapeType() == TopAbs_FACE) {
|
||||||
myResultShape = myInitShape.EmptyCopied();
|
myResultShape = myInitShape.EmptyCopied();
|
||||||
TopoDS_Iterator itr(myInitShape);
|
TopoDS_Iterator itr (myInitShape);
|
||||||
while (itr.More()) {
|
while (itr.More()) {
|
||||||
B.Add(myResultShape,itr.Value());
|
B.Add(myResultShape,itr.Value());
|
||||||
itr.Next();
|
itr.Next();
|
||||||
@ -76,7 +77,7 @@ Standard_Boolean ShHealOper_ChangeOrientation::Perform()
|
|||||||
}
|
}
|
||||||
else if ( myInitShape.ShapeType() == TopAbs_WIRE || myInitShape.ShapeType() == TopAbs_EDGE) {
|
else if ( myInitShape.ShapeType() == TopAbs_WIRE || myInitShape.ShapeType() == TopAbs_EDGE) {
|
||||||
myResultShape = myInitShape.EmptyCopied();
|
myResultShape = myInitShape.EmptyCopied();
|
||||||
TopoDS_Iterator itr(myInitShape);
|
TopoDS_Iterator itr (myInitShape);
|
||||||
while (itr.More()) {
|
while (itr.More()) {
|
||||||
B.Add(myResultShape,itr.Value());
|
B.Add(myResultShape,itr.Value());
|
||||||
itr.Next();
|
itr.Next();
|
||||||
@ -84,9 +85,17 @@ Standard_Boolean ShHealOper_ChangeOrientation::Perform()
|
|||||||
myResultShape.Reverse();
|
myResultShape.Reverse();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
return false;
|
BRepBuilderAPI_Copy Copy (myInitShape);
|
||||||
|
if (!Copy.IsDone()) return false;
|
||||||
|
|
||||||
|
myResultShape = Copy.Shape();
|
||||||
|
if (myResultShape.IsNull()) return false;
|
||||||
|
|
||||||
|
if (myResultShape.Orientation() == TopAbs_FORWARD)
|
||||||
|
myResultShape.Orientation(TopAbs_REVERSED);
|
||||||
|
else
|
||||||
|
myResultShape.Orientation(TopAbs_FORWARD);
|
||||||
}
|
}
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user