From 60f890c92343fd87aaad74f6727eea997592fb23 Mon Sep 17 00:00:00 2001 From: vsr Date: Wed, 6 Oct 2010 13:34:46 +0000 Subject: [PATCH] Issue 0020747: EDF 1275 GEOM : Create one edge from one wire --- doc/salome/gui/GEOM/images/edge1.png | Bin 0 -> 16136 bytes doc/salome/gui/GEOM/images/edge2.png | Bin 0 -> 18023 bytes doc/salome/gui/GEOM/images/neo-obj2.png | Bin 14299 -> 0 bytes doc/salome/gui/GEOM/input/creating_edge.doc | 45 ++- .../gui/GEOM/input/tui_advanced_geom_objs.doc | 26 +- idl/GEOM_Gen.idl | 11 + resources/Makefile.am | 1 + resources/build_edge_wire.png | Bin 0 -> 428 bytes src/BuildGUI/BuildGUI_EdgeDlg.cxx | 279 +++++++++++--- src/BuildGUI/BuildGUI_EdgeDlg.h | 9 +- src/GEOMGUI/GEOM_images.ts | 4 + src/GEOMGUI/GEOM_msg_en.ts | 8 + src/GEOMImpl/GEOMImpl_IShapes.hxx | 8 +- src/GEOMImpl/GEOMImpl_IShapesOperations.cxx | 71 ++++ src/GEOMImpl/GEOMImpl_IShapesOperations.hxx | 5 +- src/GEOMImpl/GEOMImpl_ShapeDriver.cxx | 353 ++++++++++++++++++ src/GEOMImpl/GEOMImpl_Types.hxx | 1 + src/GEOM_I/GEOM_IShapesOperations_i.cc | 28 ++ src/GEOM_I/GEOM_IShapesOperations_i.hh | 3 + src/GEOM_SWIG/geompyDC.py | 13 + 20 files changed, 787 insertions(+), 78 deletions(-) create mode 100644 doc/salome/gui/GEOM/images/edge1.png create mode 100644 doc/salome/gui/GEOM/images/edge2.png delete mode 100755 doc/salome/gui/GEOM/images/neo-obj2.png create mode 100644 resources/build_edge_wire.png diff --git a/doc/salome/gui/GEOM/images/edge1.png b/doc/salome/gui/GEOM/images/edge1.png new file mode 100644 index 0000000000000000000000000000000000000000..03840b25efa3830163e859b5bb3869a656fa2ede GIT binary patch literal 16136 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 om383b%7 literal 0 HcmV?d00001 diff --git a/doc/salome/gui/GEOM/images/edge2.png b/doc/salome/gui/GEOM/images/edge2.png new file mode 100644 index 0000000000000000000000000000000000000000..b17336e0694a647750f3ce86cb4880ec04e30f03 GIT binary patch literal 18023 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 literal 0 HcmV?d00001 diff --git a/doc/salome/gui/GEOM/images/neo-obj2.png b/doc/salome/gui/GEOM/images/neo-obj2.png deleted file mode 100755 index 3ce42b45c8ce5df1187774da46ce5d0cce3f336f..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 14299 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 Menu select New Entity- > Build - > Edge +To create an \b Edge, in the Main Menu select New Entity > +Build > Edge -\n You can create an \b Edge from two points (\b Point1 and \b Point2), being the first and the last vertices of the edge. +There are two ways to create an edge. In both cases the \b Result +will be a \b GEOM_Object (EDGE). -The \b Result will be a \b GEOM_Object (EDGE). +1. You can create an \b Edge by specifying two points (\b Point1 and +\b Point2), being the first and the last vertices of the edge. -TUI Command: geompy.MakeEdge(Vertex1, Vertex2), where -Vertex1 and Vertex2 are correspondingly the first and the last vertex -of the edge. +TUI Command: geompy.MakeEdge(Vertex1, Vertex2)
+Arguments: Name + 2 vertices (Vertex1 and Vertex2 are +correspondingly the first and the last vertex of the edge). -Arguments: Name + 2 vertices. +\image html edge1.png "Create edge by two points" -\image html neo-obj2.png +2. You can create an \b Edge by specifying single wire. -\n Example: +In this mode the following use cases are possible: +- All the edges, forming the wire, lie on the single geometrical curve +(i.e. curve(edge1) == curve(edge2)). +- The edges forming the wire, lie on the analytical curves of the same +type, for example, segments of line, arcs, etc. In this case, an +algorithm checks the geometrical coincidence of these curves using +some tolerance. If the curves are coinciding in terms of given +tolerance, resulting edge is built as on a single curve. +- The edges forming the wire have the same tangency in the connection +points. In this case the curves are interpolated by the single +b-spline curve with the sufficient precision. The resulting edge will +be then built on this curve. + +The case when the edges forming the wire have different tangency in +the connection points (sharp bend) is not processed. + +TUI Command: geompy.MakeEdgeWire(Wire, LinearTolerance, AngularTolerance)
+Arguments: Name + 1 wire + Linear Tolerance + Angular Tolerance +(tolerance are used to check coincidence of the edges' underlying curves). + +\image html edge2.png "Create edge from wire" + +Example: \image html edgesn.png "Edge" Our TUI Scripts provide you with useful examples of creation of \ref tui_creation_edge "Advanced Geometric Objects". -*/ \ No newline at end of file +*/ diff --git a/doc/salome/gui/GEOM/input/tui_advanced_geom_objs.doc b/doc/salome/gui/GEOM/input/tui_advanced_geom_objs.doc index f9f402a7e..506e1039a 100644 --- a/doc/salome/gui/GEOM/input/tui_advanced_geom_objs.doc +++ b/doc/salome/gui/GEOM/input/tui_advanced_geom_objs.doc @@ -10,6 +10,10 @@ import geompy import salome gg = salome.ImportComponentGUI("GEOM") +# +# create edge by two points +# + # create vertices p0 = geompy.MakeVertex(0. , 0. , 0. ) pxyz = geompy.MakeVertex(100., 100., 100.) @@ -18,10 +22,30 @@ pxyz = geompy.MakeVertex(100., 100., 100.) edge = geompy.MakeEdge(p0, pxyz) # add object in the study -id_edge = geompy.addToStudy(edge,"Edge") +id_edge = geompy.addToStudy(edge,"Edge_1") # display an edge gg.createAndDisplayGO(id_edge) + +# +# create edge from wire +# + +# create a circle +c = geompy.MakeCircle(None, None, 100) + +# create a wire +w = geompy.MakeWire([c], 1e-07) + +# create an edge from wire +edge = geompy.MakeEdgeWire(w) + +# add object in the study +id_edge = geompy.addToStudy(edge,"Edge_2") + +# display an edge +gg.createAndDisplayGO(id_edge) + \endcode \anchor tui_creation_wire diff --git a/idl/GEOM_Gen.idl b/idl/GEOM_Gen.idl index 4cef6701a..7f37c359b 100644 --- a/idl/GEOM_Gen.idl +++ b/idl/GEOM_Gen.idl @@ -1313,6 +1313,17 @@ module GEOM */ GEOM_Object MakeEdge (in GEOM_Object thePnt1, in GEOM_Object thePnt2); + /*! + * Create an edge from specified wire. + * \param theWire source Wire. + * \param theLinearTolerance linear tolerance value + * \param theAngularTolerance angular tolerance value + * \return New GEOM_Object, containing the created edge. + */ + GEOM_Object MakeEdgeWire (in GEOM_Object theWire, + in double theLinearTolerance, + in double theAngularTolerance); + /*! * Create a wire from the set of edges and wires. * \param theEdgesAndWires List of edge and/or wires. diff --git a/resources/Makefile.am b/resources/Makefile.am index f8bc0a9dc..76368f05b 100644 --- a/resources/Makefile.am +++ b/resources/Makefile.am @@ -47,6 +47,7 @@ box2points.png \ boxdxyz.png \ build_compound.png \ build_edge.png \ +build_edge_wire.png \ build_face.png \ build_shell.png \ build_solid.png \ diff --git a/resources/build_edge_wire.png b/resources/build_edge_wire.png new file mode 100644 index 0000000000000000000000000000000000000000..3c7b5383bf25da78ffd7aedee8b524dad99434f9 GIT binary patch literal 428 zcmeAS@N?(olHy`uVBq!ia0vp^A|TAc1|)ksWqE-VV{wqX6T`Z5GB1G~wj^(N7l!{J zxM1({$v_d#0*}aI1_o{+5N5n|x9$&6kiEpy*OmPirzE!!XAtiRX`m@Oo-U3d7N?I+ zF$_9vAmBQ`?9xoRub%zfT+4!ck=^mD@s=%ul8@~>bU;M_5;rv{Vgra-tOtB zSbLZGEenrR~DmdKI;Vst0Ncc`bpQYW literal 0 HcmV?d00001 diff --git a/src/BuildGUI/BuildGUI_EdgeDlg.cxx b/src/BuildGUI/BuildGUI_EdgeDlg.cxx index 5096b2a7a..33e9f1e50 100644 --- a/src/BuildGUI/BuildGUI_EdgeDlg.cxx +++ b/src/BuildGUI/BuildGUI_EdgeDlg.cxx @@ -36,6 +36,7 @@ #include #include +#include //================================================================================= // class : BuildGUI_EdgeDlg() @@ -47,38 +48,58 @@ BuildGUI_EdgeDlg::BuildGUI_EdgeDlg (GeometryGUI* theGeometryGUI, QWidget* parent) : GEOMBase_Skeleton(theGeometryGUI, parent) { - QPixmap image0 (SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM", tr("ICON_DLG_BUILD_EDGE"))); - QPixmap image1 (SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM", tr("ICON_SELECT"))); + QPixmap image0 (SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM", tr("ICON_SELECT"))); + QPixmap image1 (SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM", tr("ICON_DLG_BUILD_EDGE"))); + QPixmap image2 (SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM", tr("ICON_DLG_BUILD_EDGE_WIRE"))); setWindowTitle(tr("GEOM_EDGE_TITLE")); /***************************************************************/ mainFrame()->GroupConstructors->setTitle(tr("GEOM_EDGE")); - mainFrame()->RadioButton1->setIcon(image0); - mainFrame()->RadioButton2->setAttribute(Qt::WA_DeleteOnClose); - mainFrame()->RadioButton2->close(); - mainFrame()->RadioButton3->setAttribute(Qt::WA_DeleteOnClose); + mainFrame()->RadioButton1->setIcon(image1); + mainFrame()->RadioButton2->setIcon(image2); + mainFrame()->RadioButton3->setAttribute( Qt::WA_DeleteOnClose ); mainFrame()->RadioButton3->close(); - GroupPoints = new DlgRef_2Sel(centralWidget()); + // two points + GroupPoints = new DlgRef_2Sel(centralWidget()); GroupPoints->GroupBox1->setTitle(tr("GEOM_POINTS")); GroupPoints->TextLabel1->setText(tr("GEOM_POINT_I").arg(1)); GroupPoints->TextLabel2->setText(tr("GEOM_POINT_I").arg(2)); - GroupPoints->PushButton1->setIcon(image1); - GroupPoints->PushButton2->setIcon(image1); - + GroupPoints->PushButton1->setIcon(image0); + GroupPoints->PushButton2->setIcon(image0); GroupPoints->LineEdit1->setReadOnly(true); GroupPoints->LineEdit2->setReadOnly(true); + // wire + + GroupWire = new DlgRef_1Sel2Spin(centralWidget()); + GroupWire->GroupBox1->setTitle(tr("GEOM_WIRE")); + GroupWire->TextLabel1->setText(tr("GEOM_WIRE")); + GroupWire->PushButton1->setIcon(image0); + GroupWire->LineEdit1->setReadOnly(true); + GroupWire->TextLabel2->setText( tr( "GEOM_LINEAR_TOLERANCE" ) ); + GroupWire->TextLabel3->setText( tr( "GEOM_ANGULAR_TOLERANCE" ) ); + double SpecificStep = 0.0001; + double prec1 = Precision::Confusion(); + double prec2 = Precision::Angular(); + initSpinBox(GroupWire->SpinBox_DX, prec1, MAX_NUMBER, SpecificStep, "len_tol_precision" ); + initSpinBox(GroupWire->SpinBox_DY, prec2, MAX_NUMBER, SpecificStep, "ang_tol_precision" ); + GroupWire->SpinBox_DX->setValue(prec1); + GroupWire->SpinBox_DY->setValue(prec2); + + // layout + QVBoxLayout* layout = new QVBoxLayout(centralWidget()); layout->setMargin(0); layout->setSpacing(6); layout->addWidget(GroupPoints); + layout->addWidget(GroupWire); /***************************************************************/ setHelpFileName("create_edge_page.html"); - // Initialisation + // initialisation Init(); } @@ -98,28 +119,35 @@ BuildGUI_EdgeDlg::~BuildGUI_EdgeDlg() void BuildGUI_EdgeDlg::Init() { // init variables - GroupPoints->LineEdit1->setReadOnly(true); - GroupPoints->LineEdit2->setReadOnly(true); - - GroupPoints->LineEdit1->setText(""); - GroupPoints->LineEdit2->setText(""); - myPoint1 = myPoint2 = GEOM::GEOM_Object::_nil(); - myOkPoint1 = myOkPoint2 = false; + myPoint1 = myPoint2 = myWire = GEOM::GEOM_Object::_nil(); + myEditCurrentArgument = GroupPoints->LineEdit1; + GroupPoints->PushButton1->setDown(true); + globalSelection(); // close local contexts, if any + localSelection( GEOM::GEOM_Object::_nil(), TopAbs_VERTEX ); // signals and slots connections + connect( myGeomGUI, SIGNAL( SignalDeactivateActiveDialog() ), this, SLOT( DeactivateActiveDialog() ) ); + connect( myGeomGUI, SIGNAL( SignalCloseAllDialogs() ), this, SLOT( ClickOnCancel() ) ); + + connect( this, SIGNAL( constructorsClicked( int ) ), this, SLOT( ConstructorsClicked( int ) ) ); + connect(buttonOk(), SIGNAL(clicked()), this, SLOT(ClickOnOk())); connect(buttonApply(), SIGNAL(clicked()), this, SLOT(ClickOnApply())); connect(GroupPoints->PushButton1, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument())); connect(GroupPoints->PushButton2, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument())); + connect(GroupWire->PushButton1, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument())); connect(GroupPoints->LineEdit1, SIGNAL(returnPressed()), this, SLOT(LineEditReturnPressed())); connect(GroupPoints->LineEdit2, SIGNAL(returnPressed()), this, SLOT(LineEditReturnPressed())); + connect(GroupWire->LineEdit1, SIGNAL(returnPressed()), this, SLOT(LineEditReturnPressed())); + + connect( myGeomGUI->getApp()->selectionMgr(), SIGNAL( currentSelectionChanged() ), + this, SLOT( SelectionIntoArgument() ) ); initName(tr("GEOM_EDGE")); - GroupPoints->PushButton1->click(); - SelectionIntoArgument(); + ConstructorsClicked( 0 ); } //================================================================================= @@ -142,11 +170,60 @@ bool BuildGUI_EdgeDlg::ClickOnApply() return false; initName(); - // activate selection and connect selection manager - GroupPoints->PushButton1->click(); + + myEditCurrentArgument->setText( "" ); + ConstructorsClicked( getConstructorId() ); + return true; } +//================================================================================= +// function : ConstructorsClicked() +// purpose : Radio button management +//================================================================================= +void BuildGUI_EdgeDlg::ConstructorsClicked( int constructorId ) +{ + switch ( constructorId ) { + case 0: + { + globalSelection(); // close local contexts, if any + localSelection( GEOM::GEOM_Object::_nil(), TopAbs_VERTEX ); + + myEditCurrentArgument = GroupPoints->LineEdit1; + GroupPoints->LineEdit1->setText( "" ); + GroupPoints->LineEdit2->setText( "" ); + myPoint1 = GEOM::GEOM_Object::_nil(); + myPoint2 = GEOM::GEOM_Object::_nil(); + GroupPoints->PushButton1->setDown(true); + GroupPoints->PushButton2->setDown(false); + GroupPoints->LineEdit1->setEnabled(true); + GroupPoints->LineEdit2->setEnabled(false); + GroupPoints->show(); + GroupWire->hide(); + break; + } + case 1: + { + globalSelection(); // close local contexts, if any + localSelection( GEOM::GEOM_Object::_nil(), TopAbs_WIRE ); + + myEditCurrentArgument = GroupWire->LineEdit1; + GroupWire->LineEdit1->setText(""); + myWire = GEOM::GEOM_Object::_nil(); + GroupWire->PushButton1->setDown(true); + GroupWire->LineEdit1->setEnabled(true); + GroupPoints->hide(); + GroupWire->show(); + break; + } + } + + qApp->processEvents(); + updateGeometry(); + resize( minimumSizeHint() ); + SelectionIntoArgument(); +} + //================================================================================= // function : SelectionIntoArgument() // purpose : Called when selection is changed or on dialog initialization or activation @@ -161,38 +238,67 @@ void BuildGUI_EdgeDlg::SelectionIntoArgument() aSelMgr->selectedObjects(aSelList); if (aSelList.Extent() != 1) { - if (myEditCurrentArgument == GroupPoints->LineEdit1) - myOkPoint1 = false; - else if (myEditCurrentArgument == GroupPoints->LineEdit2) - myOkPoint2 = false; + if (myEditCurrentArgument == GroupPoints->LineEdit1) myPoint1 = GEOM::GEOM_Object::_nil(); + else if (myEditCurrentArgument == GroupPoints->LineEdit2) myPoint2 = GEOM::GEOM_Object::_nil(); + else if (myEditCurrentArgument == GroupWire->LineEdit1) myWire = GEOM::GEOM_Object::_nil(); + displayPreview(); return; } // nbSel == 1 Standard_Boolean testResult = Standard_False; GEOM::GEOM_Object_var aSelectedObject = GEOMBase::ConvertIOinGEOMObject(aSelList.First(), testResult); - if (!testResult || aSelectedObject->_is_nil()) - return; - myEditCurrentArgument->setText(GEOMBase::GetName(aSelectedObject)); + if ( testResult && !aSelectedObject->_is_nil() ) { + QString aName = GEOMBase::GetName( aSelectedObject ); + TopAbs_ShapeEnum aNeedType = myEditCurrentArgument == GroupWire->LineEdit1 ? TopAbs_WIRE : TopAbs_VERTEX; - // clear selection - disconnect(myGeomGUI->getApp()->selectionMgr(), 0, this, 0); - myGeomGUI->getApp()->selectionMgr()->clearSelected(); - connect(myGeomGUI->getApp()->selectionMgr(), SIGNAL(currentSelectionChanged()), - this, SLOT(SelectionIntoArgument())); + TopoDS_Shape aShape; + if ( GEOMBase::GetShape( aSelectedObject, aShape, TopAbs_SHAPE ) && !aShape.IsNull() ) { + TColStd_IndexedMapOfInteger aMap; + aSelMgr->GetIndexes( aSelList.First(), aMap ); + if ( aMap.Extent() == 1 ) { // Local Selection + int anIndex = aMap( 1 ); + aName += ( aNeedType == TopAbs_WIRE ? QString( ":wire_%1" ).arg( anIndex ) : QString( ":vertex_%1" ).arg( anIndex ) ); - if (myEditCurrentArgument == GroupPoints->LineEdit1) { - myPoint1 = aSelectedObject; - myOkPoint1 = true; - if (!myOkPoint2) - GroupPoints->PushButton2->click(); - } - else if (myEditCurrentArgument == GroupPoints->LineEdit2) { - myPoint2 = aSelectedObject; - myOkPoint2 = true; - if (!myOkPoint1) - GroupPoints->PushButton1->click(); + //Find SubShape Object in Father + GEOM::GEOM_Object_var aFindedObject = GEOMBase_Helper::findObjectInFather( aSelectedObject, aName ); + if ( CORBA::is_nil( aFindedObject ) ) { // Object not found in study + GEOM::GEOM_IShapesOperations_var aShapesOp = getGeomEngine()->GetIShapesOperations( getStudyId() ); + aSelectedObject = aShapesOp->GetSubShape( aSelectedObject, anIndex ); + } + else { + aSelectedObject = aFindedObject; // get Object from study + } + } + else { // Global Selection + if ( aShape.ShapeType() != aNeedType ) { + aSelectedObject = GEOM::GEOM_Object::_nil(); + aName = ""; + } + } + } + + myEditCurrentArgument->setText( aName ); + + if (!aSelectedObject->_is_nil()) { // clear selection if something selected + globalSelection(); + localSelection( GEOM::GEOM_Object::_nil(), aNeedType ); + } + + if ( myEditCurrentArgument == GroupPoints->LineEdit1 ) { + myPoint1 = aSelectedObject; + if ( !myPoint1->_is_nil() && myPoint2->_is_nil() ) + GroupPoints->PushButton2->click(); + } + else if ( myEditCurrentArgument == GroupPoints->LineEdit2 ) { + myPoint2 = aSelectedObject; + if ( !myPoint2->_is_nil() && myPoint1->_is_nil() ) + GroupPoints->PushButton1->click(); + } + else if ( myEditCurrentArgument == GroupWire->LineEdit1 ) { + myWire = aSelectedObject; + } } displayPreview(); @@ -205,7 +311,6 @@ void BuildGUI_EdgeDlg::SelectionIntoArgument() void BuildGUI_EdgeDlg::SetEditCurrentArgument() { QPushButton* send = (QPushButton*)sender(); - //globalSelection();//?? if (send == GroupPoints->PushButton1) { myEditCurrentArgument = GroupPoints->LineEdit1; @@ -217,19 +322,14 @@ void BuildGUI_EdgeDlg::SetEditCurrentArgument() GroupPoints->PushButton1->setDown(false); GroupPoints->LineEdit1->setEnabled(false); } + else if (send == GroupWire->PushButton1) { + myEditCurrentArgument = GroupWire->LineEdit1; + } // enable line edit myEditCurrentArgument->setEnabled(true); myEditCurrentArgument->setFocus(); - // after setFocus(), because it will be setDown(false) when loses focus send->setDown(true); - - disconnect(myGeomGUI->getApp()->selectionMgr(), 0, this, 0); - globalSelection(GEOM_POINT); - connect(myGeomGUI->getApp()->selectionMgr(), SIGNAL(currentSelectionChanged()), - this, SLOT(SelectionIntoArgument())); - - // seems we need it only to avoid preview disappearing, caused by selection mode change displayPreview(); } @@ -240,7 +340,7 @@ void BuildGUI_EdgeDlg::SetEditCurrentArgument() void BuildGUI_EdgeDlg::LineEditReturnPressed() { QLineEdit* send = (QLineEdit*)sender(); - if (send == GroupPoints->LineEdit1 || send == GroupPoints->LineEdit2) { + if (send == GroupPoints->LineEdit1 || send == GroupPoints->LineEdit2 || send == GroupWire->LineEdit1 ) { myEditCurrentArgument = send; GEOMBase_Skeleton::LineEditReturnPressed(); } @@ -257,7 +357,7 @@ void BuildGUI_EdgeDlg::ActivateThisDialog() connect( myGeomGUI->getApp()->selectionMgr(), SIGNAL( currentSelectionChanged() ), this, SLOT( SelectionIntoArgument() ) ); - displayPreview(); + ConstructorsClicked( getConstructorId() ); } //================================================================================= @@ -283,9 +383,18 @@ GEOM::GEOM_IOperations_ptr BuildGUI_EdgeDlg::createOperation() // function : isValid // purpose : //================================================================================= -bool BuildGUI_EdgeDlg::isValid (QString&) +bool BuildGUI_EdgeDlg::isValid (QString& msg) { - return myOkPoint1 && myOkPoint2; + bool ok = false; + if ( getConstructorId() == 0 ) { + ok = !myPoint1->_is_nil() && !myPoint2->_is_nil(); + } + else { + ok = !myWire->_is_nil(); + ok = ok && GroupWire->SpinBox_DX->isValid( msg, !IsPreview() ); + ok = ok && GroupWire->SpinBox_DY->isValid( msg, !IsPreview() ); + } + return ok; } //================================================================================= @@ -294,11 +403,57 @@ bool BuildGUI_EdgeDlg::isValid (QString&) //================================================================================= bool BuildGUI_EdgeDlg::execute (ObjectList& objects) { + bool res = false; + GEOM::GEOM_Object_var anObj; + GEOM::GEOM_IShapesOperations_var anOper = GEOM::GEOM_IShapesOperations::_narrow( getOperation() ); - GEOM::GEOM_Object_var anObj = anOper->MakeEdge(myPoint1, myPoint2); - if (!anObj->_is_nil()) - objects.push_back(anObj._retn()); + switch ( getConstructorId() ) { + case 0 : + { + anObj = anOper->MakeEdge( myPoint1, myPoint2 ); + res = true; + break; + } + case 1: + { + double aLinearTolerance = GroupWire->SpinBox_DX->value(); + double anAngularTolerance = GroupWire->SpinBox_DY->value(); + + QStringList aParameters; + aParameters << GroupWire->SpinBox_DX->text(); + aParameters << GroupWire->SpinBox_DY->text(); + + anObj = anOper->MakeEdgeWire( myWire, aLinearTolerance, anAngularTolerance ); + + if ( !anObj->_is_nil() && !IsPreview() ) + anObj->SetParameters( aParameters.join(":").toLatin1().constData() ); + + res = true; + break; + } + } - return true; + if ( !anObj->_is_nil() ) objects.push_back( anObj._retn() ); + + return res; +} + +//================================================================================= +// function : addSubshapeToStudy +// purpose : virtual method to add new SubObjects if local selection +//================================================================================= +void BuildGUI_EdgeDlg::addSubshapesToStudy() +{ + QMap objMap; + switch ( getConstructorId() ) { + case 0 : + objMap[GroupPoints->LineEdit1->text()] = myPoint1; + objMap[GroupPoints->LineEdit2->text()] = myPoint2; + break; + case 1 : + objMap[GroupWire->LineEdit1->text()] = myWire; + break; + } + addSubshapesToFather( objMap ); } diff --git a/src/BuildGUI/BuildGUI_EdgeDlg.h b/src/BuildGUI/BuildGUI_EdgeDlg.h index 1f95ea865..f6e09236f 100644 --- a/src/BuildGUI/BuildGUI_EdgeDlg.h +++ b/src/BuildGUI/BuildGUI_EdgeDlg.h @@ -29,6 +29,7 @@ #include +class DlgRef_1Sel2Spin; class DlgRef_2Sel; //================================================================================= @@ -48,19 +49,21 @@ protected: virtual GEOM::GEOM_IOperations_ptr createOperation(); virtual bool isValid( QString& ); virtual bool execute( ObjectList& ); + virtual void addSubshapesToStudy(); private: void Init(); void enterEvent( QEvent* ); private: - GEOM::GEOM_Object_var myPoint1, myPoint2; /* Points containing the edge */ - bool myOkPoint1; /* true when myPoint is defined */ - bool myOkPoint2; + GEOM::GEOM_Object_var myPoint1, myPoint2; /* Points containing the edge */ + GEOM::GEOM_Object_var myWire; /* Wire */ DlgRef_2Sel* GroupPoints; + DlgRef_1Sel2Spin* GroupWire; private slots: + void ConstructorsClicked( int ); void ClickOnOk(); bool ClickOnApply(); void ActivateThisDialog(); diff --git a/src/GEOMGUI/GEOM_images.ts b/src/GEOMGUI/GEOM_images.ts index e41de1d95..e0dd7d86c 100644 --- a/src/GEOMGUI/GEOM_images.ts +++ b/src/GEOMGUI/GEOM_images.ts @@ -109,6 +109,10 @@ ICON_DLG_BUILD_EDGE build_edge.png + + ICON_DLG_BUILD_EDGE_WIRE + build_edge_wire.png + ICON_DLG_BUILD_FACE build_face.png diff --git a/src/GEOMGUI/GEOM_msg_en.ts b/src/GEOMGUI/GEOM_msg_en.ts index 01b728a30..e0324cbe8 100644 --- a/src/GEOMGUI/GEOM_msg_en.ts +++ b/src/GEOMGUI/GEOM_msg_en.ts @@ -1821,6 +1821,14 @@ Please, select face, shell or solid and try again GEOM_TOLERANCE Tolerance + + GEOM_LINEAR_TOLERANCE + Linear Tolerance + + + GEOM_ANGULAR_TOLERANCE + Angular Tolerance + GEOM_TOLERANCE_CONSTR Object And Its Tolerances diff --git a/src/GEOMImpl/GEOMImpl_IShapes.hxx b/src/GEOMImpl/GEOMImpl_IShapes.hxx index cd8dbe705..dcdb59265 100644 --- a/src/GEOMImpl/GEOMImpl_IShapes.hxx +++ b/src/GEOMImpl/GEOMImpl_IShapes.hxx @@ -38,7 +38,8 @@ class GEOMImpl_IShapes SHAPE_ARG_PLANAR = 3, // for Face SHAPE_ARG_SUBTYPE = 4, // for Sub-shape SHAPE_ARG_INDICES = 5, // for Sub-shape - SHAPE_ARG_TOLERANCE = 6 // for Wire + SHAPE_ARG_TOLERANCE = 6, // linear tolerance (for Wire, Edge) + SHAPE_ARG_ANGLE_TOL = 7, // angular tolerance (for Edge) }; GEOMImpl_IShapes(Handle(GEOM_Function) theFunction): _func(theFunction) {} @@ -75,6 +76,11 @@ class GEOMImpl_IShapes Standard_Real GetTolerance() { return _func->GetReal(SHAPE_ARG_TOLERANCE); } + void SetAngularTolerance(const Standard_Real theValue) + { _func->SetReal(SHAPE_ARG_ANGLE_TOL, theValue); } + + Standard_Real GetAngularTolerance() { return _func->GetReal(SHAPE_ARG_ANGLE_TOL); } + private: Handle(GEOM_Function) _func; diff --git a/src/GEOMImpl/GEOMImpl_IShapesOperations.cxx b/src/GEOMImpl/GEOMImpl_IShapesOperations.cxx index 93eb4535e..851186aba 100644 --- a/src/GEOMImpl/GEOMImpl_IShapesOperations.cxx +++ b/src/GEOMImpl/GEOMImpl_IShapesOperations.cxx @@ -210,6 +210,77 @@ Handle(GEOM_Object) GEOMImpl_IShapesOperations::MakeEdge return anEdge; } +//============================================================================= +/*! + * MakeEdgeWire + */ +//============================================================================= +Handle(GEOM_Object) GEOMImpl_IShapesOperations::MakeEdgeWire + (Handle(GEOM_Object) theWire, + const Standard_Real theLinearTolerance, + const Standard_Real theAngularTolerance) +{ + SetErrorCode(KO); + + if (theWire.IsNull()) return NULL; + + //Add a new Edge object + Handle(GEOM_Object) anEdge = GetEngine()->AddObject(GetDocID(), GEOM_EDGE); + + //Add a new Vector function + Handle(GEOM_Function) aFunction = + anEdge->AddFunction(GEOMImpl_ShapeDriver::GetID(), EDGE_WIRE); + + //Check if the function is set correctly + if (aFunction->GetDriverGUID() != GEOMImpl_ShapeDriver::GetID()) return NULL; + + GEOMImpl_IShapes aCI (aFunction); + + Handle(GEOM_Function) aWire = theWire->GetLastFunction(); + + if (aWire.IsNull()) return NULL; + + aCI.SetBase(aWire); + aCI.SetTolerance(theLinearTolerance); + aCI.SetAngularTolerance(theAngularTolerance); + + //Compute the Edge value + try { +#if (OCC_VERSION_MAJOR << 16 | OCC_VERSION_MINOR << 8 | OCC_VERSION_MAINTENANCE) > 0x060100 + OCC_CATCH_SIGNALS; +#endif + if (!GetSolver()->ComputeFunction(aFunction)) { + SetErrorCode("Shape driver failed"); + return NULL; + } + } + catch (Standard_Failure) { + Handle(Standard_Failure) aFail = Standard_Failure::Caught(); + SetErrorCode(aFail->GetMessageString()); + return NULL; + } + + const double DEF_LIN_TOL = Precision::Confusion(); + const double DEF_ANG_TOL = Precision::Angular(); + //Make a Python command + if ( theAngularTolerance == DEF_ANG_TOL ) { + if ( theLinearTolerance == DEF_LIN_TOL ) + GEOM::TPythonDump(aFunction) << anEdge << " = geompy.MakeEdgeWire(" + << theWire << ")"; + else + GEOM::TPythonDump(aFunction) << anEdge << " = geompy.MakeEdgeWire(" + << theWire << ", " << theLinearTolerance << ")"; + } + else { + GEOM::TPythonDump(aFunction) << anEdge << " = geompy.MakeEdgeWire(" + << theWire << ", " << theLinearTolerance << ", " + << theAngularTolerance << ")"; + } + + SetErrorCode(OK); + return anEdge; +} + //============================================================================= /*! * MakeWire diff --git a/src/GEOMImpl/GEOMImpl_IShapesOperations.hxx b/src/GEOMImpl/GEOMImpl_IShapesOperations.hxx index 23dbccb53..b097ef81e 100644 --- a/src/GEOMImpl/GEOMImpl_IShapesOperations.hxx +++ b/src/GEOMImpl/GEOMImpl_IShapesOperations.hxx @@ -55,7 +55,10 @@ class GEOMImpl_IShapesOperations : public GEOM_IOperations Standard_EXPORT ~GEOMImpl_IShapesOperations(); Standard_EXPORT Handle(GEOM_Object) MakeEdge (Handle(GEOM_Object) thePoint1, - Handle(GEOM_Object) thePoint2); + Handle(GEOM_Object) thePoint2); + Standard_EXPORT Handle(GEOM_Object) MakeEdgeWire (Handle(GEOM_Object) theWire, + const Standard_Real theLinearTolerance, + const Standard_Real theAngularTolerance); Standard_EXPORT Handle(GEOM_Object) MakeWire (std::list theEdgesAndWires, const Standard_Real theTolerance); diff --git a/src/GEOMImpl/GEOMImpl_ShapeDriver.cxx b/src/GEOMImpl/GEOMImpl_ShapeDriver.cxx index 6990682cf..54d149b3a 100644 --- a/src/GEOMImpl/GEOMImpl_ShapeDriver.cxx +++ b/src/GEOMImpl/GEOMImpl_ShapeDriver.cxx @@ -31,6 +31,7 @@ // OCCT Includes #include #include +#include #include #include @@ -43,8 +44,13 @@ #include #include #include +#include +#include +#include +#include #include +#include #include #include @@ -61,7 +67,18 @@ #include #include +#include #include +#include +#include +#include +#include + +#include +#include +#include +#include +#include #include #include @@ -441,6 +458,342 @@ Standard_Integer GEOMImpl_ShapeDriver::Execute(TFunction_Logbook& log) const aShape = tds; } } + else if (aType == EDGE_WIRE) { + Handle(GEOM_Function) aRefBase = aCI.GetBase(); + TopoDS_Shape aWire = aRefBase->GetValue(); + Standard_Real LinTol = aCI.GetTolerance(); + Standard_Real AngTol = aCI.GetAngularTolerance(); + if (aWire.IsNull()) Standard_NullObject::Raise("Argument Wire is null"); + + TopoDS_Edge ResEdge; + + BRepLib::BuildCurves3d(aWire); + Handle(ShapeFix_Shape) Fixer = new ShapeFix_Shape(aWire); + Fixer->SetPrecision(LinTol); + Fixer->SetMaxTolerance(LinTol); + Fixer->Perform(); + TopoDS_Wire theWire = TopoDS::Wire(Fixer->Shape()); + + TColGeom_SequenceOfCurve CurveSeq; + TopTools_SequenceOfShape LocSeq; + TColStd_SequenceOfReal FparSeq; + TColStd_SequenceOfReal LparSeq; + TColStd_SequenceOfReal TolSeq; + GeomAbs_CurveType CurType; + TopoDS_Vertex FirstVertex, LastVertex; + + BRepTools_WireExplorer wexp(theWire) ; + for (; wexp.More(); wexp.Next()) + { + TopoDS_Edge anEdge = wexp.Current(); + Standard_Real fpar, lpar; + TopLoc_Location aLoc; + Handle(Geom_Curve) aCurve = BRep_Tool::Curve(anEdge, aLoc, fpar, lpar); + if (aCurve.IsNull()) + continue; + + BRepAdaptor_Curve BAcurve(anEdge); + GeomAbs_CurveType aType = BAcurve.GetType(); + + Handle(Geom_Curve) aBasisCurve = BAcurve.Curve().Curve(); + + if (aBasisCurve->IsPeriodic()) + ElCLib::AdjustPeriodic(aBasisCurve->FirstParameter(), aBasisCurve->LastParameter(), + Precision::PConfusion(), fpar, lpar); + + if (CurveSeq.IsEmpty()) + { + CurveSeq.Append(aCurve); + TopoDS_Shape aLocShape; + aLocShape.Location(aLoc); + aLocShape.Orientation(wexp.Orientation()); + LocSeq.Append(aLocShape); + FparSeq.Append(fpar); + LparSeq.Append(lpar); + CurType = aType; + FirstVertex = wexp.CurrentVertex(); + } + else + { + Standard_Boolean Done = Standard_False; + Standard_Real NewFpar, NewLpar; + GeomAdaptor_Curve GAprevcurve(CurveSeq.Last()); + TopoDS_Vertex CurVertex = wexp.CurrentVertex(); + TopoDS_Vertex CurFirstVer = TopExp::FirstVertex(anEdge); + TopAbs_Orientation ConnectByOrigin = (CurVertex.IsSame(CurFirstVer))? TopAbs_FORWARD : TopAbs_REVERSED; + if (aCurve == CurveSeq.Last()) + { + NewFpar = fpar; + NewLpar = lpar; + if (aBasisCurve->IsPeriodic()) + { + if (NewLpar < NewFpar) + NewLpar += aBasisCurve->Period(); + if (ConnectByOrigin == TopAbs_FORWARD) + ElCLib::AdjustPeriodic(FparSeq.Last(), + FparSeq.Last() + aBasisCurve->Period(), + Precision::PConfusion(), NewFpar, NewLpar); + else + ElCLib::AdjustPeriodic(FparSeq.Last() - aBasisCurve->Period(), + FparSeq.Last(), + Precision::PConfusion(), NewFpar, NewLpar); + } + Done = Standard_True; + } + else if (aType == CurType && + aType != GeomAbs_BezierCurve && + aType != GeomAbs_BSplineCurve && + aType != GeomAbs_OtherCurve) + { + switch (aType) + { + case GeomAbs_Line: + { + gp_Lin aLine = BAcurve.Line(); + gp_Lin PrevLine = GAprevcurve.Line(); + if (aLine.Contains(PrevLine.Location(), LinTol) && + aLine.Direction().IsParallel(PrevLine.Direction(), AngTol)) + { + gp_Pnt P1 = ElCLib::Value(fpar, aLine); + gp_Pnt P2 = ElCLib::Value(lpar, aLine); + NewFpar = ElCLib::Parameter(PrevLine, P1); + NewLpar = ElCLib::Parameter(PrevLine, P2); + if (NewLpar < NewFpar) + { + Standard_Real MemNewFpar = NewFpar; + NewFpar = NewLpar; + NewLpar = MemNewFpar; + ConnectByOrigin = TopAbs::Reverse(ConnectByOrigin); + } + Done = Standard_True; + } + break; + } + case GeomAbs_Circle: + { + gp_Circ aCircle = BAcurve.Circle(); + gp_Circ PrevCircle = GAprevcurve.Circle(); + if (aCircle.Location().Distance(PrevCircle.Location()) <= LinTol && + Abs(aCircle.Radius() - PrevCircle.Radius()) <= LinTol && + aCircle.Axis().IsParallel(PrevCircle.Axis(), AngTol)) + { + if (aCircle.Axis().Direction() * PrevCircle.Axis().Direction() < 0.) + { + Standard_Real memfpar = fpar; + fpar = lpar; + lpar = memfpar; + ConnectByOrigin = TopAbs::Reverse(ConnectByOrigin); + } + gp_Pnt P1 = ElCLib::Value(fpar, aCircle); + gp_Pnt P2 = ElCLib::Value(lpar, aCircle); + NewFpar = ElCLib::Parameter(PrevCircle, P1); + NewLpar = ElCLib::Parameter(PrevCircle, P2); + if (NewLpar < NewFpar) + NewLpar += 2.*PI; + //Standard_Real MemNewFpar = NewFpar, MemNewLpar = NewLpar; + if (ConnectByOrigin == TopAbs_FORWARD) + ElCLib::AdjustPeriodic(FparSeq.Last(), + FparSeq.Last() + 2.*PI, + Precision::PConfusion(), NewFpar, NewLpar); + else + ElCLib::AdjustPeriodic(FparSeq.Last() - 2.*PI, + FparSeq.Last(), + Precision::PConfusion(), NewFpar, NewLpar); + Done = Standard_True; + } + break; + } + case GeomAbs_Ellipse: + { + gp_Elips anEllipse = BAcurve.Ellipse(); + gp_Elips PrevEllipse = GAprevcurve.Ellipse(); + if (anEllipse.Focus1().Distance(PrevEllipse.Focus1()) <= LinTol && + anEllipse.Focus2().Distance(PrevEllipse.Focus2()) <= LinTol && + Abs(anEllipse.MajorRadius() - PrevEllipse.MajorRadius()) <= LinTol && + Abs(anEllipse.MinorRadius() - PrevEllipse.MinorRadius()) <= LinTol && + anEllipse.Axis().IsParallel(PrevEllipse.Axis(), AngTol)) + { + if (anEllipse.Axis().Direction() * PrevEllipse.Axis().Direction() < 0.) + { + Standard_Real memfpar = fpar; + fpar = lpar; + lpar = memfpar; + ConnectByOrigin = TopAbs::Reverse(ConnectByOrigin); + } + gp_Pnt P1 = ElCLib::Value(fpar, anEllipse); + gp_Pnt P2 = ElCLib::Value(lpar, anEllipse); + NewFpar = ElCLib::Parameter(PrevEllipse, P1); + NewLpar = ElCLib::Parameter(PrevEllipse, P2); + if (NewLpar < NewFpar) + NewLpar += 2.*PI; + if (ConnectByOrigin == TopAbs_FORWARD) + ElCLib::AdjustPeriodic(FparSeq.Last(), + FparSeq.Last() + 2.*PI, + Precision::PConfusion(), NewFpar, NewLpar); + else + ElCLib::AdjustPeriodic(FparSeq.Last() - 2.*PI, + FparSeq.Last(), + Precision::PConfusion(), NewFpar, NewLpar); + Done = Standard_True; + } + break; + } + case GeomAbs_Hyperbola: + { + gp_Hypr aHypr = BAcurve.Hyperbola(); + gp_Hypr PrevHypr = GAprevcurve.Hyperbola(); + if (aHypr.Focus1().Distance(PrevHypr.Focus1()) <= LinTol && + aHypr.Focus2().Distance(PrevHypr.Focus2()) <= LinTol && + Abs(aHypr.MajorRadius() - PrevHypr.MajorRadius()) <= LinTol && + Abs(aHypr.MinorRadius() - PrevHypr.MinorRadius()) <= LinTol && + aHypr.Axis().IsParallel(PrevHypr.Axis(), AngTol)) + { + gp_Pnt P1 = ElCLib::Value(fpar, aHypr); + gp_Pnt P2 = ElCLib::Value(lpar, aHypr); + NewFpar = ElCLib::Parameter(PrevHypr, P1); + NewLpar = ElCLib::Parameter(PrevHypr, P2); + if (NewLpar < NewFpar) + { + Standard_Real MemNewFpar = NewFpar; + NewFpar = NewLpar; + NewLpar = MemNewFpar; + ConnectByOrigin = TopAbs::Reverse(ConnectByOrigin); + } + Done = Standard_True; + } + break; + } + case GeomAbs_Parabola: + { + gp_Parab aParab = BAcurve.Parabola(); + gp_Parab PrevParab = GAprevcurve.Parabola(); + if (aParab.Location().Distance(PrevParab.Location()) <= LinTol && + aParab.Focus().Distance(PrevParab.Focus()) <= LinTol && + Abs(aParab.Focal() - PrevParab.Focal()) <= LinTol && + aParab.Axis().IsParallel(PrevParab.Axis(), AngTol)) + { + gp_Pnt P1 = ElCLib::Value(fpar, aParab); + gp_Pnt P2 = ElCLib::Value(lpar, aParab); + NewFpar = ElCLib::Parameter(PrevParab, P1); + NewLpar = ElCLib::Parameter(PrevParab, P2); + if (NewLpar < NewFpar) + { + Standard_Real MemNewFpar = NewFpar; + NewFpar = NewLpar; + NewLpar = MemNewFpar; + ConnectByOrigin = TopAbs::Reverse(ConnectByOrigin); + } + Done = Standard_True; + } + break; + } + } //end of switch (aType) + } // end of else if (aType == CurType && ... + if (Done) + { + if (NewFpar < FparSeq.Last()) + FparSeq(FparSeq.Length()) = NewFpar; + else + LparSeq(LparSeq.Length()) = NewLpar; + } + else + { + CurveSeq.Append(aCurve); + TopoDS_Shape aLocShape; + aLocShape.Location(aLoc); + aLocShape.Orientation(wexp.Orientation()); + LocSeq.Append(aLocShape); + FparSeq.Append(fpar); + LparSeq.Append(lpar); + TolSeq.Append(BRep_Tool::Tolerance(CurVertex)); + CurType = aType; + } + } // end of else (CurveSeq.IsEmpty()) -> not first time + } // end for (; wexp.More(); wexp.Next()) + + LastVertex = wexp.CurrentVertex(); + TolSeq.Append(BRep_Tool::Tolerance(LastVertex)); + + if (!CurveSeq.IsEmpty()) + { + Standard_Integer nb_curve = CurveSeq.Length(); //number of curves + TColGeom_Array1OfBSplineCurve tab(0,nb_curve-1); //array of the curves + TColStd_Array1OfReal tabtolvertex(0,nb_curve-1); //(0,nb_curve-2); //array of the tolerances + + Standard_Integer i; + + if (nb_curve > 1) + { + for (i = 1; i <= nb_curve; i++) + { + if (CurveSeq(i)->IsInstance(STANDARD_TYPE(Geom_TrimmedCurve))) + CurveSeq(i) = (*((Handle(Geom_TrimmedCurve)*)&(CurveSeq(i))))->BasisCurve(); + + Handle(Geom_TrimmedCurve) aTrCurve = new Geom_TrimmedCurve(CurveSeq(i), FparSeq(i), LparSeq(i)); + tab(i-1) = GeomConvert::CurveToBSplineCurve(aTrCurve); + tab(i-1)->Transform(LocSeq(i).Location().Transformation()); + GeomConvert::C0BSplineToC1BSplineCurve(tab(i-1), Precision::Confusion()); + if (LocSeq(i).Orientation() == TopAbs_REVERSED) + tab(i-1)->Reverse(); + + //Temporary + //char* name = new char[100]; + //sprintf(name, "c%d", i); + //DrawTrSurf::Set(name, tab(i-1)); + + if (i > 1) + tabtolvertex(i-2) = TolSeq(i-1); + } // end for (i = 1; i <= nb_curve; i++) + tabtolvertex(nb_curve-1) = TolSeq(TolSeq.Length()); + + Standard_Boolean closed_flag = Standard_False; + Standard_Real closed_tolerance = 0.; + if (FirstVertex.IsSame(LastVertex) && + GeomLProp::Continuity(tab(0), tab(nb_curve-1), + tab(0)->FirstParameter(), + tab(nb_curve-1)->LastParameter(), + Standard_False, Standard_False, LinTol, AngTol) >= GeomAbs_G1) + { + closed_flag = Standard_True ; + closed_tolerance = BRep_Tool::Tolerance(FirstVertex); + } + + Handle(TColGeom_HArray1OfBSplineCurve) concatcurve; //array of the concatenated curves + Handle(TColStd_HArray1OfInteger) ArrayOfIndices; //array of the remining Vertex + GeomConvert::ConcatC1(tab, + tabtolvertex, + ArrayOfIndices, + concatcurve, + closed_flag, + closed_tolerance); //C1 concatenation + + if (concatcurve->Length() > 1) + { + GeomConvert_CompCurveToBSplineCurve Concat(concatcurve->Value(concatcurve->Lower())); + + for (i = concatcurve->Lower()+1; i <= concatcurve->Upper(); i++) + Concat.Add( concatcurve->Value(i), LinTol, Standard_True ); + + concatcurve->SetValue(concatcurve->Lower(), Concat.BSplineCurve()); + } + + ResEdge = BRepLib_MakeEdge(concatcurve->Value(concatcurve->Lower()), + FirstVertex, LastVertex); + } + else + { + if (CurveSeq(1)->IsInstance(STANDARD_TYPE(Geom_TrimmedCurve))) + CurveSeq(1) = (*((Handle(Geom_TrimmedCurve)*)&(CurveSeq(i))))->BasisCurve(); + + CurveSeq(1)->Transform(LocSeq(1).Location().Transformation()); + ResEdge = BRepLib_MakeEdge(CurveSeq(1), + FirstVertex, LastVertex, + FparSeq(1), LparSeq(1)); + } + } + + aShape = ResEdge; + } if (aShape.IsNull()) return 0; diff --git a/src/GEOMImpl/GEOMImpl_Types.hxx b/src/GEOMImpl/GEOMImpl_Types.hxx index d1dcbe274..b954ec438 100755 --- a/src/GEOMImpl/GEOMImpl_Types.hxx +++ b/src/GEOMImpl/GEOMImpl_Types.hxx @@ -257,6 +257,7 @@ #define SUBSHAPE_NOT_SORTED 8 #define FACE_WIRES 9 #define REVERSE_ORIENTATION 10 +#define EDGE_WIRE 11 #define ARCHIMEDE_TYPE 1 diff --git a/src/GEOM_I/GEOM_IShapesOperations_i.cc b/src/GEOM_I/GEOM_IShapesOperations_i.cc index 07c9943a9..310111aaa 100644 --- a/src/GEOM_I/GEOM_IShapesOperations_i.cc +++ b/src/GEOM_I/GEOM_IShapesOperations_i.cc @@ -85,6 +85,34 @@ GEOM::GEOM_Object_ptr GEOM_IShapesOperations_i::MakeEdge return GetObject(anObject); } +//============================================================================= +/*! + * MakeEdgeWire + */ +//============================================================================= +GEOM::GEOM_Object_ptr GEOM_IShapesOperations_i::MakeEdgeWire + (GEOM::GEOM_Object_ptr theWire, + const CORBA::Double theLinearTolerance, + const CORBA::Double theAngularTolerance) +{ + GEOM::GEOM_Object_var aGEOMObject; + + //Set a not done flag + GetOperations()->SetNotDone(); + + //Get the source wire + Handle(GEOM_Object) aWire = GetObjectImpl(theWire); + + if (aWire.IsNull()) return aGEOMObject._retn(); + + //Create the Edge + Handle(GEOM_Object) anObject = GetOperations()->MakeEdgeWire(aWire, theLinearTolerance, theAngularTolerance); + if (!GetOperations()->IsDone() || anObject.IsNull()) + return aGEOMObject._retn(); + + return GetObject(anObject); +} + //============================================================================= /*! * MakeWire diff --git a/src/GEOM_I/GEOM_IShapesOperations_i.hh b/src/GEOM_I/GEOM_IShapesOperations_i.hh index fdc3e4ba0..54752caf2 100644 --- a/src/GEOM_I/GEOM_IShapesOperations_i.hh +++ b/src/GEOM_I/GEOM_IShapesOperations_i.hh @@ -44,6 +44,9 @@ class GEOM_I_EXPORT GEOM_IShapesOperations_i : GEOM::GEOM_Object_ptr MakeEdge (GEOM::GEOM_Object_ptr thePnt1, GEOM::GEOM_Object_ptr thePnt2); + GEOM::GEOM_Object_ptr MakeEdgeWire (GEOM::GEOM_Object_ptr theWire, + const CORBA::Double theLinearTolerance, + const CORBA::Double theAngularTolerance); GEOM::GEOM_Object_ptr MakeWire (const GEOM::ListOfGO& theEdgesAndWires, const CORBA::Double theTolerance); diff --git a/src/GEOM_SWIG/geompyDC.py b/src/GEOM_SWIG/geompyDC.py index 954896f5e..a9d9babb0 100644 --- a/src/GEOM_SWIG/geompyDC.py +++ b/src/GEOM_SWIG/geompyDC.py @@ -1551,6 +1551,19 @@ class geompyDC(GEOM._objref_GEOM_Gen): RaiseIfFailed("MakeEdge", self.ShapesOp) return anObj + ## Create an edge from specified wire. + # @param theWire source Wire. + # @param theLinearTolerance linear tolerance value. + # @param theAngularTolerance angular tolerance value. + # @return New GEOM_Object, containing the created edge. + # + # @ref tui_creation_edge "Example" + def MakeEdgeWire(self, theWire, theLinearTolerance = 1e-07, theAngularTolerance = 1e-12): + # Example: see GEOM_TestAll.py + anObj = self.ShapesOp.MakeEdgeWire(theWire, theLinearTolerance, theAngularTolerance) + RaiseIfFailed("MakeEdgeWire", self.ShapesOp) + return anObj + ## Create a wire from the set of edges and wires. # @param theEdgesAndWires List of edges and/or wires. # @param theTolerance Maximum distance between vertices, that will be merged.