From 53daed0dad3c355da2b2ac65dfcb97a58ded9ccc Mon Sep 17 00:00:00 2001 From: akl Date: Mon, 29 Sep 2008 06:37:21 +0000 Subject: [PATCH] To implement issue 0019962: MakePipeBiNormalAlongAxis implementation. --- doc/salome/gui/GEOM/images/pipe2.png | Bin 0 -> 9375 bytes idl/GEOM_Gen.idl | 15 +++ idl/GEOM_Superv.idl | 4 + resources/Makefile.am | 1 + resources/pipebinormal.png | Bin 0 -> 1728 bytes src/GEOMGUI/GEOM_images.po | 3 + src/GEOMImpl/GEOMImpl_I3DPrimOperations.cxx | 62 +++++++++++ src/GEOMImpl/GEOMImpl_I3DPrimOperations.hxx | 4 + src/GEOMImpl/GEOMImpl_IPipeBiNormal.hxx | 47 ++++++++ src/GEOMImpl/GEOMImpl_PipeDriver.cxx | 71 ++++++++++++ src/GEOMImpl/GEOMImpl_Types.hxx | 1 + src/GEOM_I/GEOM_I3DPrimOperations_i.cc | 38 +++++++ src/GEOM_I/GEOM_I3DPrimOperations_i.hh | 4 + src/GEOM_I_Superv/GEOM_Superv_i.cc | 17 +++ src/GEOM_I_Superv/GEOM_Superv_i.hh | 4 + src/GEOM_SWIG/geompyDC.py | 17 +++ src/GenerationGUI/GenerationGUI_PipeDlg.cxx | 115 ++++++++++++++++---- src/GenerationGUI/GenerationGUI_PipeDlg.h | 9 +- 18 files changed, 390 insertions(+), 22 deletions(-) create mode 100755 doc/salome/gui/GEOM/images/pipe2.png create mode 100644 resources/pipebinormal.png create mode 100644 src/GEOMImpl/GEOMImpl_IPipeBiNormal.hxx diff --git a/doc/salome/gui/GEOM/images/pipe2.png b/doc/salome/gui/GEOM/images/pipe2.png new file mode 100755 index 0000000000000000000000000000000000000000..0a69cd834cd4cbb5da06a7d7d3f767d942a4e08f GIT binary patch literal 9375 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 S^9N1#R|8;|D#iPiz4ISHJF%bu literal 0 HcmV?d00001 diff --git a/src/GEOMGUI/GEOM_images.po b/src/GEOMGUI/GEOM_images.po index 475db68ab..a85756d9e 100644 --- a/src/GEOMGUI/GEOM_images.po +++ b/src/GEOMGUI/GEOM_images.po @@ -359,6 +359,9 @@ msgstr "remove_extra_edges.png" msgid "ICON_DLG_PIPE" msgstr "pipe.png" +msgid "ICON_DLG_PIPE_BINORMAL" +msgstr "pipebinormal.png" + #PrismDlg msgid "ICON_DLG_PRISM" msgstr "prism.png" diff --git a/src/GEOMImpl/GEOMImpl_I3DPrimOperations.cxx b/src/GEOMImpl/GEOMImpl_I3DPrimOperations.cxx index a1c554544..6d84b9940 100644 --- a/src/GEOMImpl/GEOMImpl_I3DPrimOperations.cxx +++ b/src/GEOMImpl/GEOMImpl_I3DPrimOperations.cxx @@ -60,6 +60,7 @@ #include #include #include +#include #include #include // CAREFUL ! position of this file is critic : see Lucien PIGNOLONI / OCC @@ -1728,3 +1729,64 @@ Handle(GEOM_Object) GEOMImpl_I3DPrimOperations::MakePipeShellsWithoutPath( } + +//============================================================================= +/*! + * MakePipeBiNormalAlongVector + */ +//============================================================================= +Handle(GEOM_Object) GEOMImpl_I3DPrimOperations::MakePipeBiNormalAlongVector (Handle(GEOM_Object) theBase, + Handle(GEOM_Object) thePath, + Handle(GEOM_Object) theVec) +{ + SetErrorCode(KO); + + if (theBase.IsNull() || thePath.IsNull() || theVec.IsNull()) return NULL; + + //Add a new Pipe object + Handle(GEOM_Object) aPipe = GetEngine()->AddObject(GetDocID(), GEOM_PIPE); + + //Add a new Pipe function + Handle(GEOM_Function) aFunction = + aPipe->AddFunction(GEOMImpl_PipeDriver::GetID(), PIPE_BI_NORMAL_ALONG_VECTOR); + if (aFunction.IsNull()) return NULL; + + //Check if the function is set correctly + if (aFunction->GetDriverGUID() != GEOMImpl_PipeDriver::GetID()) return NULL; + + GEOMImpl_IPipeBiNormal aCI (aFunction); + + Handle(GEOM_Function) aRefBase = theBase->GetLastFunction(); + Handle(GEOM_Function) aRefPath = thePath->GetLastFunction(); + Handle(GEOM_Function) aRefVec = theVec->GetLastFunction(); + + if (aRefBase.IsNull() || aRefPath.IsNull() || aRefVec.IsNull()) return NULL; + + aCI.SetBase(aRefBase); + aCI.SetPath(aRefPath); + aCI.SetVector(aRefVec); + + //Compute the Pipe value + try { +#if (OCC_VERSION_MAJOR << 16 | OCC_VERSION_MINOR << 8 | OCC_VERSION_MAINTENANCE) > 0x060100 + OCC_CATCH_SIGNALS; +#endif + if (!GetSolver()->ComputeFunction(aFunction)) { + SetErrorCode("Pipe driver failed"); + return NULL; + } + } + catch (Standard_Failure) { + Handle(Standard_Failure) aFail = Standard_Failure::Caught(); + SetErrorCode(aFail->GetMessageString()); + return NULL; + } + + //Make a Python command + GEOM::TPythonDump(aFunction) << aPipe << " = geompy.MakePipeBiNormalAlongVector(" + << theBase << ", " << thePath << ", " << theVec << ")"; + + SetErrorCode(OK); + return aPipe; +} + diff --git a/src/GEOMImpl/GEOMImpl_I3DPrimOperations.hxx b/src/GEOMImpl/GEOMImpl_I3DPrimOperations.hxx index 5f1f52f36..c09edc45c 100644 --- a/src/GEOMImpl/GEOMImpl_I3DPrimOperations.hxx +++ b/src/GEOMImpl/GEOMImpl_I3DPrimOperations.hxx @@ -109,6 +109,10 @@ class GEOMImpl_I3DPrimOperations : public GEOM_IOperations { const Handle(TColStd_HSequenceOfTransient)& theBases, const Handle(TColStd_HSequenceOfTransient)& theLocations); + Standard_EXPORT Handle(GEOM_Object) MakePipeBiNormalAlongVector (Handle(GEOM_Object) theBase, + Handle(GEOM_Object) thePath, + Handle(GEOM_Object) theVec); + }; #endif diff --git a/src/GEOMImpl/GEOMImpl_IPipeBiNormal.hxx b/src/GEOMImpl/GEOMImpl_IPipeBiNormal.hxx new file mode 100644 index 000000000..38d62fa2e --- /dev/null +++ b/src/GEOMImpl/GEOMImpl_IPipeBiNormal.hxx @@ -0,0 +1,47 @@ +// Copyright (C) 2005 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN, +// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS +// +// This library is free software; you can redistribute it and/or +// modify it under the terms of the GNU Lesser General Public +// License as published by the Free Software Foundation; either +// version 2.1 of the License. +// +// This library is distributed in the hope that it will be useful +// but WITHOUT ANY WARRANTY; without even the implied warranty of +// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +// Lesser General Public License for more details. +// +// You should have received a copy of the GNU Lesser General Public +// License along with this library; if not, write to the Free Software +// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA +// +// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com +// +//NOTE: This is an interface to a function for the Pipe creation. + +#ifndef _GEOMImpl_IPIPEBINORMAL_HXX_ +#define _GEOMImpl_IPIPEBINORMAL_HXX_ + +#include "GEOM_Function.hxx" + +#ifndef _GEOMImpl_IPIPE_HXX_ +#include "GEOMImpl_IPipe.hxx" +#endif + +#define PIPE_ARG_BASE 1 +#define PIPE_ARG_PATH 2 +#define PIPE_ARG_VEC 3 + +class GEOMImpl_IPipeBiNormal : public GEOMImpl_IPipe +{ + public: + + GEOMImpl_IPipeBiNormal(Handle(GEOM_Function)& theFunction):GEOMImpl_IPipe(theFunction) {} + + void SetVector(Handle(GEOM_Function) theVec) { _func->SetReference(PIPE_ARG_VEC, theVec); } + + Handle(GEOM_Function) GetVector() { return _func->GetReference(PIPE_ARG_VEC); } + +}; + +#endif diff --git a/src/GEOMImpl/GEOMImpl_PipeDriver.cxx b/src/GEOMImpl/GEOMImpl_PipeDriver.cxx index 41aec4758..036abfdb7 100644 --- a/src/GEOMImpl/GEOMImpl_PipeDriver.cxx +++ b/src/GEOMImpl/GEOMImpl_PipeDriver.cxx @@ -25,6 +25,7 @@ #include #include #include +#include #include #include #include @@ -1851,6 +1852,69 @@ static TopoDS_Shape CreatePipeShellsWithoutPath(GEOMImpl_IPipe* aCI) } +//======================================================================= +//function : CreatePipeBiNormalAlongVector +//purpose : auxilary for Execute() +//======================================================================= +static TopoDS_Shape CreatePipeBiNormalAlongVector(const TopoDS_Wire& aWirePath, + GEOMImpl_IPipe* aCI) +{ + GEOMImpl_IPipeBiNormal* aCIBN = (GEOMImpl_IPipeBiNormal*)aCI; + + Handle(GEOM_Function) aRefBase = aCIBN->GetBase(); + Handle(GEOM_Function) aRefVec = aCIBN->GetVector(); + TopoDS_Shape aShapeBase = aRefBase->GetValue(); + TopoDS_Shape aShapeVec = aRefVec->GetValue(); + + if (aShapeBase.IsNull()) { + if(aCIBN) delete aCIBN; + Standard_NullObject::Raise("MakePipe aborted : null base argument"); + } + + TopoDS_Shape aProf; + if( aShapeBase.ShapeType() == TopAbs_EDGE) { + aProf = BRepBuilderAPI_MakeWire(TopoDS::Edge(aShapeBase)).Shape(); + } + else if( aShapeBase.ShapeType() == TopAbs_WIRE) { + aProf = aShapeBase; + } + else if( aShapeBase.ShapeType() == TopAbs_FACE) { + TopExp_Explorer wexp(aShapeBase,TopAbs_WIRE); + aProf = wexp.Current(); + } + else { + Standard_TypeMismatch::Raise + ("MakePipe aborted : invalid type of base"); + } + BRepOffsetAPI_MakePipeShell PipeBuilder(aWirePath); + PipeBuilder.Add(aProf); + + if (aShapeVec.IsNull()) { + if(aCIBN) delete aCIBN; + Standard_NullObject::Raise + ("MakePipe aborted : null vector argument"); + } + if (aShapeVec.ShapeType() != TopAbs_EDGE) + Standard_TypeMismatch::Raise + ("MakePipe aborted: invalid type of vector"); + TopoDS_Edge anEdge = TopoDS::Edge(aShapeVec); + TopoDS_Vertex V1, V2; + TopExp::Vertices(anEdge, V1, V2, Standard_True); + if (V1.IsNull() || V2.IsNull()) + Standard_NullObject::Raise + ("MakePipe aborted: vector is not defined"); + gp_Vec aVec(BRep_Tool::Pnt(V1), BRep_Tool::Pnt(V2)); + gp_Dir BiNormal(aVec); + PipeBuilder.SetMode(BiNormal); + PipeBuilder.Build(); + if( aShapeBase.ShapeType() == TopAbs_FACE) { + PipeBuilder.MakeSolid(); + } + + return PipeBuilder.Shape(); +} + + //======================================================================= //function : Execute //purpose : @@ -1870,6 +1934,8 @@ Standard_Integer GEOMImpl_PipeDriver::Execute(TFunction_Logbook& log) const aCI = new GEOMImpl_IPipeShellSect(aFunction); else if(aType == PIPE_SHELLS_WITHOUT_PATH) aCI = new GEOMImpl_IPipeShellSect(aFunction); + else if(aType == PIPE_BI_NORMAL_ALONG_VECTOR) + aCI = new GEOMImpl_IPipeBiNormal(aFunction); else return 0; @@ -2293,6 +2359,11 @@ Standard_Integer GEOMImpl_PipeDriver::Execute(TFunction_Logbook& log) const aShape = CreatePipeShellsWithoutPath(aCI); } + //building a pipe with constant bi-normal along given vector + else if (aType == PIPE_BI_NORMAL_ALONG_VECTOR) { + aShape = CreatePipeBiNormalAlongVector(aWirePath, aCI); + } + if (aCI) { delete aCI; aCI = 0; diff --git a/src/GEOMImpl/GEOMImpl_Types.hxx b/src/GEOMImpl/GEOMImpl_Types.hxx index 54b156448..cb7987537 100755 --- a/src/GEOMImpl/GEOMImpl_Types.hxx +++ b/src/GEOMImpl/GEOMImpl_Types.hxx @@ -179,6 +179,7 @@ #define PIPE_DIFFERENT_SECTIONS 2 #define PIPE_SHELL_SECTIONS 3 #define PIPE_SHELLS_WITHOUT_PATH 4 +#define PIPE_BI_NORMAL_ALONG_VECTOR 5 #define THRUSECTIONS_RULED 1 #define THRUSECTIONS_SMOOTHED 2 diff --git a/src/GEOM_I/GEOM_I3DPrimOperations_i.cc b/src/GEOM_I/GEOM_I3DPrimOperations_i.cc index 55160f0fb..743cffdf1 100644 --- a/src/GEOM_I/GEOM_I3DPrimOperations_i.cc +++ b/src/GEOM_I/GEOM_I3DPrimOperations_i.cc @@ -819,3 +819,41 @@ GEOM::GEOM_Object_ptr GEOM_I3DPrimOperations_i::MakePipeShellsWithoutPath return GetObject(anObject); } + + +//============================================================================= +/*! + * MakePipeBiNormalAlongVector + */ +//============================================================================= +GEOM::GEOM_Object_ptr GEOM_I3DPrimOperations_i::MakePipeBiNormalAlongVector + (GEOM::GEOM_Object_ptr theBase, + GEOM::GEOM_Object_ptr thePath, + GEOM::GEOM_Object_ptr theVec) +{ + GEOM::GEOM_Object_var aGEOMObject; + + //Set a not done flag + GetOperations()->SetNotDone(); + + if (theBase == NULL || thePath == NULL || theVec == NULL) return aGEOMObject._retn(); + + //Get the reference objects + Handle(GEOM_Object) aBase = GetOperations()->GetEngine()->GetObject + (theBase->GetStudyID(), theBase->GetEntry()); + Handle(GEOM_Object) aPath = GetOperations()->GetEngine()->GetObject + (thePath->GetStudyID(), thePath->GetEntry()); + Handle(GEOM_Object) aVec = GetOperations()->GetEngine()->GetObject + (theVec->GetStudyID(), theVec->GetEntry()); + + if (aBase.IsNull() || aPath.IsNull() || aVec.IsNull()) return aGEOMObject._retn(); + + //Create the Pipe + Handle(GEOM_Object) anObject = + GetOperations()->MakePipeBiNormalAlongVector(aBase, aPath, aVec); + if (!GetOperations()->IsDone() || anObject.IsNull()) + return aGEOMObject._retn(); + + return GetObject(anObject); +} + diff --git a/src/GEOM_I/GEOM_I3DPrimOperations_i.hh b/src/GEOM_I/GEOM_I3DPrimOperations_i.hh index 330f4974b..d2bd5b321 100644 --- a/src/GEOM_I/GEOM_I3DPrimOperations_i.hh +++ b/src/GEOM_I/GEOM_I3DPrimOperations_i.hh @@ -128,6 +128,10 @@ class GEOM_I_EXPORT GEOM_I3DPrimOperations_i : GEOM::GEOM_Object_ptr MakePipeShellsWithoutPath(const GEOM::ListOfGO& theBases, const GEOM::ListOfGO& theLocations); + GEOM::GEOM_Object_ptr MakePipeBiNormalAlongVector (GEOM::GEOM_Object_ptr theBase, + GEOM::GEOM_Object_ptr thePath, + GEOM::GEOM_Object_ptr theVec); + ::GEOMImpl_I3DPrimOperations* GetOperations() { return (::GEOMImpl_I3DPrimOperations*)GetImpl(); } }; diff --git a/src/GEOM_I_Superv/GEOM_Superv_i.cc b/src/GEOM_I_Superv/GEOM_Superv_i.cc index 461ef2d96..0f89227f1 100644 --- a/src/GEOM_I_Superv/GEOM_Superv_i.cc +++ b/src/GEOM_I_Superv/GEOM_Superv_i.cc @@ -1120,6 +1120,23 @@ GEOM::GEOM_Object_ptr GEOM_Superv_i::MakePipeShellsWithoutPath } +//============================================================================= +// MakePipe: +//============================================================================= +GEOM::GEOM_Object_ptr GEOM_Superv_i::MakePipeBiNormalAlongVector + (GEOM::GEOM_Object_ptr theBase, + GEOM::GEOM_Object_ptr thePath, + GEOM::GEOM_Object_ptr theVec) +{ + beginService( " GEOM_Superv_i::MakePipeBiNormalAlongVector" ); + MESSAGE("GEOM_Superv_i::MakePipeBiNormalAlongVector"); + get3DPrimOp(); + GEOM::GEOM_Object_ptr anObj = my3DPrimOp->MakePipeBiNormalAlongVector(theBase, thePath, theVec); + endService( " GEOM_Superv_i::MakePipeBiNormalAlongVector" ); + return anObj; +} + + //============================================================================= // MakeFuse: //============================================================================= diff --git a/src/GEOM_I_Superv/GEOM_Superv_i.hh b/src/GEOM_I_Superv/GEOM_Superv_i.hh index bdeadb12d..58a0ba0a6 100644 --- a/src/GEOM_I_Superv/GEOM_Superv_i.hh +++ b/src/GEOM_I_Superv/GEOM_Superv_i.hh @@ -260,6 +260,10 @@ public: GEOM::GEOM_Object_ptr MakePipeShellsWithoutPath(const GEOM::ListOfGO& theBases, const GEOM::ListOfGO& theLocations); + GEOM::GEOM_Object_ptr MakePipeBiNormalAlongVector (GEOM::GEOM_Object_ptr theBase, + GEOM::GEOM_Object_ptr thePath, + GEOM::GEOM_Object_ptr theVec); + //-----------------------------------------------------------// // BooleanOperations // //-----------------------------------------------------------// diff --git a/src/GEOM_SWIG/geompyDC.py b/src/GEOM_SWIG/geompyDC.py index 65fde5c8a..f0afc1d9c 100644 --- a/src/GEOM_SWIG/geompyDC.py +++ b/src/GEOM_SWIG/geompyDC.py @@ -1027,6 +1027,23 @@ class geompyDC(GEOM._objref_GEOM_Gen): RaiseIfFailed("MakePipeShellsWithoutPath", self.PrimOp) return anObj + ## Create a shape by extrusion of the base shape along + # the path shape with constant bi-normal direction along the given vector. + # The path shape can be a wire or an edge. + # @param theBase Base shape to be extruded. + # @param thePath Path shape to extrude the base shape along it. + # @param theVec Vector defines a constant binormal direction to keep the + # same angle beetween the direction and the sections + # along the sweep surface. + # @return New GEOM_Object, containing the created pipe. + # + # @ref tui_creation_pipe "Example" + def MakePipeBiNormalAlongVector(self,theBase, thePath, theVec): + # Example: see GEOM_TestAll.py + anObj = self.PrimOp.MakePipeBiNormalAlongVector(theBase, thePath, theVec) + RaiseIfFailed("MakePipeBiNormalAlongVector", self.PrimOp) + return anObj + # end of l3_complex ## @} diff --git a/src/GenerationGUI/GenerationGUI_PipeDlg.cxx b/src/GenerationGUI/GenerationGUI_PipeDlg.cxx index 2d124940d..e660e6819 100644 --- a/src/GenerationGUI/GenerationGUI_PipeDlg.cxx +++ b/src/GenerationGUI/GenerationGUI_PipeDlg.cxx @@ -67,23 +67,24 @@ GenerationGUI_PipeDlg::GenerationGUI_PipeDlg(GeometryGUI* theGeometryGUI, QWidge { QPixmap image0(SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM",tr("ICON_DLG_PIPE"))); QPixmap image1(SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM",tr("ICON_SELECT"))); + QPixmap image2(SUIT_Session::session()->resourceMgr()->loadPixmap("GEOM",tr("ICON_DLG_PIPE_BINORMAL"))); setCaption(tr("GEOM_PIPE_TITLE")); /***************************************************************/ GroupConstructors->setTitle(tr("GEOM_PIPE")); RadioButton1->setPixmap(image0); - RadioButton2->close(TRUE); + RadioButton2->setPixmap(image2); RadioButton3->close(TRUE); - GroupPoints = new DlgRef_2Sel_QTD(this, "GroupPoints"); + GroupPoints = new DlgRef_3Sel_QTD(this, "GroupPoints"); GroupPoints->GroupBox1->setTitle(tr("GEOM_ARGUMENTS")); GroupPoints->TextLabel1->setText(tr("GEOM_BASE_OBJECT")); GroupPoints->TextLabel2->setText(tr("GEOM_PATH_OBJECT")); + GroupPoints->TextLabel3->setText(tr("GEOM_VECTOR")); GroupPoints->PushButton1->setPixmap(image1); GroupPoints->PushButton2->setPixmap(image1); - GroupPoints->LineEdit1->setReadOnly( true ); - GroupPoints->LineEdit2->setReadOnly( true ); + GroupPoints->PushButton3->setPixmap(image1); Layout1->addWidget(GroupPoints, 2, 0); /***************************************************************/ @@ -116,17 +117,20 @@ void GenerationGUI_PipeDlg::Init() GroupPoints->LineEdit1->setReadOnly( true ); GroupPoints->LineEdit2->setReadOnly( true ); - myOkBase = myOkPath = false; + myOkBase = myOkPath = myOkVec = false; /* signals and slots connections */ connect(buttonOk, SIGNAL(clicked()), this, SLOT(ClickOnOk())); connect(buttonApply, SIGNAL(clicked()), this, SLOT(ClickOnApply())); + connect(GroupConstructors, SIGNAL(clicked(int)), this, SLOT(ConstructorsClicked(int))); connect(GroupPoints->PushButton1, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument())); connect(GroupPoints->PushButton2, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument())); + connect(GroupPoints->PushButton3, SIGNAL(clicked()), this, SLOT(SetEditCurrentArgument())); connect(GroupPoints->LineEdit1, SIGNAL(returnPressed()), this, SLOT(LineEditReturnPressed())); connect(GroupPoints->LineEdit2, SIGNAL(returnPressed()), this, SLOT(LineEditReturnPressed())); + connect(GroupPoints->LineEdit3, SIGNAL(returnPressed()), this, SLOT(LineEditReturnPressed())); connect(((SalomeApp_Application*)(SUIT_Session::session()->activeApplication()))->selectionMgr(), SIGNAL(currentSelectionChanged()), this, SLOT(SelectionIntoArgument())); @@ -134,6 +138,41 @@ void GenerationGUI_PipeDlg::Init() initName(tr("GEOM_PIPE")); // globalSelection( GEOM_ALLSHAPES ); + + GroupPoints->TextLabel3->hide(); + GroupPoints->PushButton3->hide(); + GroupPoints->LineEdit3->hide(); + ConstructorsClicked( 0 ); +} + + +//================================================================================= +// function : ConstructorsClicked() +// purpose : Radio button management +//================================================================================= +void GenerationGUI_PipeDlg::ConstructorsClicked( int constructorId ) +{ + erasePreview(); + + switch (constructorId) + { + case 0: + { + GroupPoints->TextLabel3->hide(); + GroupPoints->PushButton3->hide(); + GroupPoints->LineEdit3->hide(); + break; + } + case 1: + { + GroupPoints->TextLabel3->show(); + GroupPoints->PushButton3->show(); + GroupPoints->LineEdit3->show(); + break; + } + } + + displayPreview(); } @@ -158,6 +197,8 @@ bool GenerationGUI_PipeDlg::ClickOnApply() return false; initName(); + if ( getConstructorId() != 1 ) + ConstructorsClicked( getConstructorId() ); return true; } @@ -176,6 +217,8 @@ void GenerationGUI_PipeDlg::SelectionIntoArgument() myOkBase = false; else if(myEditCurrentArgument == GroupPoints->LineEdit2) myOkPath = false; + else if(myEditCurrentArgument == GroupPoints->LineEdit3) + myOkVec = false; return; } @@ -197,14 +240,20 @@ void GenerationGUI_PipeDlg::SelectionIntoArgument() S.ShapeType() == TopAbs_SOLID || S.ShapeType() == TopAbs_SHAPE) return; - + if ( getConstructorId() == 1 && + (S.ShapeType() == TopAbs_SHELL || + S.ShapeType() == TopAbs_VERTEX)) + return; + myBase = aSelectedObject; myEditCurrentArgument->setText( GEOMBase::GetName( aSelectedObject ) ); myOkBase = true; } - else if(myEditCurrentArgument == GroupPoints->LineEdit2) { - myOkPath = false; - + else if(myEditCurrentArgument == GroupPoints->LineEdit2 || + myEditCurrentArgument == GroupPoints->LineEdit3) { + myEditCurrentArgument == GroupPoints->LineEdit2 ? myOkPath = false : myOkVec = false; + bool myOk = false; + if( !GEOMBase::GetShape(aSelectedObject, S) ) return; @@ -227,22 +276,29 @@ void GenerationGUI_PipeDlg::SelectionIntoArgument() if ( aFindedObject == GEOM::GEOM_Object::_nil() ) { // Object not found in study GEOM::GEOM_IShapesOperations_var aShapesOp = getGeomEngine()->GetIShapesOperations( getStudyId() ); - myPath = aShapesOp->GetSubShape(aSelectedObject, anIndex); - myOkPath = true; + aSelectedObject = aShapesOp->GetSubShape(aSelectedObject, anIndex); + myOk = true; } else { // get Object from study - myPath = aFindedObject; - myOkPath = true; + aSelectedObject = aFindedObject; + myOk = true; } } else { - myOkPath = true; + myOk = true; if (S.ShapeType() != TopAbs_EDGE) { aSelectedObject = GEOM::GEOM_Object::_nil(); aName = ""; - myOkPath = false; + myOk = false; } + } + if (myEditCurrentArgument == GroupPoints->LineEdit2) { myPath = aSelectedObject; + myOkPath = myOk; + } + else if (myEditCurrentArgument == GroupPoints->LineEdit3) { + myVec = aSelectedObject; + myOkVec = myOk; } } myEditCurrentArgument->setText( aName ); @@ -272,6 +328,12 @@ void GenerationGUI_PipeDlg::SetEditCurrentArgument() globalSelection(); localSelection(GEOM::GEOM_Object::_nil(), TopAbs_EDGE); } + else if(send == GroupPoints->PushButton3) { + GroupPoints->LineEdit3->setFocus(); + myEditCurrentArgument = GroupPoints->LineEdit3; + globalSelection(); + localSelection(GEOM::GEOM_Object::_nil(), TopAbs_EDGE); + } SelectionIntoArgument(); } @@ -284,7 +346,8 @@ void GenerationGUI_PipeDlg::LineEditReturnPressed() { QLineEdit* send = (QLineEdit*)sender(); if(send == GroupPoints->LineEdit1 || - send == GroupPoints->LineEdit2) + send == GroupPoints->LineEdit2 || + send == GroupPoints->LineEdit3) { myEditCurrentArgument = send; GEOMBase_Skeleton::LineEditReturnPressed(); @@ -313,7 +376,7 @@ void GenerationGUI_PipeDlg::ActivateThisDialog() globalSelection( GEOM_ALLSHAPES ); connect(((SalomeApp_Application*)(SUIT_Session::session()->activeApplication()))->selectionMgr(), SIGNAL(currentSelectionChanged()), this, SLOT(SelectionIntoArgument())); - displayPreview(); + ConstructorsClicked(getConstructorId()); } @@ -332,7 +395,12 @@ GEOM::GEOM_IOperations_ptr GenerationGUI_PipeDlg::createOperation() //================================================================================= bool GenerationGUI_PipeDlg::isValid( QString& ) { - return myOkBase && myOkPath; + switch ( getConstructorId() ) { + case 0 : + return myOkBase && myOkPath; + case 1 : + return myOkBase && myOkPath && myOkVec; + } } //================================================================================= @@ -343,8 +411,17 @@ bool GenerationGUI_PipeDlg::execute( ObjectList& objects ) { GEOM::GEOM_Object_var anObj; - anObj = GEOM::GEOM_I3DPrimOperations::_narrow( + switch ( getConstructorId() ) { + case 0 : + anObj = GEOM::GEOM_I3DPrimOperations::_narrow( getOperation() )->MakePipe( myBase, myPath ); + break; + + case 1 : + anObj = GEOM::GEOM_I3DPrimOperations::_narrow( + getOperation() )->MakePipeBiNormalAlongVector( myBase, myPath, myVec ); + break; + } if ( !anObj->_is_nil() ) objects.push_back( anObj._retn() ); diff --git a/src/GenerationGUI/GenerationGUI_PipeDlg.h b/src/GenerationGUI/GenerationGUI_PipeDlg.h index b926d6de7..ab623ff55 100644 --- a/src/GenerationGUI/GenerationGUI_PipeDlg.h +++ b/src/GenerationGUI/GenerationGUI_PipeDlg.h @@ -31,7 +31,7 @@ #include "GenerationGUI.h" #include "GEOMBase_Skeleton.h" -#include "DlgRef_2Sel_QTD.h" +#include "DlgRef_3Sel_QTD.h" //================================================================================= // class : GenerationGUI_PipeDlg @@ -59,10 +59,12 @@ private: GEOM::GEOM_Object_var myBase; /* Base shape */ GEOM::GEOM_Object_var myPath; /* Shape, defining the path */ + GEOM::GEOM_Object_var myVec; /* Vector, defining the constant binormal direction */ bool myOkBase; - bool myOkPath; /* to check when arguments are defined */ + bool myOkPath; + bool myOkVec; /* to check when arguments are defined */ - DlgRef_2Sel_QTD* GroupPoints; + DlgRef_3Sel_QTD* GroupPoints; private slots: void ClickOnOk(); @@ -71,6 +73,7 @@ private slots: void LineEditReturnPressed(); void SelectionIntoArgument(); void SetEditCurrentArgument(); + void ConstructorsClicked(int constructorId); }; #endif // DIALOGBOX_PIPE_H