// GEOM GEOMGUI : GUI for Geometry component // // Copyright (C) 2003 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.opencascade.org/SALOME/ or email : webmaster.salome@opencascade.org // // // // File : GeometryGUI.cxx // Author : Lucien PIGNOLONI // Module : GEOM // $Header$ using namespace std; #include "GeometryGUI.h" // SALOME Includes # include "Utils_ORB_INIT.hxx" # include "Utils_SINGLETON.hxx" #include "QAD.h" #include "QAD_Tools.h" #include "QAD_Config.h" #include "QAD_Settings.h" #include "QAD_RightFrame.h" #include "QAD_MessageBox.h" #include "QAD_Resource.h" #include "QAD_FileDlg.h" #include "OCCViewer_ViewPort.h" #include "OCCViewer_ViewPort3d.h" #include "OCCViewer_Viewer3d.h" #include "SALOME_NamingService.hxx" #include "SALOME_ListIteratorOfListIO.hxx" #include "SALOME_InteractiveObject.hxx" #include "SALOMEGUI_ImportOperation.h" #include "SALOMEGUI_QtCatchCorbaException.hxx" #include "SALOMEGUI_NameDlg.h" #include "utilities.h" // Open CASCADE Includes #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include //VRV: OCC 4.0 migration #include #include #include //#include //VRV: OCC 4.0 migration #include #include #include #include #include #include #include #include #include #include #include #include // QT Includes #define INCLUDE_MENUITEM_DEF #include #include #include #include #include #include #include #include #include #include #include #include #include #include #include "VTKViewer_RenderWindowInteractor.h" #include "VTKViewer_ViewFrame.h" #include "GEOM_Actor.h" #include "GEOM_Client.hxx" #include "GEOM_AISShape.hxx" #include "GEOM_AssemblyBuilder.h" #include "GEOM_InteractiveObject.hxx" #include "GeometryGUI_aParameterDlg.h" #include "GeometryGUI_PointDlg.h" // Method POINT #include "GeometryGUI_BoxDlg.h" // Method BOX #include "GeometryGUI_VectorDlg.h" // Method VECTOR #include "GeometryGUI_PlaneDlg.h" // Method PLANE #include "GeometryGUI_PrismDlg.h" // Method PRISM #include "GeometryGUI_FuseDlg.h" // Method FUSE #include "GeometryGUI_CommonDlg.h" // Method COMMON #include "GeometryGUI_CutDlg.h" // Method CUT #include "GeometryGUI_SectionDlg.h" // Method SECTION #include "GeometryGUI_LineDlg.h" // Method LINE #include "GeometryGUI_ScaleDlg.h" // Method SCALE #include "GeometryGUI_MirrorDlg.h" // Method MIRROR #include "GeometryGUI_SphereDlg.h" // Method SPHERE #include "GeometryGUI_CircleDlg.h" // Method CIRCLE #include "GeometryGUI_RevolDlg.h" // Method REVOL #include "GeometryGUI_RotationDlg.h" // Method ROTATION #include "GeometryGUI_TranslationDlg.h" // Method TRANSLATION #include "GeometryGUI_MultiTranslationDlg.h" // Method MULTI TRANSLATION #include "GeometryGUI_MultiRotationDlg.h" // Method MULTI ROTATION #include "GeometryGUI_ArcDlg.h" // Method ARC #include "GeometryGUI_PipeDlg.h" // Method PIPE #include "GeometryGUI_CylinderDlg.h" // Method CYLINDER #include "GeometryGUI_ConeDlg.h" // Method CONE #include "GeometryGUI_TorusDlg.h" // Method TORUS #include "GeometryGUI_FillingDlg.h" // Method FILLING #include "GeometryGUI_SewingDlg.h" // Method SEWING #include "GeometryGUI_CompoundDlg.h" // Method GEOM::COMPOUND #include "GeometryGUI_EdgeDlg.h" // Method GEOM::EDGE #include "GeometryGUI_OrientationDlg.h" // Method ORIENTATION #include "GeometryGUI_PartitionDlg.h" // Method PARTITION #include "GeometryGUI_SubShapeDlg.h" // Method EXPLODE #include "GeometryGUI_WireDlg.h" // Method GEOM::WIRE #include "GeometryGUI_WorkingPlaneDlg.h" // Method WORKING PLANE #include "GeometryGUI_PropertiesDlg.h" // Method PROPERTIES #include "GeometryGUI_CenterMassDlg.h" // Method CENTER MASS #include "GeometryGUI_InertiaDlg.h" // Method INERTIA #include "GeometryGUI_FaceDlg.h" // Method GEOM::FACE #include "GeometryGUI_FilletDlg.h" // Method FILLET #include "GeometryGUI_ChamferDlg.h" // Method CHAMFER #include "GeometryGUI_FillingHoleDlg.h" // Method FILLING HOLE #include "GeometryGUI_SuppressFacesDlg.h" // Method SUPPRESS FACES #include "GeometryGUI_CheckShape.h" // Method CHECKSHAPE #include "GeometryGUI_ArchimedeDlg.h" // Method ARCHIMEDE #include "GeometryGUI_TransparencyDlg.h" // Method TRANSPARENCY adjustement #include "GeometryGUI_NbIsosDlg.h" // Method ISOS adjustement #include "GeometryGUI_BndBoxDlg.h" // Method BNDBOX #include "GeometryGUI_MaxToleranceDlg.h" // Method MAXTOLERANCE #include "GeometryGUI_WhatisDlg.h" // Method WHATIS #include "GeometryGUI_DistanceDlg.h" // Method DISTANCE #include "GeometryGUI_SuppressHoleDlg.h" // Method SUPPRESS HOLE static Handle(AIS_Shape) theConstructionShape = new AIS_Shape(TopoDS_Shape()); static Handle(GEOM_AISShape) theSelectedShape = new GEOM_AISShape(TopoDS_Shape(), ""); static AIS_ListOfInteractive ListDisplayedObject; static bool Settings_AddInStudy = false; static bool Settings_Copy = false; static Standard_CString Fatherior = ""; static GEOM_Client ShapeReader; /* The object itself created in the static method 'GetOrCreateGeometryGUI()' */ static GeometryGUI* GeomGUI = 0; //======================================================================= // class : CustomItem // purpose : Set Font to a text. //======================================================================= class CustomItem : public QCustomMenuItem { public: CustomItem( const QString& s, const QFont& f ) : string( s ), font( f ){}; ~CustomItem(){} void paint( QPainter* p, const QColorGroup& /*cg*/, bool /*act*/, bool /*enabled*/, int x, int y, int w, int h ) { p->setFont ( font ); p->drawText( x, y, w, h, AlignHCenter | AlignVCenter | ShowPrefix | DontClip, string ); } QSize sizeHint() { return QFontMetrics( font ).size( AlignHCenter | AlignVCenter | ShowPrefix | DontClip, string ); } private: QString string; QFont font; }; //======================================================================= // function : GeometryGUI() // purpose : Constructor //======================================================================= GeometryGUI::GeometryGUI() : QObject() { } //======================================================================= // function : ~GeometryGUI() // purpose : Destructor //======================================================================= GeometryGUI::~GeometryGUI() { } //======================================================================= // function : GetGeometryGUI() static // purpose : Returns current 'GeomGUI' a static pointer //======================================================================= GeometryGUI* GeometryGUI::GetGeometryGUI( ) { return GeomGUI; } //===================================================================================== // function : GetIndex() // purpose : Get the index of a sub shape in a main shape : index start at 1 //===================================================================================== int GeometryGUI::GetIndex(const TopoDS_Shape& subshape, const TopoDS_Shape& shape, int /*ShapeType*/) { if( shape.IsNull() || subshape.IsNull() ) return -1 ; int index = 1; if (subshape.ShapeType() == TopAbs_COMPOUND) { TopoDS_Iterator it; TopTools_ListOfShape CL; CL.Append( shape ); TopTools_ListIteratorOfListOfShape itC; for (itC.Initialize( CL ); itC.More(); itC.Next()) { for (it.Initialize( itC.Value() ); it.More(); it.Next()) { if ( it.Value().ShapeType() == TopAbs_COMPOUND) { if (it.Value().IsSame(subshape)) return index; else index++; CL.Append( it.Value() ); } } } } else { TopExp_Explorer Exp ( shape, subshape.ShapeType() ); TopTools_MapOfShape M; while ( Exp.More() ) { if ( M.Add(Exp.Current()) ) { if ( Exp.Current().IsSame(subshape) ) return index; index++; } Exp.Next(); } } return -1; } //======================================================================= // function : GetOrCreateGeometryGUI() // purpose : Gets or create an object 'GeometryGUI' with initialisations // : Returns 'GeomGUI' as a pointer //======================================================================= GeometryGUI* GeometryGUI::GetOrCreateGeometryGUI( QAD_Desktop* desktop ) { if( GeomGUI == 0 ) { GeomGUI = new GeometryGUI; GeomGUI->myActiveDialogBox = 0 ; GeomGUI->mySimulationShape = new AIS_Shape(TopoDS_Shape()); GeomGUI->myState = -1 ; GeomGUI->myDesktop = desktop ; GeomGUI->myActiveStudy = desktop->getActiveStudy(); GeomGUI->mySimulationActor = vtkActorCollection::New() ; GeomGUI->myShadingColor = Quantity_Color( Quantity_NOC_GOLDENROD ); Engines::Component_var comp = desktop->getEngine("FactoryServer", "Geometry"); GeomGUI->myComponentGeom = GEOM::GEOM_Gen::_narrow(comp); /* GetCurrentStudy */ int studyId = GeomGUI->myActiveStudy->getStudyId(); GeomGUI->myComponentGeom->GetCurrentStudy(studyId); GeomGUI->myNbGeom = GeomGUI->myComponentGeom->NbLabels(); } else { /* study may have changed */ GeomGUI->myActiveStudy = desktop->getActiveStudy(); } return GeomGUI; } //================================================================================= // function : VertexToPoint() // purpose : If S can be converted in a gp_Pnt returns true and the result is P //================================================================================= bool GeometryGUI::VertexToPoint( const TopoDS_Shape& S, gp_Pnt& P ) { if( S.IsNull() || S.ShapeType() != TopAbs_VERTEX ) return false ; P = BRep_Tool::Pnt(TopoDS::Vertex( S )); return true ; } //================================================================================= // function : LinearEdgeExtremities() // purpose : If S can be converted in a linear edge and if initial an final points // : distance is sufficient, returns true else returns false. // : Resulting points are respectively P1 and P2 //================================================================================= bool GeometryGUI::LinearEdgeExtremities( const TopoDS_Shape& S, gp_Pnt& P1, gp_Pnt& P2 ) { if( S.IsNull() || S.ShapeType() != TopAbs_EDGE ) return false ; BRepAdaptor_Curve curv(TopoDS::Edge(S)); if (curv.GetType() != GeomAbs_Line) return false ; curv.D0( curv.FirstParameter(), P1 ); curv.D0( curv.LastParameter(), P2 ); if( P1.Distance(P2) <= Precision::Confusion() ) return false ; return true ; } //================================================================================= // function : GetBipointDxDyDz() // purpose : //================================================================================= void GeometryGUI::GetBipointDxDyDz( gp_Pnt P1, gp_Pnt P2, double& dx, double& dy, double& dz ) { dx = P2.X() - P1.X() ; dy = P2.Y() - P1.Y() ; dz = P2.Z() - P1.Z() ; return ; } //======================================================================= // function : GetTopoFromSelection() // purpose : Define tds from a single selection and retuen true //======================================================================= bool GeometryGUI::GetTopoFromSelection(SALOME_Selection *Sel, TopoDS_Shape& tds) { if(Sel->IObjectCount() != 1) return false ; Handle(SALOME_InteractiveObject) IO = Sel->firstIObject(); /* case SObject */ if ( IO->hasEntry() ) { SALOMEDS::Study_var aStudy = GeomGUI->myActiveStudy->getStudyDocument(); SALOMEDS::SObject_var obj = aStudy->FindObjectID( IO->getEntry() ); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeIOR_var anIOR; if ( !obj->_is_nil() ) { if (obj->FindAttribute(anAttr, "AttributeIOR")) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); tds = this->GetShapeFromIOR(anIOR->Value()); if(tds.IsNull() ) return false ; else return true ; } } } if ( IO->IsInstance(STANDARD_TYPE(GEOM_InteractiveObject)) ) { Standard_CString ior = ""; Handle(GEOM_InteractiveObject) GIObject = Handle(GEOM_InteractiveObject)::DownCast( IO ); ior = GIObject->getIOR(); tds = this->GetShapeFromIOR(ior); if(tds.IsNull() ) return false ; else return true ; } return false; } //===================================================================================== // function : PrepareSubShapeSelection() // purpose : ( localContextId of the method is opened and defined here) //===================================================================================== bool GeometryGUI::PrepareSubShapeSelection(const int SubShapeType, Standard_Integer& returnLocalContextId) { //* Test the type of viewer */ if ( this->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) return false; OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); /* local context opening */ SetDisplayedObjectList() ; OnDisplayOnly(); returnLocalContextId = ic->OpenLocalContext(Standard_False, Standard_True, Standard_False, Standard_False) ; SALOME_Selection* Sel = SALOME_Selection::Selection( this->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); for(;It.More();It.Next()) { Handle(SALOME_InteractiveObject) IObject = It.Value(); Standard_Boolean found; Handle(GEOM_AISShape) Shape = ConvertIOinGEOMAISShape(IObject, found); if ( found && SubShapeType >= Shape->Shape().ShapeType()) { ic->Load(Shape, (8 - SubShapeType), Standard_True); ic->HilightWithColor(Shape, Quantity_NOC_RED); } } myDesktop->putInfo (tr("GEOM_PRP_SELECT_SUBSHAPES")); return true ; } //===================================================================================== // function : PrepareSubShapeSelectionArgumentShape() // purpose : ( localContextId of the method is opened and defined here ) //===================================================================================== bool GeometryGUI::PrepareSubShapeSelectionArgumentShape( const TopoDS_Shape& aShape, const int SubShapeType, Standard_Integer& returnLocalContextId ) { //* Test the type of viewer */ if ( this->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) return false; if( aShape.IsNull() ) return false ; OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); /* local context opening */ SetDisplayedObjectList() ; OnDisplayOnly(); returnLocalContextId = ic->OpenLocalContext(Standard_False, Standard_True, Standard_False, Standard_False) ; Handle(GEOM_AISShape) Shape = new GEOM_AISShape(aShape, "") ; ic->Display(Shape, 0, (8 - SubShapeType)); // Not Load(...) but Display(...) // ic->Load(Shape, (8 - SubShapeType), Standard_True); ic->HilightWithColor(Shape, Quantity_NOC_RED); myDesktop->putInfo (tr("GEOM_PRP_SELECT_SUBSHAPES")); return true ; } //======================================================================= // function : GetNameOfSelectedIObjects() // purpose : Define the name geom++ or other name of mono or multi sel. //======================================================================= int GeometryGUI::GetNameOfSelectedIObjects( SALOME_Selection* Sel, QString& aName ) { int nbSel = Sel->IObjectCount() ; if ( nbSel == 1 ) { Handle(SALOME_InteractiveObject) IObject = Sel->firstIObject(); aName = IObject->getName(); } else { aName = tr( "%1_objects" ).arg( nbSel ); } return nbSel; } //======================================================================= // function : ConvertIOinGEOMAISShape() // purpose : //======================================================================= Handle(GEOM_AISShape) GeometryGUI::ConvertIOinGEOMAISShape( const Handle(SALOME_InteractiveObject)& IO, Standard_Boolean& testResult, bool onlyInActiveView ) { Handle(GEOM_AISShape) res; int nbSf = myActiveStudy->getStudyFramesCount(); for ( int i = 0; i < nbSf; i++ ) { QAD_StudyFrame* sf = myActiveStudy->getStudyFrame(i); if ( sf->getTypeView() == VIEW_OCC ) { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)sf->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); AIS_ListOfInteractive List; ic->DisplayedObjects(List); AIS_ListOfInteractive List1; ic->ObjectsInCollector(List1); List.Append(List1); AIS_ListIteratorOfListOfInteractive ite(List); while (ite.More()) { if (ite.Value()->IsInstance(STANDARD_TYPE(GEOM_AISShape))) { Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast(ite.Value()); if ( aSh->hasIO() ) { Handle(GEOM_InteractiveObject) GIO = Handle(GEOM_InteractiveObject)::DownCast(aSh->getIO()); if ( GIO->isSame( IO ) ) { if ( onlyInActiveView ) { if ( sf == myActiveStudy->getActiveStudyFrame() ) { testResult = true; return aSh; } } else { testResult = true; return aSh; } } } } ite.Next(); } } } testResult = false; return res; } //======================================================================= // function : ConvertIORinGEOMAISShape() // purpose : //======================================================================= Handle(GEOM_AISShape) GeometryGUI::ConvertIORinGEOMAISShape( const char * IOR, Standard_Boolean& testResult, bool onlyInActiveView ) { Handle(GEOM_AISShape) resultShape; testResult = false; int nbSf = myActiveStudy->getStudyFramesCount(); for ( int i = 0; i < nbSf; i++ ) { QAD_StudyFrame* sf = myActiveStudy->getStudyFrame(i); if ( sf->getTypeView() == VIEW_OCC ) { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)sf->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); AIS_ListOfInteractive List; ic->DisplayedObjects(List); AIS_ListOfInteractive List1; ic->ObjectsInCollector(List1); List.Append(List1); AIS_ListIteratorOfListOfInteractive ite(List); while (ite.More()) { if (ite.Value()->IsInstance(STANDARD_TYPE(GEOM_AISShape))) { Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast(ite.Value()); if ( aSh->hasIO() ) { Handle(GEOM_InteractiveObject) GIO = Handle(GEOM_InteractiveObject)::DownCast(aSh->getIO()); Standard_CString theIOR = GIO->getIOR(); if ( strcmp( IOR, theIOR ) == 0 ) { if ( onlyInActiveView ) { if ( sf == myActiveStudy->getActiveStudyFrame() ) { testResult = true; resultShape = aSh; return resultShape; } } else { testResult = true; resultShape = aSh; return resultShape; } } } } ite.Next(); } } } return resultShape; } //======================================================================= // function : ConvertIORinGEOMActor() // purpose : //======================================================================= GEOM_Actor* GeometryGUI::ConvertIORinGEOMActor( const char * IOR, Standard_Boolean& testResult, bool onlyInActiveView ) { int nbSf = GeomGUI->myActiveStudy->getStudyFramesCount(); for ( int i = 0; i < nbSf; i++ ) { QAD_StudyFrame* sf = myActiveStudy->getStudyFrame(i); if ( sf->getTypeView() == VIEW_VTK ) { vtkRenderer* Renderer = ((VTKViewer_ViewFrame*)sf->getRightFrame()->getViewFrame())->getRenderer(); vtkActorCollection* theActors = Renderer->GetActors(); theActors->InitTraversal(); vtkActor *ac = theActors->GetNextActor(); while(!(ac==NULL)) { if ( ac->IsA("GEOM_Actor") ) { GEOM_Actor* anActor = GEOM_Actor::SafeDownCast( ac ); if ( anActor->hasIO() ) { Handle(GEOM_InteractiveObject) GIO = Handle(GEOM_InteractiveObject)::DownCast(anActor->getIO()); Standard_CString theIOR = GIO->getIOR(); if ( strcmp( IOR, theIOR ) == 0 ) { if ( onlyInActiveView ) { if ( sf == GeomGUI->myActiveStudy->getActiveStudyFrame() ) { testResult = true; return anActor; } } else { testResult = true; return anActor; } } } } ac = theActors->GetNextActor(); } } } testResult = false; return GEOM_Actor::New(); } //======================================================================= // function : ConvertIOinGEOMShape() // purpose : //======================================================================= GEOM::GEOM_Shape_ptr GeometryGUI::ConvertIOinGEOMShape( const Handle(SALOME_InteractiveObject)& IO, Standard_Boolean& testResult ) { GEOM::GEOM_Shape_ptr aShape ; testResult = false ; /* case SObject */ if ( IO->hasEntry() ) { SALOMEDS::Study_var aStudy = GeomGUI->myActiveStudy->getStudyDocument(); SALOMEDS::SObject_var obj = aStudy->FindObjectID( IO->getEntry() ); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeIOR_var anIOR; if ( !obj->_is_nil() ) { if (obj->FindAttribute(anAttr, "AttributeIOR")) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); aShape = myComponentGeom->GetIORFromString(anIOR->Value()) ; testResult = true ; return aShape; } } } /* case Graphical Object */ if ( IO->IsInstance(STANDARD_TYPE(GEOM_InteractiveObject)) ) { Handle(GEOM_InteractiveObject) GIObject = Handle(GEOM_InteractiveObject)::DownCast( IO ); Standard_CString ior = GIObject->getIOR(); testResult = true ; aShape = myComponentGeom->GetIORFromString(ior) ; return aShape; } return aShape ; } //======================================================================= // function : ConvertListOfIOInListOfIOR() // purpose : //======================================================================= void GeometryGUI::ConvertListOfIOInListOfIOR( const SALOME_ListIO& aList, GEOM::GEOM_Gen::ListOfIOR& listIOR ) { int nbSel = aList.Extent(); listIOR.length(nbSel) ; int j=0; SALOME_ListIteratorOfListIO It( aList ); for ( int i=0; It.More(); It.Next(), i++ ) { Handle(SALOME_InteractiveObject) IObject = It.Value(); if ( IObject->hasEntry() ) { SALOMEDS::Study_var aStudy = GeomGUI->myActiveStudy->getStudyDocument(); SALOMEDS::SObject_var obj = aStudy->FindObjectID( IObject->getEntry() ); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeIOR_var anIOR; if ( !obj->_is_nil() && obj->FindAttribute(anAttr, "AttributeIOR") ) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); ORB_INIT &init = *SINGLETON_::Instance() ; CORBA::ORB_var& _orb = init.orb() ; CORBA::String_var theValue = anIOR->Value(); CORBA::Object_var theObj = _orb->string_to_object(theValue); if (theObj->_is_a("IDL:GEOM/GEOM_Shape:1.0")) { listIOR[j] = strdup(theValue) ; j++; } } } else if ( IObject->IsInstance(STANDARD_TYPE(GEOM_InteractiveObject)) ) { Handle(GEOM_InteractiveObject) GIObject = Handle(GEOM_InteractiveObject)::DownCast( IObject ); Standard_CString ior = GIObject->getIOR(); listIOR[j] = strdup(ior) ; j++; } } listIOR.length(j) ; } //================================================================================= // function : GetShapeTypeString() // purpose : for a single shape //================================================================================= bool GeometryGUI::GetShapeTypeString( const TopoDS_Shape& aShape, Standard_CString& aTypeString ) { if( aShape.IsNull() ) { aTypeString = "aNullShape" ; return false ; } switch (aShape.ShapeType() ) { case TopAbs_COMPOUND: { aTypeString = strdup(tr("GEOM_COMPOUND")) ; return true ; } case TopAbs_COMPSOLID: { aTypeString = strdup(tr("GEOM_COMPOUNDSOLID")) ; return true ; } case TopAbs_SOLID: { aTypeString = strdup(tr("GEOM_SOLID")) ; return true ; } case TopAbs_SHELL: { aTypeString = strdup(tr("GEOM_SHELL")) ; return true ; } case TopAbs_FACE: { BRepAdaptor_Surface surf(TopoDS::Face(aShape)); if ( surf.GetType() == GeomAbs_Plane ) { aTypeString = strdup(tr("GEOM_PLANE")) ; return true ; } else if ( surf.GetType() == GeomAbs_Cylinder ) { aTypeString = strdup(tr("GEOM_SURFCYLINDER")) ; return true ; } else if ( surf.GetType() == GeomAbs_Sphere ) { aTypeString = strdup(tr("GEOM_SURFSPHERE")) ; return true ; } else if ( surf.GetType() == GeomAbs_Torus ) { aTypeString = strdup(tr("GEOM_SURFTORUS")) ; return true ; } else if ( surf.GetType() == GeomAbs_Cone ) { aTypeString = strdup(tr("GEOM_SURFCONE")) ; return true ; } else { aTypeString = strdup(tr("GEOM_FACE")) ; return true ; } } case TopAbs_WIRE: { aTypeString = strdup(tr("GEOM_WIRE")) ; return true ; } case TopAbs_EDGE: { BRepAdaptor_Curve curv(TopoDS::Edge(aShape)); if ( curv.GetType() == GeomAbs_Line ) { if ( (Abs(curv.FirstParameter()) >= 1E6 ) || (Abs(curv.LastParameter()) >= 1E6 )) { aTypeString = strdup(tr("GEOM_LINE")) ; } else aTypeString = strdup(tr("GEOM_EDGE")) ; return true ; } else if ( curv.GetType() == GeomAbs_Circle ) { if ( curv.IsClosed() ) aTypeString = strdup(tr("GEOM_CIRCLE")) ; else aTypeString = strdup(tr("GEOM_ARC")) ; return true ; } else { aTypeString = strdup(tr("GEOM_EDGE")) ; return true ; } } case TopAbs_VERTEX: { aTypeString = strdup(tr("GEOM_VERTEX")) ; return true ; } case TopAbs_SHAPE: { aTypeString = strdup(tr("GEOM_SHAPE")) ; return true ; } } return false ; } //================================================================================= // function : CreateArrowForLinearEdge() // purpose : Create a cone topology to be used to display an arrow in the middle // : of an edge showing its orientation. (For simulation and Viewer OCC only) //================================================================================= bool GeometryGUI::CreateArrowForLinearEdge( const TopoDS_Shape& tds, TopoDS_Shape& ArrowCone ) { if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() != VIEW_OCC || tds.ShapeType() != TopAbs_EDGE ) return false; OCCViewer_ViewPort* vp = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewPort(); Handle( V3d_View) view3d = ((OCCViewer_ViewPort3d*)vp)->getView(); Standard_Real Width, Height ; view3d->Size(Width, Height) ; const Standard_Real aHeight = (Width + Height) / 50.0 ; try { Standard_Real first, last ; Handle(Geom_Curve) curv = BRep_Tool::Curve(TopoDS::Edge(tds), first, last); if( !curv->IsCN(1) ) return false ; const Standard_Real param = (first+last) / 2.0 ; gp_Pnt middleParamPoint ; gp_Vec V1 ; curv->D1( param, middleParamPoint, V1) ; if ( V1.Magnitude() < Precision::Confusion() ) return false ; /* Topology orientation not geom orientation */ if( tds.Orientation() == TopAbs_REVERSED ) V1 *= -1.0 ; gp_Ax2 anAxis( middleParamPoint, gp_Dir(V1) ) ; const Standard_Real radius1 = aHeight / 5.0 ; if( radius1 > 10.0 * Precision::Confusion() && aHeight > 10.0 * Precision::Confusion() ) { ArrowCone = BRepPrimAPI_MakeCone( anAxis, radius1, 0.0, aHeight ).Shape() ; return true ; } } catch(Standard_Failure) { // OCC failures are hard to catch in GUI. // This because of the position for #include that is very critic to find // in SALOME environment : compilation error ! } return false ; } //======================================================================= // function : SelectionByNameInDialogs() // purpose : Called when user has entered a name of object in a LineEdit. // : The selection is changed. Dialog box will receive the // : corresponding signal to manage this event. //======================================================================= bool GeometryGUI::SelectionByNameInDialogs( QWidget* aWidget, const QString& objectUserName, SALOME_Selection* Sel ) { /* Find SObject with name in component GEOM */ SALOMEDS::Study_var ST = this->myActiveStudy->getStudyDocument() ; SALOMEDS::Study::ListOfSObject_var listSO = new SALOMEDS::Study::ListOfSObject ; listSO = ST->FindObjectByName( objectUserName, "GEOM" ) ; if ( listSO->length() < 1 ) { const QString caption = tr("GEOM_WRN_WARNING") ; const QString text = tr("GEOM_NAME_INCORRECT") ; const QString button0 = tr("GEOM_BUT_OK") ; QMessageBox::warning( aWidget, caption, text, button0 ) ; return false ; } /* More than one object with same name */ if ( listSO->length() > 1 ) { const QString caption = tr("GEOM_WRN_WARNING") ; const QString text = tr("GEOM_IDENTICAL_NAMES_SELECT_BY_MOUSE") ; const QString button0 = tr("GEOM_BUT_OK") ; QMessageBox::warning( aWidget, caption, text, button0 ) ; return false ; } SALOMEDS::SObject_var theObj = listSO[0] ; /* Create a SALOME_InteractiveObject with a SALOME::SObject */ Standard_CString anEntry = theObj->GetID() ; Handle(SALOME_InteractiveObject) SI = new SALOME_InteractiveObject( anEntry, "GEOM", strdup(objectUserName) ) ; /* Add as a selected object */ /* Clear any previous selection : */ /* Warning the LineEdit is purged because of signal currentSelectionChanged ! */ Sel->ClearIObjects() ; Sel->AddIObject( SI ) ; return true ; } //======================================================================= // function : MakePointAndDisplay // purpose : //======================================================================= void GeometryGUI::MakePointAndDisplay( const double x, const double y, const double z ) { try { GEOM::GEOM_Shape_var P = myComponentGeom->MakeVertex( x, y, z ); P->NameType( tr("GEOM_VERTEX") ); if ( Display( P, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //======================================================================= // function : MakeVectorAndDisplay() // purpose : //======================================================================= void GeometryGUI::MakeVectorAndDisplay( const gp_Pnt P1, const gp_Pnt P2 ) { try { GEOM::PointStruct pstruct1 = myComponentGeom->MakePointStruct( P1.X(), P1.Y(), P1.Z() ) ; GEOM::PointStruct pstruct2 = myComponentGeom->MakePointStruct( P2.X(), P2.Y(), P2.Z() ) ; GEOM::GEOM_Shape_var Vector = myComponentGeom->MakeVector( pstruct1, pstruct2 ); Vector->NameType(tr("GEOM_VECTOR")); if ( Display( Vector, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } //======================================================================= // function : MakeBoxAndDisplay() // purpose : //======================================================================= void GeometryGUI::MakeBoxAndDisplay( const gp_Pnt P1, const gp_Pnt P2 ) { try { GEOM::GEOM_Shape_var box = myComponentGeom->MakeBox( P1.X(), P1.Y(), P1.Z(), P2.X(), P2.Y(), P2.Z() ); box->NameType(tr("GEOM_BOX")); if ( Display( box, "") ) { myDesktop->putInfo(tr("GEOM_PRP_DONE")); } } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } //======================================================================= // function : MakePlaneAndDisplay() // purpose : Plane point is P1 and dx, dy, dz define a normal vector //======================================================================= void GeometryGUI::MakePlaneAndDisplay( const gp_Pnt P1, const Standard_Real dx, const Standard_Real dy, const Standard_Real dz, const Standard_Real TrimSize ) { try { gp_Dir aDirection; aDirection.SetCoord(dx, dy, dz) ; gp_Ax2 Axis( P1, aDirection ); GEOM::PointStruct pstruct = myComponentGeom->MakePointStruct(P1.X(), P1.Y(), P1.Z() ) ; GEOM::PointStruct d = myComponentGeom->MakePointStruct(aDirection.X(), aDirection.Y(), aDirection.Z()) ; GEOM::DirStruct dstruct = myComponentGeom->MakeDirection(d) ; GEOM::GEOM_Shape_ptr plane = myComponentGeom->MakePlane(pstruct, dstruct, TrimSize) ; plane->NameType(tr("GEOM_PLANE")); if ( Display( plane, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } //======================================================================= // function : MakeWorkingPlane() // purpose : Change the point of view3d //======================================================================= void GeometryGUI::MakeWorkingPlane( const gp_Pnt P, const gp_Dir D) { if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() != VIEW_OCC) { GeomGUI->myDesktop->putInfo( tr("GEOM_PRP_NOT_FOR_VTK_VIEWER") ) ; return ; } OCCViewer_ViewPort* vp = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewPort(); Handle( V3d_View) view3d = ((OCCViewer_ViewPort3d*)vp)->getView(); view3d->SetAt( P.X(), P.Y(), P.Z() ); view3d->SetProj( D.X(), D.Y(), D.Z() ); myDesktop->putInfo(tr("GEOM_PRP_DONE")); } //======================================================================= // function : MakePrismAndDisplay() // purpose : P1 and P2 is to define a vector for prism //======================================================================= void GeometryGUI::MakePrismAndDisplay( GEOM::GEOM_Shape_ptr BaseShape, const gp_Pnt P1, const gp_Pnt P2 ) { try { GEOM::PointStruct PS1 = myComponentGeom->MakePointStruct(P1.X(), P1.Y(), P1.Z() ) ; GEOM::PointStruct PS2 = myComponentGeom->MakePointStruct(P2.X(), P2.Y(), P2.Z() ) ; if( BaseShape->_is_nil() ) { myDesktop->putInfo (tr("GEOM_PRP_NULLSHAPE")) ; return ; } GEOM::GEOM_Shape_ptr result = myComponentGeom->MakePrism( BaseShape, PS1, PS2 ) ; if (result->_is_nil()) { myDesktop->putInfo (tr("GEOM_PRP_NULLSHAPE")) ; return ; } TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, result); Standard_CString type; GetShapeTypeString(S,type); result->NameType( type ); if ( Display( result, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakeLineAndDisplay() // purpose : Create an infinite oriented line (linear edge in fact) //===================================================================================== void GeometryGUI::MakeLineAndDisplay( const gp_Pnt InitPoint, const gp_Pnt LastPoint ) { gp_Pnt P1,P2; double dx, dy, dz ; GetBipointDxDyDz( InitPoint, LastPoint, dx, dy, dz ) ; Standard_Real length = InitPoint.Distance(LastPoint) ; if( length <= Precision::Confusion() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT")); return ; } Standard_Real coeff = 1E6 / length ; /* To create a line with length = 1E6 */ /* Precision::Infinite() is 1E100 in OCC */ P1.SetX( InitPoint.X() - (coeff * dx) ) ; P1.SetY( InitPoint.Y() - (coeff * dy) ) ; P1.SetZ( InitPoint.Z() - (coeff * dz) ) ; P2.SetX( LastPoint.X() + (coeff * dx) ) ; P2.SetY( LastPoint.Y() + (coeff * dy) ) ; P2.SetZ( LastPoint.Z() + (coeff * dz) ) ; try { GEOM::PointStruct pstruct = myComponentGeom->MakePointStruct(P1.X(), P1.Y(), P1.Z()) ; GEOM::PointStruct d = myComponentGeom->MakePointStruct(P2.X(), P2.Y(), P2.Z()) ; GEOM::DirStruct dstruct = myComponentGeom->MakeDirection(d) ; GEOM::GEOM_Shape_ptr result = myComponentGeom->MakeLine(pstruct, dstruct) ; if(result->_is_nil()) { myDesktop->putInfo(tr("GEOM_PRP_ABORT")); return ; } result->NameType(tr("GEOM_LINE")); if ( Display( result, "") ) myDesktop->putInfo(tr("GEOM_PRP_READY")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //======================================================================= // function : MakeBooleanAndDisplay() // purpose : //======================================================================= void GeometryGUI::MakeBooleanAndDisplay( GEOM::GEOM_Shape_ptr Shape1, GEOM::GEOM_Shape_ptr Shape2, const short operation ) { try { GEOM::GEOM_Shape_ptr result = myComponentGeom->MakeBoolean( Shape1, Shape2, operation ) ; if (result->_is_nil()) { myDesktop->putInfo (tr("GEOM_PRP_NULLSHAPE")) ; return ; } TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, result); Standard_CString type; GetShapeTypeString(S,type); result->NameType( type ); if ( Display( result, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakeSphere() // purpose : //===================================================================================== void GeometryGUI::MakeSphereAndDisplay( const gp_Pnt aCenterPoint, const double aRadius ) { try { if( aRadius <= Precision::Confusion() ) { QAD_MessageBox::warn1 ( QAD_Application::getDesktop(), tr ("GEOM_WRN_WARNING"), tr ("GEOM_WRN_RADIUS_NULL"), tr ("GEOM_BUT_YES") ); return ; } GEOM::GEOM_Shape_ptr result = myComponentGeom->MakeSphere(aCenterPoint.X(),aCenterPoint.Y(),aCenterPoint.Z(), aRadius); result->NameType(tr("GEOM_SPHERE")); if ( Display( result, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakeConeAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeConeAndDisplay( const gp_Pnt BasePoint, const gp_Dir aDir, const double Radius1, const double Radius2, const double aHeight ) { try { if( ( Radius1 <= Precision::Confusion() && Radius2 <= Precision::Confusion() ) || aHeight <= Precision::Confusion() ) return ; GEOM::PointStruct pstruct = myComponentGeom->MakePointStruct( BasePoint.X(), BasePoint.Y(), BasePoint.Z() ) ; GEOM::PointStruct d = myComponentGeom->MakePointStruct( aDir.X(), aDir.Y(), aDir.Z() ) ; GEOM::DirStruct dstruct = myComponentGeom->MakeDirection(d) ; GEOM::GEOM_Shape_var result = myComponentGeom->MakeCone( pstruct, dstruct, Radius1, Radius2, aHeight ) ; if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT")); return ; } result->NameType(tr("GEOM_CONE")); if ( Display( result, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakeCylinderAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeCylinderAndDisplay( const gp_Pnt BasePoint, const gp_Dir aDir, const double Radius, const double aHeight ) { try { if( Radius <= Precision::Confusion() || aHeight <= Precision::Confusion() ) return ; GEOM::PointStruct pstruct = myComponentGeom->MakePointStruct( BasePoint.X(), BasePoint.Y(), BasePoint.Z() ) ; GEOM::PointStruct d = myComponentGeom ->MakePointStruct( aDir.X(), aDir.Y(), aDir.Z() ) ; GEOM::DirStruct dstruct = myComponentGeom->MakeDirection(d) ; GEOM::GEOM_Shape_var result = myComponentGeom->MakeCylinder(pstruct, dstruct, Radius, aHeight) ; if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT")); return ; } result->NameType(tr("GEOM_CYLINDER")); if ( Display( result, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakeTorusAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeTorusAndDisplay( const gp_Pnt BasePoint, const gp_Dir aDir, const double Radius1, const double Radius2 ) { try { if( Radius1 <= Precision::Confusion() || Radius2 <= Precision::Confusion() ) return ; GEOM::PointStruct pstruct = myComponentGeom->MakePointStruct( BasePoint.X(), BasePoint.Y(), BasePoint.Z() ) ; GEOM::PointStruct d = myComponentGeom ->MakePointStruct( aDir.X(), aDir.Y(), aDir.Z() ) ; GEOM::DirStruct dstruct = myComponentGeom->MakeDirection(d) ; GEOM::GEOM_Shape_var result = myComponentGeom->MakeTorus(pstruct, dstruct, Radius1, Radius2) ; if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT")); return ; } result->NameType(tr("GEOM_TORUS")); if ( Display( result, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakePipeAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakePipeAndDisplay( GEOM::GEOM_Shape_ptr aPath, GEOM::GEOM_Shape_ptr aBase ) { try { GEOM::GEOM_Shape_ptr result = myComponentGeom->MakePipe(aPath, aBase); if ( !result->_is_nil() && Display( result, "") ) { TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, result); Standard_CString type; GetShapeTypeString(S,type); result->NameType( type ); myDesktop->putInfo( tr("GEOM_PRP_DONE") ); } else { myDesktop->putInfo(tr("GEOM_PRP_ABORT")); } } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakeFillingAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeFillingAndDisplay( GEOM::GEOM_Shape_ptr SectionShape, const short mindeg, const short maxdeg, const double tol3d, const double tol2d, const short nbiter ) { try { GEOM::GEOM_Shape_ptr result = myComponentGeom->MakeFilling( SectionShape, mindeg, maxdeg, tol3d, tol2d, nbiter ); if (result->_is_nil()) { myDesktop->putInfo (tr("GEOM_PRP_NULLSHAPE")) ; return ; } TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, result); Standard_CString type; GetShapeTypeString(S,type); result->NameType( type ); if ( Display( result, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); return ; } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } //===================================================================================== // function : MakeMirrorAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeMirrorAndDisplay( GEOM::GEOM_Shape_ptr Shape1, GEOM::GEOM_Shape_ptr Shape2 ) { try { GEOM::GEOM_Shape_var result = myComponentGeom->MakeMirrorByPlane( Shape1, Shape2 ); if (result->_is_nil()) { myDesktop->putInfo (tr("GEOM_PRP_NULLSHAPE")) ; return ; } result->NameType( Shape1->NameType() ); if ( Display( result, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakeSewingAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeSewingAndDisplay( GEOM::GEOM_Gen::ListOfIOR& listShapesIOR, const Standard_Real precision ) { try { GEOM::GEOM_Shape_var result = myComponentGeom->MakeSewing(listShapesIOR, precision) ; if( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_NULLSHAPE")) ; return ; } TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, result); Standard_CString type; GetShapeTypeString(S,type); result->NameType( type ); if( Display( result, "") ) myDesktop ->putInfo(tr("GEOM_PRP_DONE")) ; return ; } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } //===================================================================================== // function : MakeCompoundAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeCompoundAndDisplay( GEOM::GEOM_Gen::ListOfIOR& listShapesIOR ) { try { GEOM::GEOM_Shape_var result = myComponentGeom->MakeCompound(listShapesIOR) ; if( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_NULLSHAPE")) ; return ; } result->NameType(tr("GEOM_COMPOUND")); if( Display( result, "" )) myDesktop->putInfo(tr("GEOM_PRP_DONE")) ; } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakeFaceAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeFaceAndDisplay( GEOM::GEOM_Shape_ptr aWire, const Standard_Boolean wantPlanar ) { try { GEOM::GEOM_Shape_var result = myComponentGeom->MakeFace( aWire, wantPlanar) ; if( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_NULLSHAPE")) ; return ; } if ( wantPlanar ) result->NameType(tr("GEOM_PLANE")); else result->NameType(tr("GEOM_FACE")); if( Display( result, "") ) myDesktop ->putInfo(tr("GEOM_PRP_DONE")) ; } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakeLinearEdgeAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeLinearEdgeAndDisplay( const gp_Pnt P1, const gp_Pnt P2 ) { try { GEOM::PointStruct ps1 = myComponentGeom->MakePointStruct( P1.X(), P1.Y(), P1.Z() ) ; GEOM::PointStruct ps2 = myComponentGeom->MakePointStruct( P2.X(), P2.Y(), P2.Z() ) ; GEOM::GEOM_Shape_var result = myComponentGeom->MakeEdge( ps1, ps2 ) ; if( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_NULLSHAPE")) ; return ; } result->NameType(tr("GEOM_EDGE")); if( Display( result, "") ) myDesktop ->putInfo(tr("GEOM_PRP_DONE")) ; } catch(const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakeOrientationChangeAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeOrientationChangeAndDisplay( GEOM::GEOM_Shape_ptr Shape ) { try { GEOM::GEOM_Shape_var result = myComponentGeom->OrientationChange( Shape ) ; if( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_NULLSHAPE")) ; return ; } result->NameType( Shape->NameType() ); if ( Display( result, "" )) myDesktop->putInfo(tr("GEOM_PRP_DONE")); return ; } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } //===================================================================================== // function : MakeScaleAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeScaleAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Pnt centralPoint, const Standard_Real factor ) { try { GEOM::PointStruct P = myComponentGeom->MakePointStruct(centralPoint.X(), centralPoint.Y(), centralPoint.Z() ) ; GEOM::GEOM_Shape_var result = myComponentGeom->MakeScaleTransform(Shape, P, factor) ; // result->NameType(tr("GEOM_SCALE")); result->NameType( Shape->NameType() ); if ( Display( result, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); else myDesktop->putInfo (tr("GEOM_PRP_NULLSHAPE")) ; } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //======================================================================================= // function : MakeRevolutionAndDisplay() // purpose : //======================================================================================= void GeometryGUI::MakeRevolutionAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Pnt loc, const gp_Dir dir, const Standard_Real revolAngle ) { try { GEOM::AxisStruct axis = myComponentGeom->MakeAxisStruct(loc.X(), loc.Y(), loc.Z(), dir.X(), dir.Y(), dir.Z() ) ; GEOM::GEOM_Shape_ptr result = myComponentGeom->MakeRevolution(Shape, axis, revolAngle) ; if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT")); return ; } TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, result); Standard_CString type; GetShapeTypeString(S,type); result->NameType( type ); if ( Display( result ) ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //======================================================================================= // function : MakeRotationAndDisplay() // purpose : //======================================================================================= void GeometryGUI::MakeRotationAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Pnt loc, const gp_Dir dir, const Standard_Real angle ) { try { const GEOM::AxisStruct axis = myComponentGeom->MakeAxisStruct(loc.X(), loc.Y(), loc.Z(), dir.X(), dir.Y(), dir.Z() ) ; GEOM::GEOM_Shape_var result = myComponentGeom->MakeRotation(Shape, axis, angle); if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT") ); return ; } result->NameType( Shape->NameType() ); if ( Display( result ) ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //================================================================================= // function : MakeTranslationAndDisplay() // purpose : Translate a shape //================================================================================= void GeometryGUI::MakeTranslationAndDisplay( GEOM::GEOM_Shape_ptr Shape, gp_Vec V ) { try { GEOM::GEOM_Shape_var result = myComponentGeom->MakeTranslation( Shape, V.X(), V.Y(), V.Z() ) ; if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT") ); return ; } result->NameType( Shape->NameType() ); if ( Display( result ) ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //================================================================================= // function : MakeMultiTranslation1DAndDisplay() // purpose : Multi-Translate a shape //================================================================================= void GeometryGUI::MakeMultiTranslation1DAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Dir Dir, const double Step, const short NbTimes ) { try { GEOM::PointStruct d = myComponentGeom->MakePointStruct( Dir.X(), Dir.Y(), Dir.Z() ) ; GEOM::DirStruct dstruct = myComponentGeom->MakeDirection(d) ; GEOM::GEOM_Shape_var result = myComponentGeom->MakeMultiTranslation1D( Shape, dstruct, Step, NbTimes ); if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT") ); return ; } result->NameType( tr("GEOM_COMPOUND") ); if ( Display( result ) ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //================================================================================= // function : MakeMultiTranslation2DAndDisplay() // purpose : Multi-Translate a shape //================================================================================= void GeometryGUI::MakeMultiTranslation2DAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Dir Dir1, const double Step1, const short NbTimes1, const gp_Dir Dir2, const double Step2, const short NbTimes2 ) { try { GEOM::PointStruct d1 = myComponentGeom->MakePointStruct( Dir1.X(), Dir1.Y(), Dir1.Z() ) ; GEOM::DirStruct dstruct1 = myComponentGeom->MakeDirection(d1) ; GEOM::PointStruct d2 = myComponentGeom->MakePointStruct( Dir2.X(), Dir2.Y(), Dir2.Z() ) ; GEOM::DirStruct dstruct2 = myComponentGeom->MakeDirection(d2) ; GEOM::GEOM_Shape_var result = myComponentGeom->MakeMultiTranslation2D( Shape, dstruct1, Step1, NbTimes1, dstruct2, Step2, NbTimes2 ); if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT") ); return ; } result->NameType( tr("GEOM_COMPOUND") ); if ( Display( result ) ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //================================================================================= // function : MakeMultiRotation1DAndDisplay() // purpose : Multi-Rotate a shape //================================================================================= void GeometryGUI::MakeMultiRotation1DAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Dir Dir, const gp_Pnt Loc, const short NbTimes ) { try { GEOM::PointStruct d = myComponentGeom->MakePointStruct( Dir.X(), Dir.Y(), Dir.Z() ) ; GEOM::DirStruct dstruct = myComponentGeom->MakeDirection(d) ; GEOM::PointStruct pstruct = myComponentGeom->MakePointStruct( Loc.X(), Loc.Y(), Loc.Z() ) ; GEOM::GEOM_Shape_var result = myComponentGeom->MakeMultiRotation1D( Shape, dstruct, pstruct, NbTimes ); if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT") ); return ; } result->NameType( tr("GEOM_COMPOUND") ); if ( Display( result ) ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //================================================================================= // function : MakeMultiRotation2DAndDisplay() // purpose : Multi-Rotate a shape //================================================================================= void GeometryGUI::MakeMultiRotation2DAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Dir Dir, const gp_Pnt Loc, const double Ang, const short NbTimes1, const double Step, const short NbTimes2 ) { try { GEOM::PointStruct d = myComponentGeom->MakePointStruct( Dir.X(), Dir.Y(), Dir.Z() ) ; GEOM::DirStruct dstruct = myComponentGeom->MakeDirection(d) ; GEOM::PointStruct pstruct = myComponentGeom->MakePointStruct( Loc.X(), Loc.Y(), Loc.Z() ) ; GEOM::GEOM_Shape_var result = myComponentGeom->MakeMultiRotation2D( Shape, dstruct, pstruct, Ang, NbTimes1, Step, NbTimes2 ); if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT") ); return ; } result->NameType( tr("GEOM_COMPOUND") ); if ( Display( result ) ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //======================================================================================= // function : MakeArcAndDisplay() // purpose : Make an arc of circle from InitPoint to CirclePoint and passing on EndPoint //======================================================================================= void GeometryGUI::MakeArcAndDisplay( gp_Pnt InitPoint, gp_Pnt CirclePoint, gp_Pnt EndPoint ) { gp_Vec v1( CirclePoint, InitPoint ) ; gp_Vec v2( CirclePoint, EndPoint ) ; if( v1.IsParallel(v2, Precision::Angular() ) ) return ; try { GEOM::PointStruct pI = myComponentGeom->MakePointStruct( InitPoint.X(), InitPoint.Y(), InitPoint.Z() ); GEOM::PointStruct pC = myComponentGeom->MakePointStruct( CirclePoint.X(), CirclePoint.Y(), CirclePoint.Z() ); GEOM::PointStruct pE = myComponentGeom->MakePointStruct( EndPoint.X(), EndPoint.Y(), EndPoint.Z() ); GEOM::GEOM_Shape_var result = myComponentGeom->MakeArc(pI, pC, pE) ; if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT")); return ; } result->NameType(tr("GEOM_ARC")); if ( Display( result ) ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakeCircleAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeCircleAndDisplay( const gp_Pnt CenterPoint, const gp_Dir dir, const Standard_Real Radius ) { try { GEOM::PointStruct pstruct = myComponentGeom->MakePointStruct( CenterPoint.X(), CenterPoint.Y(), CenterPoint.Z() ) ; GEOM::PointStruct d = myComponentGeom->MakePointStruct( dir.X(), dir.Y(), dir.Z() ) ; GEOM::DirStruct dstruct = myComponentGeom->MakeDirection(d) ; GEOM::GEOM_Shape_var result = myComponentGeom->MakeCircle(pstruct, dstruct, Radius) ; if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT") ); return ; } result->NameType(tr("GEOM_CIRCLE")); if ( Display( result ) ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakeWireAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeWireAndDisplay( GEOM::GEOM_Gen::ListOfIOR& listShapesIOR ) { try { GEOM::GEOM_Shape_var result = myComponentGeom->MakeWire(listShapesIOR) ; if( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_NULLSHAPE")) ; return ; } result->NameType(tr("GEOM_WIRE")); if( Display( result, "") ) myDesktop ->putInfo(tr("GEOM_PRP_DONE")) ; } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } //===================================================================================== // function : MakePartitionAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakePartitionAndDisplay (const GEOM::GEOM_Gen::ListOfIOR& listShapesIOR, const GEOM::GEOM_Gen::ListOfIOR& listToolsIOR, const GEOM::GEOM_Gen::ListOfIOR& listKeepInsIOR, const GEOM::GEOM_Gen::ListOfIOR& listRemoveInsIOR, const GEOM::shape_type limit) { try { GEOM::GEOM_Shape_var result = myComponentGeom->Partition(listShapesIOR, listToolsIOR, listKeepInsIOR, listRemoveInsIOR, (CORBA::Short) limit); if( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_NULLSHAPE")) ; return ; } result->NameType(tr("GEOM_PARTITION")); if( Display( result, "") ) myDesktop ->putInfo(tr("GEOM_PRP_DONE")) ; return ; } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } //======================================================================= // function : SetState() // purpose : Sets myState = aState a private field indicating which methode is active //======================================================================= void GeometryGUI::SetState(int aState ) { this->myState = aState ; return ; } //======================================================================= // function : ResetState() // purpose : Sets myState = -1 a private field indicating which methode is active //======================================================================= void GeometryGUI::ResetState() { this->myState = -1 ; return ; } //======================================================================= // function : EmitSignalDeactivateDialog() // purpose : Emit a signal to deactivate the active dialog Box //======================================================================= void GeometryGUI::EmitSignalDeactivateDialog() { emit this->SignalDeactivateActiveDialog() ; return ; } //======================================================================= // function : EmitSignalCloseAllDialogs() // purpose : Emit a signal to deactivate all non modal dialogs box //======================================================================= void GeometryGUI::EmitSignalCloseAllDialogs() { emit this->SignalCloseAllDialogs() ; return ; } //======================================================================= // function : GetActiveDialogBox() // purpose : //======================================================================= QDialog* GeometryGUI::GetActiveDialogBox() { return this->myActiveDialogBox ; } //======================================================================= // function : SetActiveDialogBox() // purpose : //======================================================================= void GeometryGUI::SetActiveDialogBox(QDialog* aDlg) { this->myActiveDialogBox = (QDialog*)aDlg ; return ; } //======================================================================= // function : GetActiveStudy() // purpose : //======================================================================= QAD_Study* GeometryGUI::GetActiveStudy() { return this->myActiveStudy ; } //======================================================================= // function : GetActiveDesktop() // purpose : //======================================================================= QAD_Desktop* GeometryGUI::GetDesktop() { return this->myDesktop ; } //===================================================================================== // function : OnSubShapeGetAll() // purpose : Explode a shape in all sub shapes with a SubShapeType //===================================================================================== bool GeometryGUI::OnSubShapeGetAll(const TopoDS_Shape& ShapeTopo, const char* ShapeTopoIOR, const int SubShapeType) { SALOMEDS::Study_var aStudy = myActiveStudy->getStudyDocument(); SALOMEDS::SObject_var theObj = aStudy->FindObjectIOR( ShapeTopoIOR ); if ( theObj->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_SHAPE_IN_STUDY")); return false ; } SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder(); SALOMEDS::SObject_var fatherSF = aStudy->FindObjectID(myActiveStudy->getActiveStudyFrame()->entry()); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeName_var aName; SALOMEDS::AttributeIOR_var anIOR; SALOMEDS::AttributePixMap_var aPixmap; /* We create a sub object for each sub shape as attribute of the main object */ /* Each sub object contains list (length=1) containing its index in the main shape */ GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( ShapeTopoIOR ); GEOM::GEOM_Gen::ListOfGeomShapes_var listGeomShapes = new GEOM::GEOM_Gen::ListOfGeomShapes; GEOM::GEOM_Shape_var aResult ; try { listGeomShapes = myComponentGeom->SubShapeAll( aShape, SubShapeType ); if( listGeomShapes->length() < 1 ) { myDesktop->putInfo (tr("GEOM_PRP_ABORT")); return false ; } } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } /* open transaction */ QAD_Operation* op = new SALOMEGUI_ImportOperation( myActiveStudy ); op->start(); TopoDS_Shape mainTopo = ShapeReader.GetShape(myComponentGeom, aShape); TopoDS_Shape mainShape; bool main = false; while ( !main ) { if ( aShape->IsMainShape() ) { mainShape = ShapeReader.GetShape(myComponentGeom, aShape); main = true; } else aShape = myComponentGeom->GetIORFromString( aShape->MainName() ); } /* Loop on each sub shape created */ /* int i = 1 ; /* index for the nameType */ for( int j=0; jlength(); j++) { /* Get each sub shape extracted CORBA and OCC */ aResult = listGeomShapes[j] ; TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, aResult); if ( S.IsNull() ) { myDesktop->putInfo (tr("GEOM_PRP_ABORT")); return false; } // NRI : Following lines are commented according to bugID SAL695 (see history) // BRepCheck_Analyzer anAnalyzer(S); // if(!anAnalyzer.IsValid()) { // myDesktop->putInfo (tr("GEOM_PRP_ABORT")); // MESSAGE("#### An exploded shape number "<< j << " is not valid"); // op->abort(); // return false; // } /* Set the nameType of sub shape */ char* nameG = (char *)malloc(20); Standard_CString Type; if ( GetShapeTypeString(S, Type) ) { aResult->NameType( Type ); sprintf (nameG, "%s_%d", Type, GetIndex( S, mainShape, SubShapeType ) ); } else { aResult->NameType( tr("GEOM_SHAPE") ); sprintf (nameG, "%s_%d", tr("GEOM_SHAPE").latin1(), this->myNbGeom++ ); } SALOMEDS::SObject_var SO = aStudy->FindObjectIOR( aResult->Name() ); bool allreadyexist = false; if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); Handle(GEOM_AISShape) result = new GEOM_AISShape( S, nameG ); Handle(GEOM_InteractiveObject) IO = new GEOM_InteractiveObject(aResult->Name(), Fatherior, "GEOM"); MESSAGE ( "SO->_is_nil() " << SO->_is_nil() ) if ( SO->_is_nil() ) { SALOMEDS::SObject_var newObj = aStudyBuilder->NewObject( theObj ); anAttr = aStudyBuilder->FindOrCreateAttribute(newObj, "AttributeName"); aName = SALOMEDS::AttributeName::_narrow(anAttr); aName->SetValue(nameG); anAttr = aStudyBuilder->FindOrCreateAttribute(newObj, "AttributeIOR"); anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); anIOR->SetValue(aResult->Name()); anAttr = aStudyBuilder->FindOrCreateAttribute(newObj, "AttributePixMap"); aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr); MESSAGE( " Type " << S.ShapeType() ) if ( S.ShapeType() == TopAbs_COMPOUND ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_COMPOUND" ); } else if ( S.ShapeType() == TopAbs_COMPSOLID ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_COMPSOLID" ); } else if ( S.ShapeType() == TopAbs_SOLID ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_SOLID" ); } else if ( S.ShapeType() == TopAbs_SHELL ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_SHELL" ); } else if ( S.ShapeType() == TopAbs_FACE ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_FACE" ); } else if ( S.ShapeType() == TopAbs_WIRE ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_WIRE" ); } else if ( S.ShapeType() == TopAbs_EDGE ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_EDGE" ); } else if ( S.ShapeType() == TopAbs_VERTEX ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_VERTEX" ); } MESSAGE ( " aPixmap->GetPixMap " << aPixmap->GetPixMap() ) SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(fatherSF); aStudyBuilder->Addreference(newObj1, newObj); IO->setEntry(newObj->GetID()); aResult->StudyShapeId( newObj->GetID() ); } else { allreadyexist = true; if ( ! SObjectExist(theObj, aResult->Name()) ) { SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(theObj); aStudyBuilder->Addreference(newObj1, SO); IO->setEntry(SO->GetID()); aResult->StudyShapeId( SO->GetID() ); } } result->setIO( IO ); result->setName( nameG ); if ( !allreadyexist ) ic->Display(result); } else if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { VTKViewer_RenderWindowInteractor* myRenderInter= ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor(); int themode = myRenderInter->GetDisplayMode(); vtkRenderer *theRenderer = ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRenderer(); vtkRenderWindow *renWin = theRenderer->GetRenderWindow(); Handle(GEOM_InteractiveObject) IO = new GEOM_InteractiveObject(aResult->Name(), Fatherior,"GEOM"); if ( SO->_is_nil() ) { SALOMEDS::SObject_var newObj = aStudyBuilder->NewObject( theObj ); anAttr = aStudyBuilder->FindOrCreateAttribute(newObj, "AttributeIOR"); anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); anIOR->SetValue(aResult->Name()); anAttr = aStudyBuilder->FindOrCreateAttribute(newObj, "AttributeName"); aName = SALOMEDS::AttributeName::_narrow(anAttr); aName->SetValue(nameG); anAttr = aStudyBuilder->FindOrCreateAttribute(newObj, "AttributePixMap"); aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr); if ( S.ShapeType() == TopAbs_COMPOUND ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_COMPOUND" ); } else if ( S.ShapeType() == TopAbs_COMPSOLID ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_COMPSOLID" ); } else if ( S.ShapeType() == TopAbs_SOLID ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_SOLID" ); } else if ( S.ShapeType() == TopAbs_SHELL ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_SHELL" ); } else if ( S.ShapeType() == TopAbs_FACE ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_FACE" ); } else if ( S.ShapeType() == TopAbs_WIRE ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_WIRE" ); } else if ( S.ShapeType() == TopAbs_EDGE ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_EDGE" ); } else if ( S.ShapeType() == TopAbs_VERTEX ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_VERTEX" ); } SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(fatherSF); aStudyBuilder->Addreference(newObj1, newObj); IO->setEntry(newObj->GetID()); } else { allreadyexist = true; if ( ! SObjectExist(theObj, aResult->Name()) ) { SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(theObj); aStudyBuilder->Addreference(newObj1, SO); IO->setEntry(SO->GetID()); } } if ( !allreadyexist ) { vtkActorCollection* theActors = GEOM_AssemblyBuilder::BuildActors(S,0,themode,Standard_True); theActors->InitTraversal(); vtkActor* anActor = (vtkActor*)theActors->GetNextActor(); while(!(anActor==NULL)) { GEOM_Actor* GActor = GEOM_Actor::SafeDownCast( anActor ); GActor->setIO( IO ); GActor->setName( nameG ); theRenderer->AddActor(GActor); renWin->Render(); anActor = (vtkActor*)theActors->GetNextActor(); } } } } /* commit transaction */ op->finish(); myActiveStudy->updateObjBrowser(); myDesktop->putInfo (tr("GEOM_PRP_READY")); return true ; } //===================================================================================== // function : GetIndexSubShapeSelected() // purpose : Define a ListOfID of sub shapes selected in ShapeTopo with SubShapeType // : Method used by Dialogs //===================================================================================== bool GeometryGUI::GetIndexSubShapeSelected( const TopoDS_Shape& ShapeTopo, const int SubShapeType, GEOM::GEOM_Shape::ListOfSubShapeID& ListOfID, Standard_Integer& aLocalContextId, bool& myUseLocalContext ) { //* Test the type of viewer */ if ( this->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) { return false; } OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)this->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); ic->InitSelected(); int nbSelected = ic->NbSelected(); ListOfID.length(nbSelected); //***************** DEFINE INDEX OF EACH SELECTION *********************// int i = 0 ; ic->InitSelected(); /* to restart */ while( ic->MoreSelected() ) { /* Find index of sub shape into main shape */ TopExp_Explorer Exp ( ShapeTopo, TopAbs_ShapeEnum(SubShapeType) ); int index = 1; bool found = false ; while ( Exp.More() ) { if ( (Exp.Current()).IsSame( ic->SelectedShape()) ) { found = true ; break; } index++; Exp.Next(); } if( !found ) { /* Manage local context from DialogBox */ ic->CloseLocalContext(aLocalContextId) ; myUseLocalContext = false ; return false ; } ListOfID[i] = index ; i++; ic->NextSelected(); } //***************** END *********************// /* Manage local context from DialogBox */ ic->CloseLocalContext(aLocalContextId) ; myUseLocalContext = false ; return true ; } //===================================================================================== // function : OnSubShapeGetSelected() // purpose : //===================================================================================== bool GeometryGUI::OnSubShapeGetSelected( const TopoDS_Shape& ShapeTopo, const char* ShapeTopoIOR, const int SubShapeType, Standard_Integer& aLocalContextId, bool& myUseLocalContext ) { //* Test the type of viewer */ if ( this->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) { return false; } SALOMEDS::Study_var aStudy = myActiveStudy->getStudyDocument(); SALOMEDS::SObject_var theObj = aStudy->FindObjectIOR( ShapeTopoIOR ); if ( theObj->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_SHAPE_IN_STUDY")); return false ; } OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); if( myUseLocalContext == false ) { /* local context is from DialogBox */ MESSAGE("Error : No local context opened for sub shapes method" << endl ) ; return false ; } GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( ShapeTopoIOR ); TopoDS_Shape mainTopo = ShapeReader.GetShape(myComponentGeom, aShape); TopoDS_Shape mainShape; bool main = false; while ( !main ) { if ( aShape->IsMainShape() ) { mainShape = ShapeReader.GetShape(myComponentGeom, aShape); main = true; } else aShape = myComponentGeom->GetIORFromString( aShape->MainName() ); } GEOM::GEOM_Shape::ListOfSubShapeID_var ListOfID = new GEOM::GEOM_Shape::ListOfSubShapeID; ic->InitSelected(); int nbSelected = ic->NbSelected(); ListOfID->length(nbSelected); TopoDS_Compound compound; ic->InitSelected(); /* to init again */ BRep_Builder B; B.MakeCompound( compound ); int i = 0; /* We create a unique compound containing all the sub shapes selected by user as attribute of the main shape */ /* the compound is homogenous by selection */ while(ic->MoreSelected()) { int index = GetIndex( ic->SelectedShape(), mainShape, SubShapeType ); ListOfID[i] = index ; B.Add( compound, ic->SelectedShape() ); i++; ic->NextSelected(); } /* Test if user has selected sub shapes */ if( ListOfID->length() < 1 ) return false ; GEOM::GEOM_Shape_var aResult ; try { aResult = myComponentGeom->SubShape( aShape, SubShapeType, ListOfID ); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } /* local context from DialogBox */ ic->CloseLocalContext(aLocalContextId) ; myUseLocalContext = false ; char* nameG = (char *)malloc(20); Standard_CString Type; Handle(GEOM_AISShape) result; Handle(GEOM_InteractiveObject) IO ; // if ( ! SObjectExist(theObj, aResult->Name()) ) { if ( nbSelected == 1 ) { TopExp_Explorer Exp ( compound, TopAbs_ShapeEnum(SubShapeType) ); if ( Exp.More() ) { if ( GetShapeTypeString(Exp.Current(),Type) ) { aResult->NameType( Type ); sprintf (nameG, "%s_%d", Type, GetIndex( Exp.Current(), mainTopo, SubShapeType ) ); } else { aResult->NameType( tr("GEOM_SHAPE") ); sprintf (nameG, "%s_%d", tr("GEOM_SHAPE").latin1(), this->myNbGeom++ ); } result = new GEOM_AISShape( Exp.Current(), nameG ); IO = new GEOM_InteractiveObject(aResult->Name(), Fatherior, "GEOM"); } } else { if ( GetShapeTypeString(compound,Type) ) { aResult->NameType( Type ); sprintf (nameG, "%s_%d", Type, this->myNbGeom++ ); } else { aResult->NameType( tr("GEOM_SHAPE") ); sprintf (nameG, "%s_%d", tr("GEOM_SHAPE").latin1(), this->myNbGeom++ ); } result = new GEOM_AISShape( compound, nameG ); IO = new GEOM_InteractiveObject(aResult->Name(), Fatherior, "GEOM"); } SALOMEDS::SObject_var SO = aStudy->FindObjectIOR( aResult->Name() ); /* open transaction */ QAD_Operation* op = new SALOMEGUI_ImportOperation( myActiveStudy ); op->start(); SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder(); SALOMEDS::SObject_var fatherSF = aStudy->FindObjectID(myActiveStudy->getActiveStudyFrame()->entry()); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeName_var aName; SALOMEDS::AttributeIOR_var anIOR; SALOMEDS::AttributePixMap_var aPixmap; bool allreadyexist = false; if ( SO->_is_nil() ) { SALOMEDS::SObject_var newObj = aStudyBuilder->NewObject( theObj ); anAttr = aStudyBuilder->FindOrCreateAttribute(newObj, "AttributeIOR"); anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); anIOR->SetValue(aResult->Name()); anAttr = aStudyBuilder->FindOrCreateAttribute(newObj, "AttributeName"); aName = SALOMEDS::AttributeName::_narrow(anAttr); aName->SetValue(result->getName()); anAttr = aStudyBuilder->FindOrCreateAttribute(newObj, "AttributePixMap"); aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr); if ( result->Shape().ShapeType() == TopAbs_COMPOUND ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_COMPOUND" ); } else if ( result->Shape().ShapeType() == TopAbs_COMPSOLID ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_COMPSOLID" ); } else if ( result->Shape().ShapeType() == TopAbs_SOLID ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_SOLID" ); } else if ( result->Shape().ShapeType() == TopAbs_SHELL ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_SHELL" ); } else if ( result->Shape().ShapeType() == TopAbs_FACE ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_FACE" ); } else if ( result->Shape().ShapeType() == TopAbs_WIRE ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_WIRE" ); } else if ( result->Shape().ShapeType() == TopAbs_EDGE ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_EDGE" ); } else if ( result->Shape().ShapeType() == TopAbs_VERTEX ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_VERTEX" ); } SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(fatherSF); aStudyBuilder->Addreference(newObj1, newObj); IO->setEntry(newObj->GetID()); aResult->StudyShapeId(newObj->GetID()); } else { allreadyexist = true; if ( ! SObjectExist(theObj, aResult->Name()) ) { SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(theObj); aStudyBuilder->Addreference(newObj1, SO); IO->setEntry(SO->GetID()); aResult->StudyShapeId(SO->GetID()); } } /* commit transaction */ op->finish(); result->setIO( IO ); result->setName( nameG ); if ( !allreadyexist ) ic->Display(result); this->OnDisplayAll(true); myActiveStudy->updateObjBrowser(); myDesktop->putInfo (tr("GEOM_PRP_READY")); return true ; } //===================================================================================== // function : OnSuppressFaces() // purpose : To suppress faces from a shape // : The result is one or more shells/faces as main shapes ! //===================================================================================== bool GeometryGUI::OnSuppressFaces( const TopoDS_Shape& ShapeTopo, const char* ShapeTopoIOR, const Standard_Integer& aLocalContextId, bool& myUseLocalContext ) { /* Test the type of viewer */ if ( this->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) { return false; } SALOMEDS::Study_var aStudy = myActiveStudy->getStudyDocument(); SALOMEDS::SObject_var theObj = aStudy->FindObjectIOR( ShapeTopoIOR ); if ( theObj->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_SHAPE_IN_STUDY")); return false ; } OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); if( myUseLocalContext == false ) { /* local context is from DialogBox */ MESSAGE("Error : No local context opened for suppress faces method" << endl ) ; return false ; } GEOM::GEOM_Shape::ListOfSubShapeID_var ListOfID = new GEOM::GEOM_Shape::ListOfSubShapeID; ic->InitSelected(); int nbSelected = ic->NbSelected(); ListOfID->length(nbSelected); /* Create a list of indices of faces to be suppressed */ int i = 0; const int SubShapeType = 4 ; /* GEOM::FACE type */ ic->InitSelected(); /* to repositioning at beginning */ while( ic->MoreSelected() ) { int index = GetIndex( ic->SelectedShape(), ShapeTopo, SubShapeType ); ListOfID[i] = index ; i++; ic->NextSelected(); } /* Close local context opened in DialogBox */ ic->CloseLocalContext(aLocalContextId) ; myUseLocalContext = false ; /* Here is the main shape */ GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( ShapeTopoIOR ); GEOM::GEOM_Gen::ListOfGeomShapes_var listGeomShapes = new GEOM::GEOM_Gen::ListOfGeomShapes; /* Call geom method that return a list of shells/faces as result of suppress */ try { listGeomShapes = myComponentGeom->SuppressFaces( aShape, ListOfID ); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } /* Test list of shells/faces */ if( listGeomShapes->length() < 1 ) { return false ; } /* Loop on each object created */ for( int i=0; ilength(); i++ ) { GEOM::GEOM_Shape_var aShellOrFace = listGeomShapes[i] ; TopoDS_Shape S = ShapeReader.GetShape( this->myComponentGeom, aShellOrFace ); if( S.IsNull() ) { return false ; } char* nameG = (char *)malloc(20); Standard_CString Type; if ( GetShapeTypeString(S, Type) ) { aShellOrFace->NameType( Type ); sprintf (nameG, "%s_%d", Type, this->myNbGeom++); } else { aShellOrFace->NameType( tr("GEOM_SHAPE") ); sprintf (nameG, "%s_%d", tr("GEOM_SHAPE").latin1(), this->myNbGeom++ ); } /* Display with name */ if( !Display( aShellOrFace, nameG) ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT")); return false ; } } myDesktop->putInfo (tr("GEOM_PRP_READY")); return true ; } //===================================================================================== // function : OnSuppressHole() // purpose : To suppress an hole on a shape 'ShapeTopo'. // : 'ListOfIdEndFace' may be an empty list. // : This means that hole do not traverse ShapeTopo. // : Warning : the hole to be suppressed must be defined by one or two single closed wires ! //===================================================================================== bool GeometryGUI::OnSuppressHole( const char* ShapeTopoIOR, const GEOM::GEOM_Shape::ListOfSubShapeID& ListOfIdFace, const GEOM::GEOM_Shape::ListOfSubShapeID& ListOfIdWire, const GEOM::GEOM_Shape::ListOfSubShapeID& ListOfIdEndFace ) { /* Test the type of viewer */ if ( this->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) { return false; } try { GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( ShapeTopoIOR ); GEOM::GEOM_Shape_var aResult = myComponentGeom->SuppressHole( aShape, ListOfIdFace, ListOfIdWire, ListOfIdEndFace ) ; TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, aResult); Standard_CString type; GetShapeTypeString(S,type); aResult->NameType( type ); if ( Display( aResult, "" ) ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return true ; } //===================================================================================== // function : OnSuppressHolesInFaceOrShell() // purpose : To suppress one or more holes on a face // : 'ListOfIdWires' contains indices or wires/holes. //===================================================================================== bool GeometryGUI::OnSuppressHolesInFaceOrShell( const char* ShapeTopoIOR, const GEOM::GEOM_Shape::ListOfSubShapeID& ListOfIdWires ) { /* Test the type of viewer */ if ( this->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) { return false; } try { GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( ShapeTopoIOR ); GEOM::GEOM_Shape_var aResult = myComponentGeom->SuppressHolesInFaceOrShell( aShape, ListOfIdWires ) ; TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, aResult); Standard_CString type; GetShapeTypeString(S,type); aResult->NameType( type ); if ( Display( aResult, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return true ; } //======================================================================= // function : activeStudyChanged() // purpose : static //======================================================================= void GeometryGUI::activeStudyChanged( QAD_Desktop* parent ) { MESSAGE ("GeometryGUI::activeStudyChanged init.") /* Create or retrieve an object GeomGUI */ GeometryGUI::GetOrCreateGeometryGUI(parent); if(GeomGUI != 0) { if (GeomGUI->myState == CURRENT_SKETCH) { GeomGUI->mySketcher.Clear(); GeomGUI->ResetState(); } QMenuBar* Mb = GeomGUI->myDesktop->getMainMenuBar(); bool ViewOCC = false; if ( GeomGUI->myDesktop->getActiveStudy()->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) ViewOCC = true; Mb->setItemEnabled( 312, ViewOCC); //Sketch Mb->setItemEnabled( 309, ViewOCC); //SuppressFace Mb->setItemEnabled( 314, ViewOCC); //SuppressHole Mb->setItemEnabled( 703, ViewOCC);// ShadingColor Settings Mb->setItemEnabled( 704, ViewOCC);// Isos Settings GeomGUI->EraseSimulationShape() ; GeomGUI->EmitSignalCloseAllDialogs() ; GeomGUI = 0 ; } // GeomGUI->SetSettings( parent ); // MESSAGE ("GeometryGUI::activeStudyChanged done.") return ; } //======================================================================= // function : DefineDlgPosition() // purpose : Define x and y the default position for a dialog box //======================================================================= bool GeometryGUI::DefineDlgPosition(QWidget* aDlg, int& x, int& y) { /* Here the position is on the bottom right corner - 10 */ QAD_Desktop* PP = QAD_Application::getDesktop() ; x = abs ( PP->x() + PP->size().width() - aDlg->size().width() - 10 ) ; y = abs ( PP->y() + PP->size().height() - aDlg->size().height() - 10 ) ; return true ; } //======================================================================= // function : OnGUIEvent() [static] // purpose : manage all events on GUI //======================================================================= bool GeometryGUI::OnGUIEvent(int theCommandID, QAD_Desktop* parent) { /* Create or retrieve an object GeomGUI */ GeometryGUI::GetOrCreateGeometryGUI(parent); SALOMEDS::Study_var aStudy = GeomGUI->myActiveStudy->getStudyDocument(); SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder(); OCCViewer_Viewer3d* v3d; Handle(AIS_InteractiveContext) ic; vtkRenderer* Renderer; QMenuBar* Mb = GeomGUI->myDesktop->getMainMenuBar(); bool ViewOCC = false; if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { v3d = ((OCCViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); ic = v3d->getAISContext(); ViewOCC = true; Mb->setItemEnabled( 312, ViewOCC);//Sketch Mb->setItemEnabled( 309, ViewOCC);//SuppressFace Mb->setItemEnabled( 314, ViewOCC);//SuppressHole Mb->setItemEnabled( 703, ViewOCC);// ShadingColor Settings Mb->setItemEnabled( 704, ViewOCC);// Isos Settings } else if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { Renderer = ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRenderer(); // OnSuppressFaces, OnSuppressHole, SETTINGS - SHADING COLOR, SETTINGS - ISOS, SETTINGS : STEP VALUE FOR SPIN BOXES, SKETCHER, ISOS - POPUP VIEWER, Mb->setItemEnabled( 312, ViewOCC);//Sketch Mb->setItemEnabled( 309, ViewOCC);//SuppressFace Mb->setItemEnabled( 314, ViewOCC);//SuppressHole Mb->setItemEnabled( 703, ViewOCC);// ShadingColor Settings Mb->setItemEnabled( 704, ViewOCC);// Isos Settings } else { return 0; } if (GeomGUI->myState == CURRENT_SKETCH && theCommandID != 10000 && theCommandID != 10001 && theCommandID != 10002 && theCommandID != 10003 && theCommandID != 10004 && theCommandID != 10006 && theCommandID != 10007 && theCommandID != 10008 && theCommandID != 10010 && theCommandID != 10011 && theCommandID != 10012 && theCommandID != 10013 && theCommandID != 10014 && theCommandID != 3133 && theCommandID != 3134) return false; switch (theCommandID) { case 31: // COPY GeomGUI->OnEditCopy(); break; case 33: // DELETE GeomGUI->OnEditDelete(); break; case 111: { GeomGUI->SetState(111); GeomGUI->Import(); GeomGUI->ResetState(); break; } case 112: { GeomGUI->SetState(112); GeomGUI->Import(); GeomGUI->ResetState(); break; } case 113: // IMPORT STEP { GeomGUI->SetState(113); GeomGUI->Import(); GeomGUI->ResetState(); break; } case 121: // EXPORT BREP { GeomGUI->SetState(121); GeomGUI->Export(); GeomGUI->ResetState(); break; } case 122: // EXPORT IGES { GeomGUI->SetState(122); GeomGUI->Export(); GeomGUI->ResetState(); break; } case 123: // EXPORT STEP { GeomGUI->SetState(123); GeomGUI->Export(); GeomGUI->ResetState(); break; } case 303: // EXPLODE : use ic { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_SubShapeDlg *aDlg = new GeometryGUI_SubShapeDlg( parent, "", Sel, ic ) ; break ; } case 304: // GEOM::EDGE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_EdgeDlg *aDlg = new GeometryGUI_EdgeDlg( parent, "", Sel ) ; break ; } case 305: // GEOM::WIRE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_WireDlg *aDlg = new GeometryGUI_WireDlg( parent, "", Sel ) ; break ; } case 306: // GEOM::FACE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_FaceDlg *aDlg = new GeometryGUI_FaceDlg ( parent, "", Sel ) ; break ; } case 308: // GEOM::COMPOUND { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_CompoundDlg *aDlg = new GeometryGUI_CompoundDlg ( parent, "", Sel ) ; break ; } case 309: // SUPPRESS FACES : use ic { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_SuppressFacesDlg *aDlg = new GeometryGUI_SuppressFacesDlg( parent, "", Sel, ic ) ; break ; } case 314: // SUPPRESS HOLES : use ic { if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_SuppressHoleDlg *aDlg = new GeometryGUI_SuppressHoleDlg( parent, "", Sel, ic ) ; } else { GeomGUI->myDesktop->putInfo( tr("GEOM_PRP_NOT_FOR_VTK_VIEWER") ) ; } break ; } case 501: // SEWING { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_SewingDlg *aDlg = new GeometryGUI_SewingDlg ( parent, "", Sel ) ; break ; } case 502: // ORIENTATION { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_OrientationDlg *aDlg = new GeometryGUI_OrientationDlg( parent, "", Sel ) ; break ; } case 601: // PROPERTIES (Length, surface, volume) { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_PropertiesDlg *aDlg = new GeometryGUI_PropertiesDlg( parent, "", Sel ) ; break ; } case 604: // CDG : Center of mass { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_CenterMassDlg *aDlg = new GeometryGUI_CenterMassDlg ( parent, "", Sel ) ; break ; } case 605: // INERTIA { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_InertiaDlg *aDlg = new GeometryGUI_InertiaDlg( parent, "", Sel ) ; break ; } case 607: // MAXTOLERANCE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_MaxToleranceDlg *aDlg = new GeometryGUI_MaxToleranceDlg( parent, "", Sel ) ; break ; } case 608: // WHATIS { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_WhatisDlg *aDlg = new GeometryGUI_WhatisDlg( parent, "", Sel ) ; break ; } case 609: // CHECKSHAPE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_CheckShape *aDlg = new GeometryGUI_CheckShape( parent, "", Sel ) ; break ; } case 701: // SETTINGS - COPY { QMenuData* pp; QMenuItem* item = parent->menuBar()->findItem(701,&pp); bool check = !pp->isItemChecked(701); pp->setItemChecked(701,check); Settings_Copy = check; QAD_CONFIG->addSetting( "Geometry:SettingsCopy", Settings_Copy ); break; } case 702: // SETTINGS - ADD IN STUDY { QMenuData* pp; QMenuItem* item = parent->menuBar()->findItem(702,&pp); bool check = !pp->isItemChecked(702); pp->setItemChecked(702,check); Settings_AddInStudy = check; QAD_CONFIG->addSetting( "Geometry:SettingsAddInStudy", Settings_AddInStudy ); break; } case 703: // SETTINGS - SHADING COLOR { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) break; QString SCr = QAD_CONFIG->getSetting("Geometry:SettingsShadingColorRed"); QString SCg = QAD_CONFIG->getSetting("Geometry:SettingsShadingColorGreen"); QString SCb = QAD_CONFIG->getSetting("Geometry:SettingsShadingColorBlue"); QColor color; if( !SCr.isEmpty() && !SCg.isEmpty() && !SCb.isEmpty() ) { color = QColor (SCr.toInt(), SCg.toInt(), SCb.toInt()); } else { Quantity_Color Default = Quantity_Color(); color = QColor ( (int)Default.Red() * 255.0, (int)Default.Green()* 255.0, (int)Default.Blue() * 255.0 ); } QColor c = QColorDialog::getColor( color, QAD_Application::getDesktop() ); if ( c.isValid() ) { GeomGUI->myShadingColor = Quantity_Color(c.red() / 255.0, c.green()/ 255.0, c.blue() / 255.0, Quantity_TOC_RGB); AIS_ListOfInteractive List; ic->DisplayedObjects(List); AIS_ListOfInteractive List1; ic->ObjectsInCollector(List1); List.Append(List1); AIS_ListIteratorOfListOfInteractive ite(List); while (ite.More()) { if (ite.Value()->IsInstance(STANDARD_TYPE(GEOM_AISShape))) { Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast(ite.Value()); aSh->SetShadingColor( GeomGUI->myShadingColor ); ic->Redisplay( aSh, Standard_True, Standard_True); } ite.Next(); } ic->UpdateCurrentViewer(); QAD_CONFIG->addSetting("Geometry:SettingsShadingColorRed", c.red() ); QAD_CONFIG->addSetting("Geometry:SettingsShadingColorGreen", c.green() ); QAD_CONFIG->addSetting("Geometry:SettingsShadingColorBlue", c.blue() ); } break; } case 704: // SETTINGS - ISOS { if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) break; QString IsoU = QAD_CONFIG->getSetting("Geometry:SettingsIsoU"); QString IsoV = QAD_CONFIG->getSetting("Geometry:SettingsIsoV"); if ( !IsoU.isEmpty() ) ic->DefaultDrawer()->UIsoAspect()->SetNumber(IsoU.toInt()); else IsoU = "1"; if ( !IsoV.isEmpty() ) ic->DefaultDrawer()->VIsoAspect()->SetNumber(IsoV.toInt()); else IsoV = "1"; GeometryGUI_NbIsosDlg * NbIsosDlg = new GeometryGUI_NbIsosDlg( QAD_Application::getDesktop(), tr("GEOM_MEN_ISOS"), TRUE ); int UIso = IsoU.toInt(); int VIso = IsoV.toInt(); NbIsosDlg->SpinBoxU->setValue(UIso) ; NbIsosDlg->SpinBoxV->setValue(VIso) ; if ( NbIsosDlg->exec() ) { UIso = NbIsosDlg->SpinBoxU->text().toInt() ; VIso = NbIsosDlg->SpinBoxV->text().toInt() ; ic->DefaultDrawer()->UIsoAspect()->SetNumber(UIso); ic->DefaultDrawer()->VIsoAspect()->SetNumber(VIso); QAD_CONFIG->addSetting( "Geometry:SettingsIsoU", NbIsosDlg->SpinBoxU->text() ); /* text format */ QAD_CONFIG->addSetting( "Geometry:SettingsIsoV", NbIsosDlg->SpinBoxV->text() ); /* text format */ } AIS_ListOfInteractive List; ic->DisplayedObjects(List); AIS_ListOfInteractive List1; ic->ObjectsInCollector(List1); List.Append(List1); AIS_ListIteratorOfListOfInteractive ite(List); ic->InitCurrent(); if ( ic->NbCurrents() ) while (ite.More()) { if (ite.Value()->IsInstance(STANDARD_TYPE(GEOM_AISShape))) { Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast(ite.Value()); Handle (AIS_Drawer) CurDrawer; CurDrawer = aSh->Attributes(); CurDrawer->UIsoAspect()->SetNumber( UIso ); CurDrawer->VIsoAspect()->SetNumber( VIso ); ic->SetLocalAttributes(aSh, CurDrawer); ic->Redisplay(aSh); } ite.Next(); } ic->UpdateCurrentViewer(); break; } case 705: // SETTINGS : STEP VALUE FOR SPIN BOXES { //NRI if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) //NRI break; QString step = QAD_CONFIG->getSetting( "Geometry:SettingsGeomStep" ); if( step.isEmpty() ) step = "100.0" ; Standard_Boolean res = false ; double dd = Parameter( res, QString("%1").arg(step), tr("GEOM_MEN_STEP_LABEL"), tr("GEOM_STEP_TITLE"), 0.001, 10000.0, 3 ) ; if( res ) { QAD_CONFIG->addSetting( "Geometry:SettingsGeomStep", QString("%1").arg(dd) ) ; /* Emit signal to GeometryGUI_SpinBoxes */ GeomGUI->SignalDefaultStepValueChanged( dd ) ; } else parent->putInfo(tr("GEOM_PRP_ABORT")); break ; } case 801: // ADD IN STUDY - POPUP VIEWER { SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); const SALOME_ListIO& ListSelected = Sel->StoredIObjects(); SALOME_ListIteratorOfListIO It( ListSelected ); for ( ; It.More(); It.Next() ) { Handle(SALOME_InteractiveObject) IObject = It.Value(); GeomGUI->AddInStudy(true, IObject); } /* Is set on the dialog box */ QApplication::restoreOverrideCursor(); break; } case 901: // RENAME { SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); for ( ; It.More(); It.Next() ) { Handle(SALOME_InteractiveObject) IObject = It.Value(); SALOMEDS::SObject_var obj = aStudy->FindObjectID( IObject->getEntry() ); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeName_var aName; if ( !obj->_is_nil() ) { if (obj->FindAttribute(anAttr, "AttributeName")) { aName = SALOMEDS::AttributeName::_narrow(anAttr); QString nm = QString( aName->Value() ); nm = SALOMEGUI_NameDlg::getName( QAD_Application::getDesktop(), nm ); if ( !nm.isEmpty() ) { QApplication::setOverrideCursor( Qt::waitCursor ); GeomGUI->myActiveStudy->renameIObject( IObject, nm ); QApplication::restoreOverrideCursor(); } } } } break; } case 903: // DISPLAY OBJECT BROWSER { if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { // VTK QApplication::setOverrideCursor( Qt::waitCursor ); SALOMEDS::SObject_var fatherSF = aStudy->FindObjectID(GeomGUI->myActiveStudy->getActiveStudyFrame()->entry()); SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); for(;It.More();It.Next()) { Handle(SALOME_InteractiveObject) IObject = It.Value(); SALOMEDS::SObject_var obj = aStudy->FindObjectID( IObject->getEntry() ); VTKViewer_RenderWindowInteractor* myRenderInter= ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor(); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeName_var aName; SALOMEDS::AttributeIOR_var anIOR; if(myRenderInter->isInViewer(IObject)) { myRenderInter->Display(IObject); } else { // Create new actor if ( !obj->_is_nil() ) { if ( obj->FindAttribute(anAttr, "AttributeIOR")) { // this SObject may be GEOM module root SObject SALOMEDS::ChildIterator_var anIter = GeomGUI->myActiveStudy->getStudyDocument()->NewChildIterator(obj); bool useSubItems = false; while (anIter->More() && !useSubItems) { SALOMEDS::SObject_var subobj = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttr; if (subobj->FindAttribute(aTmpAttr, "AttributeIOR")) { anAttr = aTmpAttr; obj = subobj; useSubItems = true; } else anIter->Next(); } while(useSubItems?anIter->More():!anAttr->_is_nil()) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); GEOM::GEOM_Shape_var aShape = GeomGUI->myComponentGeom->GetIORFromString(anIOR->Value()); TopoDS_Shape Shape = ShapeReader.GetShape(GeomGUI->myComponentGeom,aShape); if (obj->FindAttribute(anAttr, "AttributeName")) { aName = SALOMEDS::AttributeName::_narrow(anAttr); vtkRenderer* theRenderer = ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRenderer(); vtkActorCollection* theAllActors = theRenderer->GetActors(); theAllActors->InitTraversal(); vtkActor* actor = (vtkActor*)theAllActors->GetNextActor(); Handle(SALOME_InteractiveObject) anIObj; // don't create new study object if it already exists bool isDisplayed = false; while(!(actor==NULL)) { SALOME_Actor* Gactor = SALOME_Actor::SafeDownCast(actor); if (Gactor!=NULL) { if (Gactor->hasIO()) { if (strcmp(Gactor->getIO()->getEntry(),obj->GetID())==0) { isDisplayed = true; anIObj = Gactor->getIO(); if (!anIObj.IsNull()) myRenderInter->Display(anIObj); } } } actor=(vtkActor*)(theAllActors->GetNextActor()); } if (!isDisplayed) { // open transaction QAD_Operation* op = new SALOMEGUI_ImportOperation( GeomGUI->myActiveStudy ); op->start(); SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(fatherSF); aStudyBuilder->Addreference(newObj1, obj); // commit transaction op->finish(); vtkRenderWindow *renWin = theRenderer->GetRenderWindow(); int themode = myRenderInter->GetDisplayMode(); vtkActorCollection* theActors = GEOM_AssemblyBuilder::BuildActors(Shape,0,themode,Standard_True); theActors->InitTraversal(); vtkActor* anActor = (vtkActor*)theActors->GetNextActor(); while(!(anActor==NULL)) { GEOM_Actor* GActor = GEOM_Actor::SafeDownCast( anActor ); Handle(GEOM_InteractiveObject) IO = new GEOM_InteractiveObject(anIOR->Value(), Fatherior,"GEOM"); IO->setEntry(obj->GetID()); GActor->setIO( IO ); GActor->setName( IObject->getName() ); theRenderer->AddActor(GActor); renWin->Render(); anActor = (vtkActor*)theActors->GetNextActor(); } } } // next item iteration if (useSubItems) { anIter->Next(); anAttr = SALOMEDS::GenericAttribute::_nil(); while (anIter->More() && anAttr->_is_nil()) { SALOMEDS::SObject_var subobject = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttribute; if (subobject->FindAttribute(aTmpAttribute, "AttributeIOR")) { anAttr = aTmpAttribute; obj = subobject; } else anIter->Next(); } } else anAttr = SALOMEDS::GenericAttribute::_nil(); } } } } } GeomGUI->myActiveStudy->updateObjBrowser( true ); QApplication::restoreOverrideCursor(); } else if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { QApplication::setOverrideCursor( Qt::waitCursor ); SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); for(;It.More();It.Next()) { Handle(SALOME_InteractiveObject) IObject = It.Value(); SALOMEDS::SObject_var fatherSF = aStudy->FindObjectID( GeomGUI->myActiveStudy->getActiveStudyFrame()->entry()); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeName_var aName; SALOMEDS::AttributeIOR_var anIOR; if ( v3d->isInViewer( IObject, true ) ) { Standard_Boolean found; Handle(GEOM_AISShape) aSh = GeomGUI->ConvertIOinGEOMAISShape( IObject, found, true ); if ( found ) { ic->Display(aSh); ic->AddOrRemoveCurrentObject(aSh, true); } } else { SALOMEDS::SObject_var obj = aStudy->FindObjectID( IObject->getEntry() ); if ( !obj->_is_nil() ) { if ( obj->FindAttribute(anAttr, "AttributeIOR")) { // this SObject may be GEOM module root SObject SALOMEDS::ChildIterator_var anIter = GeomGUI->myActiveStudy->getStudyDocument()->NewChildIterator(obj); bool useSubItems = false; while (anIter->More() && !useSubItems) { SALOMEDS::SObject_var subobj = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttr; if (subobj->FindAttribute(aTmpAttr, "AttributeIOR")) { anAttr = aTmpAttr; obj = subobj; useSubItems = true; } else anIter->Next(); } while(useSubItems?anIter->More():!anAttr->_is_nil()) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); GEOM::GEOM_Shape_var aShape = GeomGUI->myComponentGeom->GetIORFromString(anIOR->Value()); TopoDS_Shape Shape = ShapeReader.GetShape(GeomGUI->myComponentGeom,aShape); if (obj->FindAttribute(anAttr, "AttributeName")) { aName = SALOMEDS::AttributeName::_narrow(anAttr); // searchin for already displayed objects with the same shape AIS_ListOfInteractive aDisplayed; ic->DisplayedObjects(aDisplayed); AIS_ListIteratorOfListOfInteractive anIObjects(aDisplayed); Handle(AIS_Shape) anAISShape; for(;anIObjects.More();anIObjects.Next()) { anAISShape = Handle(AIS_Shape)::DownCast(anIObjects.Value()); if (!anAISShape.IsNull()) { if (anAISShape->Shape().IsSame(Shape)) break; anAISShape.Nullify(); } } if (!anAISShape.IsNull()) { if (!ic->IsDisplayed(anAISShape)) ic->Display(anAISShape); } else { if (!useSubItems) { // open transaction QAD_Operation* op = new SALOMEGUI_ImportOperation( GeomGUI->myActiveStudy ); op->start(); SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(fatherSF); aStudyBuilder->Addreference(newObj1, obj); // commit transaction op->finish(); } Handle(GEOM_AISShape) aSh = new GEOM_AISShape(Shape, aName->Value()); aSh->SetShadingColor( GeomGUI->myShadingColor ); Handle(GEOM_InteractiveObject) IO = new GEOM_InteractiveObject(anIOR->Value(), Fatherior, "GEOM"); IO->setEntry(obj->GetID()); aSh->setIO( IO ); aSh->setName( aName->Value() ); ic->Display (aSh); if (!useSubItems) ic->AddOrRemoveCurrentObject(aSh, true); } } // next item iteration if (useSubItems) { anIter->Next(); anAttr=SALOMEDS::GenericAttribute::_nil(); while (anIter->More() && anAttr->_is_nil()) { SALOMEDS::SObject_var subobject = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttribute; if (subobject->FindAttribute(aTmpAttribute, "AttributeIOR")) { anAttr = aTmpAttribute; obj = subobject; } else anIter->Next(); } } else anAttr = SALOMEDS::GenericAttribute::_nil(); } } } } } GeomGUI->myActiveStudy->updateObjBrowser( true ); QApplication::restoreOverrideCursor(); } break; } case 3011: // POINT { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_PointDlg *aDlg = new GeometryGUI_PointDlg( parent, "", Sel, ic ) ; break; } case 3012: // LINE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_LineDlg *aDlg = new GeometryGUI_LineDlg( parent, "", Sel ) ; break ; } case 3013: // CIRCLE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_CircleDlg *aDlg = new GeometryGUI_CircleDlg( parent, "", Sel ) ; break ; } case 3015: // ARC { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_ArcDlg *aDlg = new GeometryGUI_ArcDlg( parent, "", Sel ) ; break ; } case 3016: // VECTOR { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_VectorDlg *aDlg = new GeometryGUI_VectorDlg( parent, "", Sel ) ; break; } case 3017: // PLANE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_PlaneDlg *aDlg = new GeometryGUI_PlaneDlg( parent, "", Sel ) ; break; } case 3018: // WORKING PLANE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_WorkingPlaneDlg *aDlg = new GeometryGUI_WorkingPlaneDlg( parent, "", Sel ) ; break; } case 312: // SKETCHER { if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC) break; GeomGUI->EmitSignalDeactivateDialog() ; ((OCCViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->onViewTop(); // DCQ : 28/02/2002 GeomGUI->mySketcher = Sketch( v3d->getViewer3d() ); GeomGUI->SetState(CURRENT_SKETCH); QMenuBar* Mb = GeomGUI->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(10010,&pp); GeomGUI->mySketcher.SetParameterVisibility(LENGTH_PARAMETER,pp->isItemChecked(10010)); item = Mb->findItem(10011,&pp); GeomGUI->mySketcher.SetParameterVisibility(ANGLE_PARAMETER,pp->isItemChecked(10011)); item = Mb->findItem(10012,&pp); GeomGUI->mySketcher.SetParameterVisibility(RADIUS_PARAMETER,pp->isItemChecked(10012)); item = Mb->findItem(10013,&pp); GeomGUI->mySketcher.SetParameterVisibility(XVALUE_PARAMETER,pp->isItemChecked(10013)); item = Mb->findItem(10014,&pp); GeomGUI->mySketcher.SetParameterVisibility(YVALUE_PARAMETER,pp->isItemChecked(10014)); GeomGUI->mySketcher.SetTransitionStatus(NOCONSTRAINT); item = Mb->findItem(3133,&pp); pp->setItemChecked(3133,false); item = Mb->findItem(3134,&pp); pp->setItemChecked(3134,false); break; } case 3021: // BOX { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_BoxDlg *aDlg = new GeometryGUI_BoxDlg( parent, "", Sel ) ; break; } case 3022: // CYLINDER { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_CylinderDlg *aDlg = new GeometryGUI_CylinderDlg( parent, "", Sel ) ; break; } case 3023: // SPHERE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_SphereDlg *aDlg = new GeometryGUI_SphereDlg( parent, "", Sel ) ; break; } case 3024: // TORUS { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_TorusDlg *aDlg = new GeometryGUI_TorusDlg( parent, "", Sel ) ; break; } case 3025: // CONE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_ConeDlg *aDlg = new GeometryGUI_ConeDlg( parent, "", Sel ) ; break; } case 3131: { break; } case 3133: // sketcher { QMenuBar* Mb = GeomGUI->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(3133,&pp); pp->setItemChecked(3133,!pp->isItemChecked(3133)); if (pp->isItemChecked(3133) == true) GeomGUI->mySketcher.SetTransitionStatus(TANGENT); else GeomGUI->mySketcher.SetTransitionStatus(NOCONSTRAINT); pp->setItemChecked(3134,false); break; } case 3134: // sketcher { QMenuBar* Mb = GeomGUI->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(3134,&pp); pp->setItemChecked(3134,!pp->isItemChecked(3134)); if (pp->isItemChecked(3134) == true) GeomGUI->mySketcher.SetTransitionStatus(PERPENDICULAR); else GeomGUI->mySketcher.SetTransitionStatus(NOCONSTRAINT); pp->setItemChecked(3133,false); break; } case 4011: // FUSE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_FuseDlg *aDlg = new GeometryGUI_FuseDlg( parent, "", Sel ) ; break; } case 4012: // COMMON { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_CommonDlg *aDlg = new GeometryGUI_CommonDlg( parent, "", Sel ) ; break; } case 4013: // CUT { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_CutDlg *aDlg = new GeometryGUI_CutDlg( parent, "", Sel ) ; break; } case 4014: // SECTION { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_SectionDlg *aDlg = new GeometryGUI_SectionDlg( parent, "", Sel ) ; break; } case 4021: // TRANSLATION { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_TranslationDlg *aDlg = new GeometryGUI_TranslationDlg( parent, "", Sel ) ; break; } case 4022: // ROTATION { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_RotationDlg *aDlg = new GeometryGUI_RotationDlg( parent, "", Sel ) ; break; } case 4030: // MULTI TRANSLATION { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_MultiTranslationDlg *aDlg = new GeometryGUI_MultiTranslationDlg( parent, "", Sel ) ; break; } case 4040: // MULTI ROTATION { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_MultiRotationDlg *aDlg = new GeometryGUI_MultiRotationDlg( parent, "", Sel ) ; break; } case 4023: // MIRROR { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_MirrorDlg *aDlg = new GeometryGUI_MirrorDlg( parent, "", Sel ) ; break; } case 4024: // SCALE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_ScaleDlg *aDlg = new GeometryGUI_ScaleDlg( parent, "", Sel ) ; break; } case 4025: // PARTITION { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_PartitionDlg *aDlg = new GeometryGUI_PartitionDlg( parent, "", Sel ) ; break; } case 4026: // ARCHIMEDE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_ArchimedeDlg *aDlg = new GeometryGUI_ArchimedeDlg( parent, "", Sel ) ; break; } case 4027: // FILLET { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_FilletDlg *aDlg = new GeometryGUI_FilletDlg( parent, "", Sel, ic ) ; break; } case 4028: // CHAMFER { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_ChamferDlg *aDlg = new GeometryGUI_ChamferDlg( parent, "", Sel, ic ) ; break; } case 4031: // PRISM { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_PrismDlg *aDlg = new GeometryGUI_PrismDlg( parent, "", Sel ) ; break; } case 4032: // REVOL { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_RevolDlg *aDlg = new GeometryGUI_RevolDlg( parent, "", Sel ) ; break; } case 4033: // FILLING { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_FillingDlg *aDlg = new GeometryGUI_FillingDlg( parent, "", Sel ) ; break; } case 4034: // PIPE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_PipeDlg *aDlg = new GeometryGUI_PipeDlg(parent, "", Sel ) ; break; } case 5001: // CHECK GEOMETRY { QAD_PyEditor* PyEditor = GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getPyEditor(); PyEditor->setText("from GEOM_usinggeom import *\n"); PyEditor->setText(">>> "); PyEditor->handleReturn(); break; } case 6021: // SHADING - WIREFRAME { if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { VTKViewer_RenderWindowInteractor* myRenderInter= ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor(); QApplication::setOverrideCursor(waitCursor); int themode = myRenderInter->GetDisplayMode(); if( themode==0 ) { myRenderInter->SetDisplayMode(1); GeomGUI->GetDesktop()->menuBar()->changeItem(6021, tr("GEOM_MEN_WIREFRAME") ); } else { myRenderInter->SetDisplayMode(0); GeomGUI->GetDesktop()->menuBar()->changeItem(6021, tr("GEOM_MEN_SHADING") ); } QApplication::restoreOverrideCursor(); } else if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC) { AIS_DisplayMode mode = ( AIS_DisplayMode )ic->DisplayMode(); QApplication::setOverrideCursor( Qt::waitCursor ); AIS_DisplayMode newmode = (mode == AIS_WireFrame ? AIS_Shaded : AIS_WireFrame); AIS_ListOfInteractive List; ic->DisplayedObjects(List); AIS_ListOfInteractive List1; ic->ObjectsInCollector(List1); List.Append(List1); AIS_ListIteratorOfListOfInteractive ite(List); while (ite.More()) { if (ite.Value()->IsInstance(STANDARD_TYPE(GEOM_AISShape))) { Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast(ite.Value()); ic->SetDisplayMode(aSh,Standard_Integer(newmode),true); } ite.Next(); } ic->SetDisplayMode( newmode, Standard_False); if ( newmode == 1 ) GeomGUI->GetDesktop()->menuBar()->changeItem(6021, tr("GEOM_MEN_WIREFRAME") ); else GeomGUI->GetDesktop()->menuBar()->changeItem(6021, tr("GEOM_MEN_SHADING") ); QApplication::restoreOverrideCursor(); } break; } case 6022: // DISPLAY ALL { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) //VTK ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor()->DisplayAll(); else if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) GeomGUI->OnDisplayAll(); break; } case 6023: // DISPLAY ONLY case 8023: // DISPLAY ONLY - POPUP VIEWER { if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { // VTK GeomGUI->OnVTKDisplayOnly(); } else if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC) GeomGUI->OnDisplayOnly(); break; } case 6024: // ERASE ALL { if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { //VTK ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor()->EraseAll(); } else if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC) { ic->EraseAll(Standard_True, Standard_False); ic->Display(v3d->getTrihedron()); } //NRI SALOME_Selection* Sel = SALOME_Selection::Selection( myActiveStudy->getSelection() ); //NRI Sel->ClearInteractiveObjects(); break; } case 6025 : // ERASE ONLY case 8022 : // ERASE - POPUP VIEWER { SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { // VTK SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); Handle(SALOME_InteractiveObject) anIObject; for(;It.More();It.Next()) { anIObject = It.Value(); VTKViewer_RenderWindowInteractor* myRenderInter= ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor(); if(myRenderInter->isInViewer(anIObject)) { myRenderInter->Erase(anIObject); } else { SALOMEDS::SObject_var obj = aStudy->FindObjectID( anIObject->getEntry() ); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeIOR_var anIOR; if ( !obj->_is_nil() ) { if ( obj->FindAttribute(anAttr, "AttributeIOR")) { // this SObject may be GEOM module root SObject SALOMEDS::ChildIterator_var anIter = GeomGUI->myActiveStudy->getStudyDocument()->NewChildIterator(obj); bool useSubItems = false; while (anIter->More() && !useSubItems) { SALOMEDS::SObject_var subobj = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttr; if (subobj->FindAttribute(aTmpAttr, "AttributeIOR")) { anAttr = aTmpAttr; obj = subobj; useSubItems = true; } else anIter->Next(); } while(useSubItems?anIter->More():!anAttr->_is_nil()) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); GEOM::GEOM_Shape_var aShape = GeomGUI->myComponentGeom->GetIORFromString(anIOR->Value()); TopoDS_Shape Shape = ShapeReader.GetShape(GeomGUI->myComponentGeom,aShape); if (obj->FindAttribute(anAttr, "AttributeName")) { // searchin for already displayed objects with the same shape vtkRenderer* theRenderer = ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRenderer(); vtkActorCollection* theAllActors = theRenderer->GetActors(); theAllActors->InitTraversal(); vtkActor* actor = (vtkActor*)theAllActors->GetNextActor(); Handle(SALOME_InteractiveObject) anIObj; // don't create new study object if it already exists bool isDisplayed = false; while(!(actor==NULL)) { SALOME_Actor* Gactor = SALOME_Actor::SafeDownCast(actor); if (Gactor!=NULL) { if (Gactor->hasIO()) { if (strcmp(Gactor->getIO()->getEntry(),obj->GetID())==0) { isDisplayed = true; anIObj = Gactor->getIO(); if (!anIObj.IsNull()) myRenderInter->Erase(anIObj); } } } actor=(vtkActor*)(theAllActors->GetNextActor()); } } if (useSubItems) { anIter->Next(); anAttr=SALOMEDS::GenericAttribute::_nil(); while (anIter->More() && anAttr->_is_nil()) { SALOMEDS::SObject_var subobject = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttribute; if (subobject->FindAttribute(aTmpAttribute, "AttributeIOR")) { anAttr = aTmpAttribute; obj = subobject; } else anIter->Next(); } } else anAttr = SALOMEDS::GenericAttribute::_nil(); } } } } } // SALOME_ListIteratorOfListIO It(Sel->StoredIObjects()); // for(;It.More();It.Next()) { // Handle(SALOME_InteractiveObject) IOS = It.Value(); // GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getVTKView()->getRWInteractor()->Erase(IOS);; } else if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC) { // OCC SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); Handle(SALOME_InteractiveObject) anIObject; for(;It.More();It.Next()) { anIObject = It.Value(); if ( v3d->isInViewer( anIObject, true ) ) { Standard_Boolean found; Handle(GEOM_AISShape) aSh = GeomGUI->ConvertIOinGEOMAISShape( anIObject, found, true ); if ( found ) { ic->Erase(aSh); ic->AddOrRemoveCurrentObject(aSh, true); } } else { SALOMEDS::SObject_var obj = aStudy->FindObjectID( anIObject->getEntry() ); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeIOR_var anIOR; if ( !obj->_is_nil() ) { if ( obj->FindAttribute(anAttr, "AttributeIOR")) { // this SObject may be GEOM module root SObject SALOMEDS::ChildIterator_var anIter = GeomGUI->myActiveStudy->getStudyDocument()->NewChildIterator(obj); bool useSubItems = false; while (anIter->More() && !useSubItems) { SALOMEDS::SObject_var subobj = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttr; if (subobj->FindAttribute(aTmpAttr, "AttributeIOR")) { anAttr = aTmpAttr; obj = subobj; useSubItems = true; } else anIter->Next(); } while(useSubItems?anIter->More():!anAttr->_is_nil()) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); GEOM::GEOM_Shape_var aShape = GeomGUI->myComponentGeom->GetIORFromString(anIOR->Value()); TopoDS_Shape Shape = ShapeReader.GetShape(GeomGUI->myComponentGeom,aShape); if (obj->FindAttribute(anAttr, "AttributeName")) { // searchin for already displayed objects with the same shape AIS_ListOfInteractive aDisplayed; ic->DisplayedObjects(aDisplayed); AIS_ListIteratorOfListOfInteractive anIObjects(aDisplayed); Handle(AIS_Shape) anAISShape; for(;anIObjects.More();anIObjects.Next()) { anAISShape = Handle(AIS_Shape)::DownCast(anIObjects.Value()); if (!anAISShape.IsNull()) { if (anAISShape->Shape().IsSame(Shape)) break; anAISShape.Nullify(); } } if (!anAISShape.IsNull()) { if (ic->IsDisplayed(anAISShape)) ic->Erase(anAISShape); } } if (useSubItems) { anIter->Next(); anAttr=SALOMEDS::GenericAttribute::_nil(); while (anIter->More() && anAttr->_is_nil()) { SALOMEDS::SObject_var subobject = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttribute; if (subobject->FindAttribute(aTmpAttribute, "AttributeIOR")) { anAttr = aTmpAttribute; obj = subobject; } else anIter->Next(); } } else anAttr = SALOMEDS::GenericAttribute::_nil(); } } } } } } Sel->ClearIObjects(); break; } case 6060: // BOUNDING BOX { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_BndBoxDlg *aDlg = new GeometryGUI_BndBoxDlg(parent, "", Sel ) ; break ; } case 6061: // MIN DISTANCE { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_DistanceDlg *aDlg = new GeometryGUI_DistanceDlg(parent, "", Sel ) ; break ; } case 8021: // WIREFRAME-SHADING { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { // VTK VTKViewer_RenderWindowInteractor* myRenderInter= ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor(); SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It(Sel->StoredIObjects()); QApplication::setOverrideCursor( Qt::waitCursor ); for(;It.More();It.Next()) { Handle(SALOME_InteractiveObject) IOS = It.Value(); myRenderInter->SwitchRepresentation(IOS, false); } myRenderInter->Render(); QApplication::restoreOverrideCursor(); } else if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { QApplication::setOverrideCursor( Qt::waitCursor ); SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); for(;It.More();It.Next()) { Handle(SALOME_InteractiveObject) IObject = It.Value(); Standard_Boolean found; Handle(GEOM_AISShape) Shape = GeomGUI->ConvertIOinGEOMAISShape( IObject, found, true ); if (!Shape.IsNull()) { AIS_DisplayMode mode = ( AIS_DisplayMode )Shape->DisplayMode(); if ( mode == -1 ) mode = ( AIS_DisplayMode )ic->DisplayMode(); QApplication::setOverrideCursor( Qt::waitCursor ); ic->SetDisplayMode(Shape, mode == AIS_WireFrame ? AIS_Shaded : AIS_WireFrame, false); } QApplication::restoreOverrideCursor(); } ic->UpdateCurrentViewer(); } QApplication::restoreOverrideCursor(); break; } case 8031: // COLOR - POPUP VIEWER { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { // VTK VTKViewer_RenderWindowInteractor* myRenderInter= ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor(); SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It(Sel->StoredIObjects()); Handle(SALOME_InteractiveObject) FirstIOS = Sel->firstIObject(); if(!FirstIOS.IsNull()) { QColor initcolor = myRenderInter->GetColor(FirstIOS); QColor c = QColorDialog::getColor( initcolor, QAD_Application::getDesktop() ); if ( c.isValid() ) { QApplication::setOverrideCursor( Qt::waitCursor ); for(;It.More();It.Next()) { Handle(SALOME_InteractiveObject) IOS = It.Value(); myRenderInter->SetColor(IOS,c); } } QApplication::restoreOverrideCursor(); } } else if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); Handle(SALOME_InteractiveObject) IO = Sel->firstIObject(); Standard_Boolean found; Handle(GEOM_AISShape) Shape = GeomGUI->ConvertIOinGEOMAISShape(IO, found, true); if ( found ) { Quantity_Color CSFColor; Shape->Color( CSFColor ); QColor c = QColorDialog::getColor( QColor(CSFColor.Red() * 255.0, CSFColor.Green()* 255.0, CSFColor.Blue() * 255.0 ), QAD_Application::getDesktop() ); if ( c.isValid() ) { CSFColor = Quantity_Color ( c.red()/255., c.green()/255., c.blue()/255., Quantity_TOC_RGB ); QApplication::setOverrideCursor( Qt::waitCursor ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); for(;It.More();It.Next()) { Handle(SALOME_InteractiveObject) IObject = It.Value(); Standard_Boolean found; Handle(GEOM_AISShape) Shape = GeomGUI->ConvertIOinGEOMAISShape(IObject, found, true); if ( found ) { Shape->SetColor ( CSFColor ); Shape->SetShadingColor ( CSFColor ); } } } } } QApplication::restoreOverrideCursor(); break; } case 8032: // TRANSPARENCY - POPUP VIEWER { GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); GeometryGUI_TransparencyDlg *aDlg = new GeometryGUI_TransparencyDlg( parent, "", Sel, ic ) ; break ; } case 8033: // ISOS - POPUP VIEWER { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) break; else { ic->InitCurrent(); if ( ic->MoreCurrent() ) { Handle(GEOM_AISShape) CurObject = Handle(GEOM_AISShape)::DownCast(ic->Current()); QString IsoU = QAD_CONFIG->getSetting("Geometry:SettingsIsoU"); QString IsoV = QAD_CONFIG->getSetting("Geometry:SettingsIsoV"); if ( !IsoU.isEmpty() ) ic->DefaultDrawer()->UIsoAspect()->SetNumber(IsoU.toInt()); else IsoU = "1"; if ( !IsoV.isEmpty() ) ic->DefaultDrawer()->VIsoAspect()->SetNumber(IsoV.toInt()); else IsoV = "1"; GeometryGUI_NbIsosDlg * NbIsosDlg = new GeometryGUI_NbIsosDlg(QAD_Application::getDesktop(), tr("GEOM_MEN_ISOS"), TRUE ); NbIsosDlg->SpinBoxU->setValue(IsoU.toInt()); NbIsosDlg->SpinBoxV->setValue(IsoV.toInt()); if ( NbIsosDlg->exec() ) { QApplication::setOverrideCursor( Qt::waitCursor ); for ( ; ic->MoreCurrent (); ic->NextCurrent () ) { Handle (AIS_Drawer) CurDrawer; CurDrawer = ic->Current()->Attributes(); CurDrawer->UIsoAspect()->SetNumber( NbIsosDlg->SpinBoxU->text().toInt() ); CurDrawer->VIsoAspect()->SetNumber( NbIsosDlg->SpinBoxV->text().toInt() ); ic->SetLocalAttributes(CurObject, CurDrawer); ic->Redisplay(CurObject); } } } } QApplication::restoreOverrideCursor(); break; } case 9022 : // ERASE - OBJBROSER POPUP { SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { // VTK SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); Handle(SALOME_InteractiveObject) anIObject; for(;It.More();It.Next()) { anIObject = It.Value(); VTKViewer_RenderWindowInteractor* myRenderInter= ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor(); // Handle(SALOME_InteractiveObject) IObject; if(myRenderInter->isInViewer(anIObject)) { myRenderInter->Erase(anIObject); } else { SALOMEDS::SObject_var obj = aStudy->FindObjectID( anIObject->getEntry() ); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeIOR_var anIOR; if ( !obj->_is_nil() ) { if ( obj->FindAttribute(anAttr, "AttributeIOR")) { // this SObject may be GEOM module root SObject SALOMEDS::ChildIterator_var anIter = GeomGUI->myActiveStudy->getStudyDocument()->NewChildIterator(obj); bool useSubItems = false; while (anIter->More() && !useSubItems) { SALOMEDS::SObject_var subobj = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttr; if (subobj->FindAttribute(aTmpAttr, "AttributeIOR")) { anAttr = aTmpAttr; obj = subobj; useSubItems = true; } else anIter->Next(); } while(useSubItems?anIter->More():!anAttr->_is_nil()) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); GEOM::GEOM_Shape_var aShape = GeomGUI->myComponentGeom->GetIORFromString(anIOR->Value()); TopoDS_Shape Shape = ShapeReader.GetShape(GeomGUI->myComponentGeom,aShape); if (obj->FindAttribute(anAttr, "AttributeName")) { // searchin for already displayed objects with the same shape vtkRenderer* theRenderer = ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRenderer(); vtkActorCollection* theAllActors = theRenderer->GetActors(); theAllActors->InitTraversal(); vtkActor* actor = (vtkActor*)theAllActors->GetNextActor(); Handle(SALOME_InteractiveObject) anIObj; // don't create new study object if it already exists bool isDisplayed = false; while(!(actor==NULL)) { SALOME_Actor* Gactor = SALOME_Actor::SafeDownCast(actor); if (Gactor!=NULL) { if (Gactor->hasIO()) { if (strcmp(Gactor->getIO()->getEntry(),obj->GetID())==0) { isDisplayed = true; anIObj = Gactor->getIO(); if (!anIObj.IsNull()) myRenderInter->Erase(anIObj); } } } actor=(vtkActor*)(theAllActors->GetNextActor()); } } if (useSubItems) { anIter->Next(); anAttr=SALOMEDS::GenericAttribute::_nil(); while (anIter->More() && anAttr->_is_nil()) { SALOMEDS::SObject_var subobject = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttribute; if (subobject->FindAttribute(aTmpAttribute, "AttributeIOR")) { anAttr = aTmpAttribute; obj = subobject; } else anIter->Next(); } } else anAttr = SALOMEDS::GenericAttribute::_nil(); } } } } // SALOME_ListIteratorOfListIO It(Sel->StoredIObjects()); // for(;It.More();It.Next()) { // Handle(SALOME_InteractiveObject) IOS = It.Value(); // GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getVTKView()->getRWInteractor()->Erase(IOS);; } // SALOME_ListIteratorOfListIO It(Sel->StoredIObjects()); // for(;It.More();It.Next()) { // Handle(SALOME_InteractiveObject) IOS = It.Value(); // GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getVTKView()->getRWInteractor()->Erase(IOS);; // } } else if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { // OCC SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); Handle(SALOME_InteractiveObject) anIObject; for(;It.More();It.Next()) { anIObject = It.Value(); if ( v3d->isInViewer( anIObject, true ) ) { Standard_Boolean found; Handle(GEOM_AISShape) aSh = GeomGUI->ConvertIOinGEOMAISShape( anIObject, found, true ); if ( found ) { ic->Erase(aSh); ic->AddOrRemoveCurrentObject(aSh, true); } } else { SALOMEDS::SObject_var obj = aStudy->FindObjectID( anIObject->getEntry() ); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeIOR_var anIOR; if ( !obj->_is_nil() ) { if ( obj->FindAttribute(anAttr, "AttributeIOR")) { // this SObject may be GEOM module root SObject SALOMEDS::ChildIterator_var anIter = GeomGUI->myActiveStudy->getStudyDocument()->NewChildIterator(obj); bool useSubItems = false; while (anIter->More() && !useSubItems) { SALOMEDS::SObject_var subobj = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttr; if (subobj->FindAttribute(aTmpAttr, "AttributeIOR")) { anAttr = aTmpAttr; obj = subobj; useSubItems = true; } else anIter->Next(); } while(useSubItems?anIter->More():!anAttr->_is_nil()) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); GEOM::GEOM_Shape_var aShape = GeomGUI->myComponentGeom->GetIORFromString(anIOR->Value()); TopoDS_Shape Shape = ShapeReader.GetShape(GeomGUI->myComponentGeom,aShape); if (obj->FindAttribute(anAttr, "AttributeName")) { // searchin for already displayed objects with the same shape AIS_ListOfInteractive aDisplayed; ic->DisplayedObjects(aDisplayed); AIS_ListIteratorOfListOfInteractive anIObjects(aDisplayed); Handle(AIS_Shape) anAISShape; for(;anIObjects.More();anIObjects.Next()) { anAISShape = Handle(AIS_Shape)::DownCast(anIObjects.Value()); if (!anAISShape.IsNull()) { if (anAISShape->Shape().IsSame(Shape)) break; anAISShape.Nullify(); } } if (!anAISShape.IsNull()) { if (ic->IsDisplayed(anAISShape)) ic->Erase(anAISShape); } } if (useSubItems) { anIter->Next(); anAttr=SALOMEDS::GenericAttribute::_nil(); while (anIter->More() && anAttr->_is_nil()) { SALOMEDS::SObject_var subobject = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttribute; if (subobject->FindAttribute(aTmpAttribute, "AttributeIOR")) { anAttr = aTmpAttribute; obj = subobject; } else anIter->Next(); } } else anAttr = SALOMEDS::GenericAttribute::_nil(); } } } } } // QAD_Viewer3d* v3d = GeomGUI->myActiveStudy->getActiveStudyFrame()->getViewerOCC(); // Handle (AIS_InteractiveContext) myContext = v3d->getAISContext(); // myContext->EraseSelected(); } Sel->ClearIObjects(); break; } case 9023 : // DISPLAY ONLY - OBJBROSER POPUP { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) GeomGUI->OnVTKDisplayOnly(); else if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) GeomGUI->OnDisplayOnly(); break; } case 9024 : // OPEN - OBJBROSER POPUP { SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); Handle(SALOME_InteractiveObject) anIObject; for(;It.More();It.Next()) { anIObject = It.Value(); SALOMEDS::SObject_var obj = aStudy->FindObjectID( anIObject->getEntry() ); SALOMEDS::AttributePersistentRef_var aPersist; SALOMEDS::AttributeIOR_var anIOR; if ( !obj->_is_nil() ) { // this SObject may be GEOM module root SObject SALOMEDS::ChildIterator_var anIter = GeomGUI->myActiveStudy->getStudyDocument()->NewChildIterator(obj); SALOMEDS::GenericAttribute_var anAttr; bool useSubItems = false; while (anIter->More() && !useSubItems) { SALOMEDS::SObject_var subobj = anIter->Value(); if (subobj->FindAttribute(anAttr, "AttributePersistentRef")) { useSubItems = true; obj = subobj; } else anIter->Next(); } obj->FindAttribute(anAttr, "AttributePersistentRef"); while(useSubItems?anIter->More():!anAttr->_is_nil()) { if (!obj->FindAttribute(anAttr, "AttributeIOR") && obj->FindAttribute(anAttr, "AttributePersistentRef")) { // load Engines::Component_var comp = GeomGUI->myDesktop->getEngine("FactoryServer","Geometry"); if (!CORBA::is_nil(comp)) { SALOMEDS::Driver_var driver = SALOMEDS::Driver::_narrow(comp); SALOMEDS::StudyBuilder_var aStudyBuilder = GeomGUI->myActiveStudy->getStudyDocument()->NewBuilder(); aStudyBuilder->LoadWith(GeomGUI->myActiveStudy->getStudyDocument()->FindComponent("GEOM"),driver); } else { MESSAGE("Component is null"); } } if (useSubItems) { anIter->Next(); obj = anIter->Value(); } else anAttr = SALOMEDS::GenericAttribute::_nil(); } } } break; } case 10000 : // SKETCH Segment { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) break; GeomGUI->OnSketchSegment(); break; } case 10001 : // SKETCH Arc { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) break; GeomGUI->OnSketchArc(); break; } case 10002 : // SKETCH Set Angle { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) break; GeomGUI->OnSketchSetAngle(); break; } case 10003 : // SKETCH Set X { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) break; GeomGUI->OnSketchSetx(); break; } case 10004 : // SKETCH Set Y { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) break; GeomGUI->OnSketchSety(); break; } case 10006 : // SKETCH Delete { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) break; GeomGUI->OnSketchDelete(); break; } case 10007 : // SKETCH End { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) break; GeomGUI->OnSketchEnd(); break; } case 10008 : // SKETCH Close { if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) break; GeomGUI->OnSketchClose(); break; } case 10010 : // SKETCH OptionsOnofflengthdimension { GeomGUI->OnSketchOptionsOnofflengthdimension(); break; } case 10011 : // SKETCH OptionsOnoffangledimension { GeomGUI->OnSketchOptionsOnoffangledimension(); break; } case 10012 : // SKETCH OptionsOnoffradiusdimension { GeomGUI->OnSketchOptionsOnoffradiusdimension(); break; } case 10013 : // SKETCH OptionsOnoffxdimension { GeomGUI->OnSketchOptionsOnoffxdimension(); break; } case 10014 : // SKETCH OptionsOnoffydimension { GeomGUI->OnSketchOptionsOnoffydimension(); break; } default: { parent->putInfo( tr("GEOM_PRP_COMMAND").arg(theCommandID ) ); break; } } return true ; } //======================================================================= // function : ConvertClickToPoint() // purpose : Returns the point clicked in 3D view //======================================================================= gp_Pnt GeometryGUI::ConvertClickToPoint( Standard_Real x, Standard_Real y, Handle(V3d_View) aView ) { V3d_Coordinate XEye, YEye, ZEye, XAt, YAt, ZAt; aView->Eye(XEye, YEye, ZEye); aView->At(XAt, YAt, ZAt); gp_Pnt EyePoint(XEye, YEye, ZEye); gp_Pnt AtPoint(XAt, YAt, ZAt); gp_Vec EyeVector(EyePoint, AtPoint); gp_Dir EyeDir(EyeVector); gp_Pln PlaneOfTheView = gp_Pln(AtPoint,EyeDir); Standard_Real X, Y, Z; aView->Convert(x, y, X, Y, Z); gp_Pnt ConvertedPoint(X, Y, Z); gp_Pnt2d ConvertedPointOnPlane = ProjLib::Project(PlaneOfTheView, ConvertedPoint); gp_Pnt ResultPoint = ElSLib::Value(ConvertedPointOnPlane.X(), ConvertedPointOnPlane.Y(), PlaneOfTheView); return ResultPoint; } //================================================================================== // function : 0nMousePress() // purpose : [static] manage mouse events //================================================================================== bool GeometryGUI::OnMousePress(QMouseEvent* pe, QAD_Desktop* parent, QAD_StudyFrame* studyFrame) { MESSAGE ( "GeometryGUI::OnMousePress") GeometryGUI::GetOrCreateGeometryGUI(parent); if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) return false; OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); OCCViewer_ViewPort* vp = ((OCCViewer_ViewFrame*)studyFrame->getRightFrame()->getViewFrame())->getViewPort(); /* Get the clicked or selected point */ gp_Pnt thePoint; if ( GeomGUI->myState == CURRENT_SKETCH) { GeomGUI->mySketcher.ValidateEdge(); if (GeomGUI->mySketcher.GetmyEdgesNumber() == 1 ) { QMenuBar* Mb = GeomGUI->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(313,&pp); pp->setItemEnabled( 313, true); // SKETCH CONTRAINTS } } else if( GeomGUI->myState == POINT_METHOD ) { GeomGUI->EraseSimulationShape() ; GeometryGUI_PointDlg *DialogPt = (GeometryGUI_PointDlg*)(GeomGUI->myActiveDialogBox) ; if ( DialogPt->UseLocalContext() ) { ic->InitSelected(); if ( pe->state() == Qt::ShiftButton ) v3d->getAISSelector()->shiftSelect(); /* Append selection */ else v3d->getAISSelector()->select(); /* New selection */ if ( ic->MoreSelected() ) { thePoint = BRep_Tool::Pnt( TopoDS::Vertex(ic->SelectedShape()) ); } else thePoint = ConvertClickToPoint(pe->x(), pe->y(), ( (OCCViewer_ViewPort3d*)vp)->getView() ); } else thePoint = ConvertClickToPoint(pe->x(), pe->y(), ( (OCCViewer_ViewPort3d*)vp)->getView() ); if( DialogPt != 0 ) { DialogPt->PointIntoCoordinates(thePoint, true) ; /* display point */ } else { // MESSAGE ("On Mouse Press : myActiveDialogBox is null" << endl) ; GeomGUI->myDesktop->putInfo(tr("GEOM_PRP_ABORT")); } } return false ; } //======================================================================= // function : OnMouseMove() // purpose : [static] manage mouse events //======================================================================= bool GeometryGUI::OnMouseMove (QMouseEvent* pe, QAD_Desktop* parent, QAD_StudyFrame* studyFrame) { GeometryGUI::GetOrCreateGeometryGUI(parent); if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC) return false; OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); OCCViewer_ViewPort* vp = ((OCCViewer_ViewFrame*)studyFrame->getRightFrame()->getViewFrame())->getViewPort(); if ( GeomGUI->myState == CURRENT_SKETCH) GeomGUI->mySketcher.MakeCurrentEdge( pe->x(), pe->y(), ((OCCViewer_ViewPort3d*)vp)->getView() ); return true; } //================================================================================ // function : SetDisplayedObjectList() // purpose : //================================================================================ void GeometryGUI::SetDisplayedObjectList() { if (myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC) return; OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); ListDisplayedObject.Clear(); Handle (AIS_InteractiveContext) aContext = v3d->getAISContext(); aContext->DisplayedObjects( ListDisplayedObject ); } //===================================================================================== // function : OnDisplayAll() // purpose : //===================================================================================== void GeometryGUI::OnDisplayAll(bool onlyPreviousDisplayedObject) { if (myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC) return; OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) myContext = v3d->getAISContext(); myContext->Display(v3d->getTrihedron()); if ( !onlyPreviousDisplayedObject ) { AIS_ListOfInteractive List1; myContext->ObjectsInCollector(List1); AIS_ListIteratorOfListOfInteractive ite1(List1); while (ite1.More()) { if (ite1.Value()->IsInstance(STANDARD_TYPE(GEOM_AISShape))) { Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast(ite1.Value()); if ( aSh->hasIO() ) { Handle(GEOM_InteractiveObject) GIO = Handle(GEOM_InteractiveObject)::DownCast(aSh->getIO()); if ( v3d->isInViewer(GIO, true) ) { myContext->Display(aSh); } } } ite1.Next(); } } else { AIS_ListIteratorOfListOfInteractive ite(ListDisplayedObject); while (ite.More()) { if (ite.Value()->IsInstance(STANDARD_TYPE(GEOM_AISShape))) { Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast(ite.Value()); if ( aSh->hasIO() ) { Handle(GEOM_InteractiveObject) GIO = Handle(GEOM_InteractiveObject)::DownCast(aSh->getIO()); if ( v3d->isInViewer(GIO,true) ) { myContext->Display(aSh); } } } ite.Next(); } } } //===================================================================================== // function : OnVTKDisplayOnly() // purpose : //===================================================================================== void GeometryGUI::OnVTKDisplayOnly() { // Erase all not selected actors QApplication::setOverrideCursor( Qt::waitCursor ); vtkRenderer* aren = ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRenderer(); vtkActorCollection* theActors = aren->GetActors(); theActors->InitTraversal(); vtkActor *ac = theActors->GetNextActor(); while(!(ac==NULL)) { if ( ac->IsA("SALOME_Actor") ) { SALOME_Actor* anActor = SALOME_Actor::SafeDownCast( ac ); if(!anActor->isHighlighted()) anActor->VisibilityOff(); } ac = theActors->GetNextActor(); } // Display selection SALOMEDS::Study_var aStudy = myActiveStudy->getStudyDocument(); SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder(); SALOMEDS::SObject_var fatherSF = aStudy->FindObjectID(GeomGUI->myActiveStudy->getActiveStudyFrame()->entry()); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeName_var aName; SALOMEDS::AttributeIOR_var anIOR; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); for(;It.More();It.Next()) { Handle(SALOME_InteractiveObject) IObject = It.Value(); SALOMEDS::SObject_var obj = aStudy->FindObjectID( IObject->getEntry() ); VTKViewer_RenderWindowInteractor* myRenderInter= ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor(); if(myRenderInter->isInViewer(IObject)) { myRenderInter->Display(IObject); } else { // Create new actor if ( !obj->_is_nil() ) { if ( !obj->FindAttribute(anAttr, "AttributeIOR")) break; // If selected object contains displayable subobjects, then do nothing SALOMEDS::ChildIterator_var anIter = GeomGUI->myActiveStudy->getStudyDocument()->NewChildIterator(obj); SALOMEDS::GenericAttribute_var aTmpAttr; anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); GEOM::GEOM_Shape_var aShape = GeomGUI->myComponentGeom->GetIORFromString(anIOR->Value()); if (CORBA::is_nil(aShape)) continue; TopoDS_Shape Shape = ShapeReader.GetShape(GeomGUI->myComponentGeom,aShape); if (obj->FindAttribute(anAttr, "AttributeName")) { aName = SALOMEDS::AttributeName::_narrow(anAttr); // open transaction QAD_Operation* op = new SALOMEGUI_ImportOperation( GeomGUI->myActiveStudy ); op->start(); SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(fatherSF); aStudyBuilder->Addreference(newObj1, obj); // commit transaction op->finish(); vtkRenderer* theRenderer = ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRenderer(); int themode = myRenderInter->GetDisplayMode(); vtkActorCollection* theActors = GEOM_AssemblyBuilder::BuildActors(Shape,0,themode,Standard_True); theActors->InitTraversal(); vtkActor* anActor = (vtkActor*)theActors->GetNextActor(); while(!(anActor==NULL)) { GEOM_Actor* GActor = GEOM_Actor::SafeDownCast( anActor ); GActor->setIO( IObject ); GActor->setName( IObject->getName() ); theRenderer->AddActor(GActor); vtkRenderWindow *renWin = ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRenderer()->GetRenderWindow(); renWin->Render(); anActor = (vtkActor*)theActors->GetNextActor(); } } } } } GeomGUI->myActiveStudy->updateObjBrowser( true ); QApplication::restoreOverrideCursor(); } //===================================================================================== // function : OnDisplayOnly() // purpose : //===================================================================================== void GeometryGUI::OnDisplayOnly() { if (myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC) return; OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); SALOMEDS::Study_var aStudy = myActiveStudy->getStudyDocument(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); AIS_ListOfInteractive List; ic->DisplayedObjects(List); AIS_ListIteratorOfListOfInteractive ite(List); while (ite.More()) { if (ite.Value()->IsInstance(STANDARD_TYPE(GEOM_AISShape))) { Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast(ite.Value()); if (!ic->IsSelected( aSh )) { ic->Erase( aSh, Standard_True, Standard_True ); } } ite.Next(); } SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder(); SALOME_Selection* Sel = SALOME_Selection::Selection( myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It1( Sel->StoredIObjects() ); for(;It1.More();It1.Next()) { Handle(SALOME_InteractiveObject) IObject = It1.Value(); SALOMEDS::SObject_var fatherSF = aStudy->FindObjectID(myActiveStudy->getActiveStudyFrame()->entry()); if ( v3d->isInViewer( IObject, true ) ) { AIS_ListOfInteractive List1; ic->ObjectsInCollector(List1); AIS_ListIteratorOfListOfInteractive ite1(List1); while (ite1.More()) { if (ite1.Value()->IsInstance(STANDARD_TYPE(GEOM_AISShape))) { Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast(ite1.Value()); if ( aSh->hasIO() ) { Handle(GEOM_InteractiveObject) GIO = Handle(GEOM_InteractiveObject)::DownCast(aSh->getIO()); if ( IObject->isSame( GIO ) ) { ic->Display(aSh); ic->AddOrRemoveCurrentObject(aSh, true); break; } } } ite1.Next(); } } else { if ( IObject->hasEntry() ) { SALOMEDS::SObject_var obj = aStudy->FindObjectID( IObject->getEntry() ); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeName_var aName; SALOMEDS::AttributeIOR_var anIOR; if ( !obj->_is_nil() ) { if (obj->FindAttribute(anAttr, "AttributeIOR")) { // this SObject may be GEOM module root SObject anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( anIOR->Value() ); if (CORBA::is_nil(aShape)) continue; TopoDS_Shape Shape = ShapeReader.GetShape(myComponentGeom, aShape); if (obj->FindAttribute(anAttr, "AttributeName")) { aName = SALOMEDS::AttributeName::_narrow(anAttr); // open transaction QAD_Operation* op = new SALOMEGUI_ImportOperation( myActiveStudy ); op->start(); SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(fatherSF); aStudyBuilder->Addreference(newObj1, obj); // commit transaction op->finish(); } Handle(GEOM_AISShape) aSh = new GEOM_AISShape(Shape, aName->Value()); Handle(GEOM_InteractiveObject) IO = new GEOM_InteractiveObject(anIOR->Value(), Fatherior,"GEOM"); IO->setEntry(obj->GetID()); aSh->setIO( IO ); aSh->setName( aName->Value() ); ic->Display (aSh); ic->AddOrRemoveCurrentObject(aSh, true); } } } } } } //=============================================================================== // function : OnEditDelete() // purpose : //=============================================================================== void GeometryGUI::OnEditDelete() { if ( QAD_MessageBox::warn2 ( QAD_Application::getDesktop(), tr ("GEOM_WRN_WARNING"), tr ("GEOM_REALLY_DELETE"), tr ("GEOM_BUT_YES"), tr ("GEOM_BUT_NO"), 1, 0, 0) != 1 ) return; int nbSf = myActiveStudy->getStudyFramesCount(); Standard_Boolean found; SALOMEDS::Study_var aStudy = myActiveStudy->getStudyDocument(); SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder(); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeIOR_var anIOR; SALOME_Selection* Sel = SALOME_Selection::Selection( myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); for(;It.More();It.Next()) { Handle(SALOME_InteractiveObject) IObject = It.Value(); if ( IObject->hasEntry() ) { SALOMEDS::Study_var aStudy = GeomGUI->myActiveStudy->getStudyDocument(); SALOMEDS::SObject_var SO = aStudy->FindObjectID( IObject->getEntry() ); /* Erase child graphical objects */ SALOMEDS::ChildIterator_var it = aStudy->NewChildIterator(SO); for (; it->More();it->Next()) { SALOMEDS::SObject_var CSO= it->Value(); if (CSO->FindAttribute(anAttr, "AttributeIOR") ) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); /* Delete child(s) shape in Client : */ const TCollection_AsciiString ASCior(anIOR->Value()) ; ShapeReader.RemoveShapeFromBuffer( ASCior ) ; for ( int i = 0; i < nbSf; i++ ) { QAD_StudyFrame* sf = myActiveStudy->getStudyFrame(i); if ( sf->getTypeView() == VIEW_OCC ) { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)sf->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) myContext = v3d->getAISContext(); Handle(GEOM_AISShape) Result = GeomGUI->ConvertIORinGEOMAISShape( anIOR->Value(), found ); if ( found ) myContext->Erase( Result, true, false ); } else if ( sf->getTypeView() == VIEW_VTK ) { //vtkRenderer* Renderer = ((VTKViewer_ViewFrame*)sf->getRightFrame()->getViewFrame())->getRenderer(); VTKViewer_RenderWindowInteractor* myRenderInter= ((VTKViewer_ViewFrame*)sf->getRightFrame()->getViewFrame())->getRWInteractor(); GEOM_Actor* ac = GeomGUI->ConvertIORinGEOMActor( anIOR->Value(), found ); if ( found ) { //Renderer->RemoveActor(ac); if ( ac->hasIO() ) myRenderInter->Remove( ac->getIO() ); } } } } } /* Erase main graphical object */ for ( int i = 0; i < nbSf; i++ ) { QAD_StudyFrame* sf = myActiveStudy->getStudyFrame(i); if ( sf->getTypeView() == VIEW_OCC ) { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)sf->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) myContext = v3d->getAISContext(); Handle(GEOM_AISShape) Result = GeomGUI->ConvertIOinGEOMAISShape( IObject, found ); if ( found ) myContext->Erase( Result, true, false ); } else if ( sf->getTypeView() == VIEW_VTK ) { VTKViewer_RenderWindowInteractor* myRenderInter= ((VTKViewer_ViewFrame*)sf->getRightFrame()->getViewFrame())->getRWInteractor(); myRenderInter->Remove( IObject ); } } /* Delete main shape in Client : */ if (SO->FindAttribute(anAttr, "AttributeIOR") ) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); const TCollection_AsciiString ASCIor(anIOR->Value()) ; ShapeReader.RemoveShapeFromBuffer( ASCIor ) ; } /* Erase objects in Study */ SALOMEDS::SObject_var obj = aStudy->FindObjectID( IObject->getEntry() ); if ( !obj->_is_nil() ) { QAD_Operation* op = new SALOMEGUI_ImportOperation( myActiveStudy ); op->start(); aStudyBuilder->RemoveObject(obj); op->finish(); } } /* IObject->hasEntry() */ } /* more/next */ /* Clear any previous selection */ Sel->ClearIObjects() ; myActiveStudy->updateObjBrowser(); } //============================================================================== // function : OnEditCopy() // purpose : //============================================================================== void GeometryGUI::OnEditCopy() { SALOME_Selection* Sel = SALOME_Selection::Selection( myActiveStudy->getSelection() ); GEOM::GEOM_Gen::ListOfIOR_var listIOR = new GEOM::GEOM_Gen::ListOfIOR; const SALOME_ListIO& List = Sel->StoredIObjects(); GeomGUI->ConvertListOfIOInListOfIOR( List, listIOR); Sel->ClearIObjects(); for (unsigned int ind = 0; ind < listIOR->length();ind++) { GEOM::GEOM_Shape_var aShapeInit = myComponentGeom->GetIORFromString(listIOR[ind]); try { GEOM::GEOM_Shape_var result = myComponentGeom->MakeCopy(aShapeInit) ; result->NameType( aShapeInit->NameType() ); this->Display(result); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } myDesktop->putInfo(tr("GEOM_PRP_READY")); } //===================================================================================== // function : OnKeyPress() // purpose : [static] //===================================================================================== bool GeometryGUI::OnKeyPress (QKeyEvent* pe, QAD_Desktop* parent, QAD_StudyFrame* studyFrame) { GeometryGUI::GetOrCreateGeometryGUI(parent); if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC) return false; return true ; } //===================================================================================== // function : DisplaySimulationShape() // purpose : Displays 'this->mySimulationShape' a pure graphical shape from a TopoDS_Shape //===================================================================================== void GeometryGUI::DisplaySimulationShape(const TopoDS_Shape& S) { if( S.IsNull() ) return ; //NRI DEBUG : 14/02/2002 if ( myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) return ; OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); try { /* erase any previous */ ic->Erase( this->mySimulationShape, Standard_True, Standard_False ); ic->ClearPrs( this->mySimulationShape ); this->mySimulationShape = new AIS_Shape( TopoDS_Shape() ) ; this->mySimulationShape->Set( S ) ; this->mySimulationShape->SetColor(Quantity_NOC_VIOLET) ; ic->Deactivate( this->mySimulationShape ); ic->Display( this->mySimulationShape, Standard_False ); ic->UpdateCurrentViewer(); } catch(Standard_Failure) { MESSAGE( "Exception catched in GeometryGUI::DisplaySimulationShape " ) ; } this->mySimulationShape->UnsetColor() ; return ; } //================================================================================== // function : EraseSimulationShape() // purpose : Clears the display of 'mySimulationShape' a pure graphical shape //================================================================================== void GeometryGUI::EraseSimulationShape() { int count = myActiveStudy->getStudyFramesCount(); for ( int i = 0; i < count; i++ ) { if (myActiveStudy->getStudyFrame(i)->getTypeView() == VIEW_OCC ) { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getStudyFrame(i)->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); ic->Erase( this->mySimulationShape, Standard_True, Standard_False ); ic->ClearPrs( this->mySimulationShape ); ic->UpdateCurrentViewer(); } else if (myActiveStudy->getStudyFrame(i)->getTypeView() == VIEW_VTK ) { // VTK } } // MESSAGE ( " GeometryGUI::EraseSimulationShape done. " ) } //===================================================================================== // function : Import // purpose : BRep, Iges, Step //===================================================================================== bool GeometryGUI::Import( ) { SALOMEDS::Study_var aStudy = myActiveStudy->getStudyDocument(); SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder(); GEOM::GEOM_Shape_var aShape; QString file; QStringList filtersList ; switch ( GeomGUI->myState ) { case 111 : // Import BREP { filtersList.append( tr("GEOM_MEN_IMPORT_BREP") ); filtersList.append( tr("GEOM_MEN_ALL_FILES") ) ; file = QAD_FileDlg::getFileName(myDesktop, "", filtersList, tr("GEOM_MEN_IMPORT"), true); if ( !file.isEmpty() ) { QApplication::setOverrideCursor( Qt::waitCursor ); try { aShape = myComponentGeom->ImportBREP( file.latin1() ); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } break; } case 112 : // Import IGES { filtersList.append( tr("GEOM_MEN_IMPORT_IGES") ) ; filtersList.append( tr("GEOM_MEN_ALL_FILES") ) ; file = QAD_FileDlg::getFileName(myDesktop, "", filtersList, tr("GEOM_MEN_IMPORT"), true); if ( !file.isEmpty() ) { QApplication::setOverrideCursor( Qt::waitCursor ); try { aShape = myComponentGeom->ImportIGES( file.latin1() ); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } break; } case 113 : // Import STEP { filtersList.append( tr("GEOM_MEN_IMPORT_STEP") ) ; filtersList.append( tr("GEOM_MEN_ALL_FILES") ) ; file = QAD_FileDlg::getFileName(myDesktop, "", filtersList, tr("GEOM_MEN_IMPORT"), true); if ( !file.isEmpty() ) { QApplication::setOverrideCursor( Qt::waitCursor ); try { aShape = myComponentGeom->ImportSTEP( file.latin1() ); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } break; } } if ( !file.isEmpty() ) { myDesktop->putInfo( tr("GEOM_PRP_LOADING").arg(QAD_Tools::getFileNameFromPath( file )) ); SALOMEDS::SComponent_var father = aStudy->FindComponent("GEOM"); SALOMEDS::SObject_var fatherSF = aStudy->FindObjectID( myActiveStudy->getActiveStudyFrame()->entry()); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeName_var aName; SALOMEDS::AttributePixMap_var aPixmap; int aLocked = false; if (father->_is_nil()) { QAD_Operation* op = new SALOMEGUI_ImportOperation( myActiveStudy ); op->start(); aLocked = aStudy->GetProperties()->IsLocked(); if (aLocked) aStudy->GetProperties()->SetLocked(false); father = aStudyBuilder->NewComponent("GEOM"); anAttr = aStudyBuilder->FindOrCreateAttribute(father, "AttributeName"); aName = SALOMEDS::AttributeName::_narrow(anAttr); aName->SetValue( tr("GEOM_MEN_COMPONENT") ); anAttr = aStudyBuilder->FindOrCreateAttribute(father, "AttributePixMap"); aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr); aPixmap->SetPixMap( "ICON_OBJBROWSER_Geometry" ); if (aLocked) aStudy->GetProperties()->SetLocked(true); op->finish(); } // if (aLocked) return false; aStudyBuilder->DefineComponentInstance( father, myComponentGeom ); father->ComponentIOR( Fatherior ); QString nameShape = QAD_Tools::getFileNameFromPath(file,false) + QString("_%1").arg(this->myNbGeom++); if ( Display ( aShape, strdup(nameShape.latin1())) ) { myActiveStudy->setMessage( tr("GEOM_INF_LOADED").arg(QAD_Tools::getFileNameFromPath( file )) ); myDesktop->putInfo( tr("GEOM_PRP_READY")); } } QApplication::restoreOverrideCursor(); return true ; } //===================================================================================== // function : Export // purpose : BRep, Iges, Step //===================================================================================== bool GeometryGUI::Export( ) { SALOMEDS::Study_var aStudy = myActiveStudy->getStudyDocument(); SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder(); GEOM::GEOM_Shape_var aShape; static QString filters[] = { tr("GEOM_MEN_IMPORT_BREP"), tr("GEOM_MEN_IMPORT_IGES"), tr("GEOM_MEN_IMPORT_STEP") }; SALOME_Selection* Sel = SALOME_Selection::Selection( this->myActiveStudy->getSelection() ); SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); switch ( GeomGUI->myState ) { case 121 : { for(;It.More();It.Next()) { QApplication::restoreOverrideCursor(); Handle(SALOME_InteractiveObject) IObject = It.Value(); Standard_Boolean found; GEOM::GEOM_Shape_var aShape = GeomGUI->ConvertIOinGEOMShape(IObject, found); // Handle(GEOM_AISShape) Shape = ConvertIOinGEOMAISShape(IObject, found, true); if ( found ) { QString file = QAD_FileDlg::getFileName(myDesktop, QString( IObject->getName() ) + ".brep", tr("GEOM_MEN_IMPORT_BREP"), tr("GEOM_MEN_EXPORT"), false); if ( !file.isEmpty() && !aShape->_is_nil() ) { QApplication::setOverrideCursor( Qt::waitCursor ); // Standard_Boolean result = BRepTools::Write(Shape->Shape(), strdup(file.latin1()) ); try { GeomGUI->myComponentGeom->ExportBREP(strdup( file.latin1()), aShape); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } } } break; } case 122 : { for(;It.More();It.Next()) { QApplication::restoreOverrideCursor(); Handle(SALOME_InteractiveObject) IObject = It.Value(); Standard_Boolean found; GEOM::GEOM_Shape_var aShape = GeomGUI->ConvertIOinGEOMShape(IObject, found); // Handle(GEOM_AISShape) Shape = ConvertIOinGEOMAISShape(IObject, found, true); if ( found ) { QString file = QAD_FileDlg::getFileName(myDesktop, QString( IObject->getName() ) + ".igs", tr("GEOM_MEN_IMPORT_IGES"), tr("GEOM_MEN_EXPORT"), false); if ( !file.isEmpty() && !aShape->_is_nil() ) { QApplication::setOverrideCursor( Qt::waitCursor ); try { GeomGUI->myComponentGeom->ExportIGES(strdup( file.latin1()), aShape); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } // //VRV: OCC 4.0 migration // IGESControl_Controller::Init(); // IGESControl_Writer ICW (Interface_Static::CVal("XSTEP.iges.unit"), // Interface_Static::IVal("XSTEP.iges.writebrep.mode")); // //VRV: OCC 4.0 migration // ICW.AddShape (Shape->Shape()); // ICW.ComputeModel(); // Standard_Boolean result = ICW.Write( strdup(file.latin1()) ); } } } break; } case 123 : { // bool test = false ; // IFSelect_ReturnStatus status ; // //VRV: OCC 4.0 migration // STEPControl_Writer aWriter; // //VRV: OCC 4.0 migration QString file; for( ; It.More(); It.Next() ) { // GEOM::GEOM_Shape_var aShape = GeomGUI->ConvertIOinGEOMShape(IObject, found); QApplication::restoreOverrideCursor(); Handle(SALOME_InteractiveObject) IObject = It.Value(); Standard_Boolean found; GEOM::GEOM_Shape_var aShape = GeomGUI->ConvertIOinGEOMShape(IObject, found); // Handle(GEOM_AISShape) Shape = ConvertIOinGEOMAISShape(IObject, found, true); if ( found ) { file = QAD_FileDlg::getFileName(myDesktop, QString( IObject->getName() ) + ".stp", tr("GEOM_MEN_IMPORT_STEP"), tr("GEOM_MEN_EXPORT"), false); if ( !file.isEmpty() && !aShape->_is_nil() ) { QApplication::setOverrideCursor( Qt::waitCursor ) ; try { GeomGUI->myComponentGeom->ExportSTEP(strdup( file.latin1()), aShape); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } // //VRV: OCC 4.0 migration // status = aWriter.Transfer( Shape->Shape(), STEPControl_ManifoldSolidBrep ) ; // //VRV: OCC 4.0 migration // test = true ; // if ( status != IFSelect_RetDone ) { // QApplication::restoreOverrideCursor() ; // return false ; // } } } } // if(test) { // status = aWriter.Write( strdup(file.latin1()) ) ; // QApplication::restoreOverrideCursor() ; // return status ; // } break; } } QApplication::restoreOverrideCursor() ; } //===================================================================================== // function : Display() // purpose : Displays a CORBA shape //===================================================================================== bool GeometryGUI::Display( GEOM::GEOM_Shape_ptr aShape, Standard_CString name) { // MESSAGE ( "GeometryGUI::Display init ") Handle(GEOM_InteractiveObject) IO; SALOME_Selection* Sel = SALOME_Selection::Selection( myActiveStudy->getSelection() ); Sel->ClearIObjects(); if( aShape->_is_nil() ) { QAD_MessageBox::warn1 ( QAD_Application::getDesktop(), tr ("GEOM_WRN_WARNING"), tr ("GEOM_PRP_ABORT"), tr ("GEOM_BUT_OK") ); return false ; } TopoDS_Shape shape = ShapeReader.GetShape(myComponentGeom, aShape); if ( shape.IsNull() ) return false; SALOMEDS::Study_var aStudy = myActiveStudy->getStudyDocument(); SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder(); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeName_var aName; SALOMEDS::AttributePixMap_var aPixmap; SALOMEDS::SComponent_var father = aStudy->FindComponent("GEOM"); int aLocked = false; if (father->_is_nil()) { QAD_Operation* op = new SALOMEGUI_ImportOperation( myActiveStudy ); op->start(); aLocked = aStudy->GetProperties()->IsLocked(); if (aLocked) aStudy->GetProperties()->SetLocked(false); father = aStudyBuilder->NewComponent("GEOM"); anAttr = aStudyBuilder->FindOrCreateAttribute(father, "AttributeName"); aName = SALOMEDS::AttributeName::_narrow(anAttr); aName->SetValue( tr("GEOM_MEN_COMPONENT") ); anAttr = aStudyBuilder->FindOrCreateAttribute(father, "AttributePixMap"); aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr); aPixmap->SetPixMap( "ICON_OBJBROWSER_Geometry" ); myActiveStudy->updateObjBrowser(); if (aLocked) aStudy->GetProperties()->SetLocked(true); op->finish(); } // if (aLocked) return false; aStudyBuilder->DefineComponentInstance( father, myComponentGeom ); father->ComponentIOR( Fatherior ); TCollection_AsciiString nameG(""); Standard_CString Type; if ( TCollection_AsciiString(name).IsEqual(Standard_CString("")) ) { if ( TCollection_AsciiString(aShape->NameType()).IsEqual(Standard_CString("")) ) { Standard_CString type; GetShapeTypeString(shape,type); aShape->NameType( type ); nameG += TCollection_AsciiString( type ) + TCollection_AsciiString("_") + TCollection_AsciiString( GeomGUI->myNbGeom++ ) + TCollection_AsciiString("\0"); } else nameG += TCollection_AsciiString( aShape->NameType()) + TCollection_AsciiString("_") + TCollection_AsciiString( GeomGUI->myNbGeom++ ) + TCollection_AsciiString("\0"); } else nameG = TCollection_AsciiString(name); // VTK if ( myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { VTKViewer_RenderWindowInteractor* myRenderInter = ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor(); vtkRenderer *theRenderer = ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRenderer(); int themode = myRenderInter->GetDisplayMode(); vtkActorCollection* theActors = GEOM_AssemblyBuilder::BuildActors(shape,0,themode,Standard_True); theActors->InitTraversal(); vtkActor* anActor = (vtkActor*)theActors->GetNextActor(); IO = new GEOM_InteractiveObject(aShape->Name(), Fatherior, "GEOM"); while(!(anActor==NULL)) { GEOM_Actor* GActor = GEOM_Actor::SafeDownCast( anActor ); GActor->setIO( IO ); GActor->setName( nameG.ToCString() ); theRenderer->AddActor(GActor); anActor = (vtkActor*)theActors->GetNextActor(); } } // OCC else if ( myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); Handle(GEOM_AISShape) theResult = new GEOM_AISShape( shape, nameG.ToCString() ); theResult->SetShadingColor( myShadingColor ); IO = new GEOM_InteractiveObject(aShape->Name(), Fatherior, "GEOM"); theResult->setIO( IO ); theResult->setName( nameG.ToCString() ); /* Precaution : close any local context to permit the display */ if ( ic->HasOpenedContext() ) { ic->CloseAllContexts(); } // if(isInfinite) // theResult->SetInfiniteState() ; ic->Display(theResult); } Sel->AddIObject( IO, false ); myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame()->Repaint(); if ( Settings_AddInStudy ) GeomGUI->AddInStudy( false, IO ); return true; } //===================================================================================== // function : AddInStudy() // purpose : anIOShape or a selected shape //===================================================================================== bool GeometryGUI::AddInStudy( bool selection, const Handle(SALOME_InteractiveObject)& anIO) { SALOME_Selection* Sel = SALOME_Selection::Selection( myActiveStudy->getSelection() ); if ( !( !Settings_AddInStudy || selection ) ) { Sel->ClearIObjects(); } SALOMEDS::Study_var aStudy = myActiveStudy->getStudyDocument(); SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder(); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeName_var aName; SALOMEDS::AttributePixMap_var aPixmap; SALOMEDS::AttributeIOR_var anIOR; SALOMEDS::AttributeSelectable_var aSelAttr; SALOMEDS::SComponent_var father = aStudy->FindComponent("GEOM"); int aLocked = false; if (father->_is_nil()) { QAD_Operation* op = new SALOMEGUI_ImportOperation( myActiveStudy ); op->start(); aLocked = aStudy->GetProperties()->IsLocked(); if (aLocked) aStudy->GetProperties()->SetLocked(false); father = aStudyBuilder->NewComponent("GEOM"); anAttr = aStudyBuilder->FindOrCreateAttribute(father, "AttributeName"); aName = SALOMEDS::AttributeName::_narrow(anAttr); aName->SetValue( tr("GEOM_MEN_COMPONENT") ); anAttr = aStudyBuilder->FindOrCreateAttribute(father, "AttributePixMap"); aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr); aPixmap->SetPixMap( "ICON_OBJBROWSER_Geometry" ); if (aLocked) aStudy->GetProperties()->SetLocked(true); op->finish(); } // if (aLocked) return false; aStudyBuilder->DefineComponentInstance( father, myComponentGeom ); father->ComponentIOR( Fatherior ); SALOMEDS::SObject_var fatherSF = aStudy->FindObjectID(myActiveStudy->getActiveStudyFrame()->entry()); Handle(GEOM_AISShape) GAISShape; GEOM_Actor* GActor; Handle(GEOM_InteractiveObject) GIO; bool found = false; // VTK if ( myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { vtkRenderer *Renderer = ((VTKViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRenderer(); vtkActorCollection* theActors = Renderer->GetActors(); theActors->InitTraversal(); vtkActor *ac = theActors->GetNextActor(); while(!(ac==NULL)) { if ( ac->IsA("GEOM_Actor") ) { GEOM_Actor* anActor = GEOM_Actor::SafeDownCast( ac ); if ( anActor->hasIO() ) { Handle(SALOME_InteractiveObject) IO = anActor->getIO(); if ( IO->IsKind(STANDARD_TYPE(GEOM_InteractiveObject)) ) { GIO = Handle(GEOM_InteractiveObject)::DownCast( IO ); if ( anIO->isSame( GIO ) ) { found = true; GActor = anActor; break; } } } } ac = theActors->GetNextActor(); } if ( !found ) return false; } // OCC else if ( myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); AIS_ListOfInteractive List; ic->DisplayedObjects(List); AIS_ListIteratorOfListOfInteractive ite(List); while (ite.More()) { if (ite.Value()->IsInstance(STANDARD_TYPE(GEOM_AISShape))) { Handle(GEOM_AISShape) aSh = Handle(GEOM_AISShape)::DownCast(ite.Value()); if ( aSh->hasIO() ) { Handle(SALOME_InteractiveObject) IO = aSh->getIO(); if ( IO->IsKind(STANDARD_TYPE(GEOM_InteractiveObject)) ) { GIO = Handle(GEOM_InteractiveObject)::DownCast( IO ); if ( anIO->isSame( GIO ) ) { found = true; GAISShape = aSh; break; } } } } ite.Next(); } if ( !found ) return false; } if ( !Settings_AddInStudy || selection ) { QString Name = SALOMEGUI_NameDlg::getName( QAD_Application::getDesktop(), anIO->getName() ); if ( !Name.isEmpty() ) { // VTK if ( myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { GActor->setName( strdup(Name.latin1()) ); } // OCC else if ( myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { GAISShape->setName( strdup(Name.latin1()) ); } } else { return false; } } // open transaction QAD_Operation* op = new SALOMEGUI_ImportOperation( myActiveStudy ); op->start(); SALOMEDS::SObject_var newObj = aStudyBuilder->NewObject(father); GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( GIO->getIOR() ); /* For the shape inserted into the study we set its field 'studyshapeid' */ /* so the shape will contain its corresponding entry in the study Ocaf doc. */ aShape->StudyShapeId(newObj->GetID()) ; GIO->setEntry(newObj->GetID()); anAttr = aStudyBuilder->FindOrCreateAttribute(newObj, "AttributeIOR"); anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); anIOR->SetValue(aShape->Name()); anAttr = aStudyBuilder->FindOrCreateAttribute(newObj, "AttributeName"); aName = SALOMEDS::AttributeName::_narrow(anAttr); anAttr = aStudyBuilder->FindOrCreateAttribute(newObj, "AttributePixMap"); aPixmap = SALOMEDS::AttributePixMap::_narrow(anAttr); if ( aShape->ShapeType() == GEOM::COMPOUND ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_COMPOUND" ); } else if ( aShape->ShapeType() == GEOM::COMPSOLID ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_COMPSOLID" ); } else if ( aShape->ShapeType() == GEOM::SOLID ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_SOLID" ); } else if ( aShape->ShapeType() == GEOM::SHELL ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_SHELL" ); } else if ( aShape->ShapeType() == GEOM::FACE ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_FACE" ); } else if ( aShape->ShapeType() == GEOM::WIRE ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_WIRE" ); } else if ( aShape->ShapeType() == GEOM::EDGE ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_EDGE" ); } else if ( aShape->ShapeType() == GEOM::VERTEX ) { aPixmap->SetPixMap( "ICON_OBJBROWSER_VERTEX" ); } // VTK if ( myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { GActor->setIO( GIO ); aName->SetValue(GActor->getName()); } // OCC else if ( myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { GAISShape->setIO( GIO ); aName->SetValue(GAISShape->getName()); } SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(fatherSF); aStudyBuilder->Addreference(newObj1,newObj); GEOM::GEOM_Gen::ListOfIOR_var listIOR = new GEOM::GEOM_Gen::ListOfIOR; listIOR = myComponentGeom->GetReferencedObjects(aShape); if (listIOR->length()>0) { SALOMEDS::SObject_var Arguments = aStudyBuilder->NewObject(newObj); anAttr = aStudyBuilder->FindOrCreateAttribute(Arguments, "AttributeName"); aName = SALOMEDS::AttributeName::_narrow(anAttr); aName->SetValue(tr("GEOM_ARGUMENTS")); anAttr = aStudyBuilder->FindOrCreateAttribute(Arguments, "AttributeSelectable"); aSelAttr = SALOMEDS::AttributeSelectable::_narrow(anAttr); aSelAttr->SetSelectable(false); bool ObjectReferenced = false; for (unsigned int ind = 0; ind < listIOR->length();ind++) { SALOMEDS::SObject_var theObj = aStudy->FindObjectIOR(listIOR[ind]); if ( !theObj->_is_nil() ) { SALOMEDS::SObject_var RefObject = aStudyBuilder->NewObject(Arguments); aStudyBuilder->Addreference(RefObject, theObj); ObjectReferenced = true; } } if ( !ObjectReferenced ) aStudyBuilder->RemoveObject(Arguments); } op->finish(); if ( !Settings_AddInStudy || selection ) { myActiveStudy->updateObjBrowser(); } else { myActiveStudy->updateObjBrowser(false); Sel->AddIObject( GIO ); } // MESSAGE ( " highlihght done" ) return true; } //===================================================================================== // function : GetShapeFromIOR() // purpose : exist also as static method ! //===================================================================================== TopoDS_Shape GeometryGUI::GetShapeFromIOR( QString IOR ) { TopoDS_Shape result; if( IOR.stripWhiteSpace().isEmpty() ) return result; ORB_INIT &init = *SINGLETON_::Instance() ; CORBA::ORB_var& _orb = init.orb() ; CORBA::Object_var obj = _orb->string_to_object( (char*)(IOR.latin1()) ); if ( CORBA::is_nil( obj ) ) return result; GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( IOR ); if (!aShape->_is_nil()) { result = ShapeReader.GetShape( myComponentGeom, aShape ); } return result; } //===================================================================================== // function : SetSettings() // purpose : [static] //===================================================================================== bool GeometryGUI::SetSettings( QAD_Desktop* parent ) { /* Create or retrieve an object GeomGUI */ GeometryGUI::GetOrCreateGeometryGUI(parent); //DCQ parent->menuBar()->setItemEnabled( 504, false); // CORRECTING //DCQ parent->menuBar()->setItemEnabled( 6062, false); // RADIUS //VSR parent->menuBar()->setItemEnabled( 701, false); // AUTOMATIC COPY parent->menuBar()->setItemEnabled( 313, false); // SKETCH CONTRAINTS parent->menuBar()->setItemEnabled( 3131, false); // SKETCH SET PLAN /* Shading Color */ QString SCr = QAD_CONFIG->getSetting("Geometry:SettingsShadingColorRed"); QString SCg = QAD_CONFIG->getSetting("Geometry:SettingsShadingColorGreen"); QString SCb = QAD_CONFIG->getSetting("Geometry:SettingsShadingColorBlue"); if( !SCr.isEmpty() && !SCg.isEmpty() && !SCb.isEmpty() ) GeomGUI->myShadingColor = Quantity_Color ( SCr.toInt()/255., SCg.toInt()/255., SCb.toInt()/255., Quantity_TOC_RGB ); /* Wireframe or Shading */ int DisplayMode = 0; if ( parent->getActiveStudy()->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)parent->getActiveStudy()->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle(AIS_InteractiveContext) ic = v3d->getAISContext(); DisplayMode = ic->DisplayMode(); } else if ( parent->getActiveStudy()->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { VTKViewer_RenderWindowInteractor* myRenderInter = ((VTKViewer_ViewFrame*)parent->getActiveStudy()->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor(); DisplayMode = myRenderInter->GetDisplayMode(); } if ( DisplayMode == 1 ) parent->menuBar()->changeItem(6021, tr("GEOM_MEN_WIREFRAME") ); else parent->menuBar()->changeItem(6021, tr("GEOM_MEN_SHADING") ); /* Copy */ // QString Copy = QAD_CONFIG->getSetting("Geometry:SettingsCopy"); // if ( !Copy.isEmpty() ) { // Settings_Copy = Copy.toInt(); // QMenuData* pp; // parent->menuBar()->findItem(701,&pp); // pp->setItemChecked(701, Settings_Copy); // } QMenuData* pp; if ( parent->menuBar()->findItem(701,&pp) ) pp->removeItem(701); /* Add in Study */ QString AddInStudy = QAD_CONFIG->getSetting("Geometry:SettingsAddInStudy"); if ( !AddInStudy.isEmpty() ) Settings_AddInStudy = AddInStudy.toInt(); else Settings_AddInStudy = 1; parent->menuBar()->findItem(702,&pp); pp->setItemChecked(702, Settings_AddInStudy); /* step value */ QString S = QAD_CONFIG->getSetting( "Geometry:SettingsGeomStep" ); if( S.isEmpty() ) QAD_CONFIG->addSetting( "Geometry:SettingsGeomStep", "100" ); /* isos */ QAD_Study* ActiveStudy = parent->getActiveStudy(); int count = ActiveStudy->getStudyFramesCount(); bool ViewOCC = false; for ( int i = 0; i < count; i++ ) { if ( ActiveStudy->getStudyFrame(i)->getTypeView() == VIEW_OCC ) { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)ActiveStudy->getStudyFrame(i)->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); QString IsoU = QAD_CONFIG->getSetting("Geometry:SettingsIsoU"); QString IsoV = QAD_CONFIG->getSetting("Geometry:SettingsIsoV"); if ( !IsoU.isEmpty() ) ic->DefaultDrawer()->UIsoAspect()->SetNumber(IsoU.toInt()); if ( !IsoV.isEmpty() ) ic->DefaultDrawer()->VIsoAspect()->SetNumber(IsoV.toInt()); ViewOCC = true; } } QMenuBar* Mb = GeomGUI->myDesktop->getMainMenuBar(); Mb->setItemEnabled( 312, ViewOCC); //Sketch Mb->setItemEnabled( 309, ViewOCC); //SuppressFace Mb->setItemEnabled( 314, ViewOCC); //SuppressHole Mb->setItemEnabled( 703, ViewOCC);// ShadingColor Settings Mb->setItemEnabled( 704, ViewOCC);// Isos Settings return true; } //===================================================================================== // function : DefinePopup() // purpose : [static] //===================================================================================== void GeometryGUI::DefinePopup( QString & theContext, QString & theParent, QString & theObject ) { /* Create or retrieve an object GeomGUI */ GeometryGUI::GetOrCreateGeometryGUI(QAD_Application::getDesktop()); SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); theObject = ""; if ( Sel->IObjectCount() == 1 ) { Handle(SALOME_InteractiveObject) IO = Sel->firstIObject(); if (IO->hasEntry()) { SALOMEDS::SObject_var sobj = GeomGUI->myActiveStudy->getStudyDocument()->FindObjectID(IO->getEntry()); if (!sobj->_is_nil()) { SALOMEDS::SComponent_var scomp = sobj->GetFatherComponent(); if (strcmp(scomp->GetID(), IO->getEntry()) == 0) { // component is selected theObject = "Component"; } } } } if ( ( theParent.compare("Viewer")==0 ) ) { if ( GeomGUI->myState == CURRENT_SKETCH ) theContext = "Sketch"; else { if ( Sel->IObjectCount() > 0 ) theContext = ""; else theContext = "NothingSelected"; } } else theContext = ""; } //===================================================================================== // function : CustomPopup() // purpose : [static] //===================================================================================== bool GeometryGUI::CustomPopup( QAD_Desktop* parent, QPopupMenu* popup, const QString& theContext, const QString& theParent, const QString& theObject ) { /* Create or retrieve an object GeomGUI */ GeometryGUI::GetOrCreateGeometryGUI(parent); /* Deactivate any non modal dialog box to get the neutral point */ GeomGUI->EmitSignalDeactivateDialog() ; SALOME_Selection* Sel = SALOME_Selection::Selection( GeomGUI->myActiveStudy->getSelection() ); int nbSel = Sel->IObjectCount(); if ( (nbSel == 0) && ( theContext.compare("Sketch")!=0 ) ) return false; if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC) { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()-> getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); if ( theParent.compare("Viewer")==0 ) { if ( theContext.compare("Sketch")==0 ) { SketchStatus myCS = GeomGUI->mySketcher.GetCurrentStatus(); popup->setCheckable(TRUE); if (myCS==SEGMENT) { popup->setItemChecked(10000,true); popup->setItemChecked(10001,false); } else if (myCS==ARC_CHORD) { popup->setItemChecked(10000,false); popup->setItemChecked(10001,true); } return true; } else if (theObject.compare("Component") == 0) { popup->removeItem(QAD_DisplayOnly_Popup_ID); return true; } else { QFont f = QApplication::font(); f.setBold( TRUE ); if (nbSel==1) { Handle(SALOME_InteractiveObject) IObject = Sel->firstIObject(); popup->removeItem(QAD_TopLabel_Popup_ID); popup->insertItem( new CustomItem ( QString(IObject->getName()), f ), QAD_TopLabel_Popup_ID, 0 ); if ( IObject->hasEntry() ) popup->setItemEnabled( 801, false ); else popup->setItemEnabled( 801, true ); if (IObject->IsKind(STANDARD_TYPE(GEOM_InteractiveObject))) { Standard_Boolean found; Handle(GEOM_AISShape) Result = GeomGUI->ConvertIOinGEOMAISShape(IObject, found, true); if ( found ) { if ( Result->DisplayMode() == 1 ) popup->changeItem(8021, tr("GEOM_MEN_WIREFRAME") ); else popup->changeItem(8021, tr("GEOM_MEN_SHADING") ); } } if ( !(v3d->isInViewer( IObject ) && v3d->isVisible( IObject )) ) popup->removeItem(QAD_Erase_Popup_ID); else popup->removeItem(QAD_Display_Popup_ID); } else { popup->removeItem(QAD_DisplayOnly_Popup_ID); popup->removeItem(QAD_TopLabel_Popup_ID); popup->insertItem( new CustomItem ( tr("GEOM_MEN_POPUP_NAME").arg(nbSel), f ), QAD_TopLabel_Popup_ID, 0 ); popup->setItemEnabled( 801, false ); } } return true; } else if ( theParent.compare("ObjectBrowser")==0 ) { popup->removeItem(QAD_TopLabel_Popup_ID); int id = popup->idAt(0); // separator if (id < 0) popup->removeItem(id); // checking for GEOM label in the selected list SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); Handle(SALOME_InteractiveObject) anIObject; bool useSubItems = false; bool needOpen = false; bool needDisplay = false; bool needErase = false; SALOMEDS::GenericAttribute_var aTmpAttr; for(;It.More();It.Next()) { anIObject = It.Value(); if (!anIObject->hasEntry()) continue; if (v3d->isInViewer(anIObject) && v3d->isVisible(anIObject)) needErase = true; else needDisplay = true; SALOMEDS::SObject_var obj = GeomGUI->myActiveStudy->getStudyDocument()->FindObjectID( anIObject->getEntry() ); if (!obj->_is_nil()) { GEOM::GEOM_Shape_var aShape; if (obj->FindAttribute(aTmpAttr, "AttributeIOR")) { char *str = SALOMEDS::AttributeIOR::_narrow(aTmpAttr)->Value(); if (str && strlen(str)) aShape = GeomGUI->myComponentGeom-> GetIORFromString(str); } else if (obj->FindAttribute(aTmpAttr, "AttributePersistentRef")) needOpen = true; if (aShape->_is_nil()) { SALOMEDS::ChildIterator_var anIter = GeomGUI->myActiveStudy-> getStudyDocument()->NewChildIterator(obj); while (anIter->More()) { SALOMEDS::SObject_var subobj = anIter->Value(); if (subobj->FindAttribute(aTmpAttr, "AttributeIOR")) { useSubItems = true; needErase = true; needDisplay = true; } else if (subobj->FindAttribute(aTmpAttr, "AttributePersistentRef")) { needOpen = true; useSubItems = true; } anIter->Next(); } } } } // remove useless popup items if (nbSel != 1) popup->removeItem(901); // rename if (useSubItems) popup->removeItem(QAD_DisplayOnly_Popup_ID); // display only if (!needOpen) { int index = popup->indexOf(9024); popup->removeItem(9024); // open popup->removeItemAt(index); // separator under Open if (!needDisplay) popup->removeItem(QAD_Display_Popup_ID); if (!needErase) popup->removeItem(QAD_Erase_Popup_ID); if (!needDisplay && !needErase) { int id = popup->idAt(popup->count()-1); // last item popup->removeItem(id); // separator } } else { popup->removeItem(QAD_DisplayOnly_Popup_ID); // display only popup->removeItem(QAD_Display_Popup_ID); popup->removeItem(QAD_Erase_Popup_ID); if (nbSel!=1) { int id = popup->idAt(popup->count()-1); // last item popup->removeItem(id); // separator } } return true; } // MESSAGE ( " CUSTOM POPUP VIEWER OCC done. ") } else if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK) { // MESSAGE ( " CUSTOM POPUP VIEWER VTK ") if ( ( theParent.compare("Viewer")==0 ) ) { popup->setItemEnabled( 8033, false ); if (theObject.compare("Component") == 0) { popup->removeItem(QAD_DisplayOnly_Popup_ID); return true; } //int id = popup->idAt(0); QFont f = QApplication::font(); f.setBold( TRUE ); if (nbSel==1) { Handle(SALOME_InteractiveObject) IObject = Sel->firstIObject(); popup->removeItem(QAD_TopLabel_Popup_ID); popup->insertItem( new CustomItem ( QString(IObject->getName()), f ), QAD_TopLabel_Popup_ID, 0 ); if ( IObject->hasEntry() ) { popup->setItemEnabled( 801, false ); SALOMEDS::Study_var aStudy = GeomGUI->myActiveStudy->getStudyDocument(); SALOMEDS::SObject_var SO = aStudy->FindObjectID( IObject->getEntry() ); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeIOR_var anIOR; if ( !SO->_is_nil() ) { if (SO->FindAttribute(anAttr, "AttributeIOR") ) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); Standard_Boolean found; GEOM_Actor* Result = GeomGUI->ConvertIORinGEOMActor(anIOR->Value(), found, true); if ( found ) { if ( Result->getDisplayMode() == 1 ) popup->changeItem(8021, "Wireframe" ); else popup->changeItem(8021, "Shading" ); if ( !Result->GetVisibility() ) popup->removeItem(QAD_Erase_Popup_ID); else popup->removeItem(QAD_Display_Popup_ID); } else popup->removeItem(QAD_Erase_Popup_ID); } } } else popup->setItemEnabled( 801, true ); } else { popup->removeItem(QAD_DisplayOnly_Popup_ID); popup->removeItem(QAD_TopLabel_Popup_ID); popup->insertItem( new CustomItem ( tr("GEOM_MEN_POPUP_NAME").arg(nbSel), f ), QAD_TopLabel_Popup_ID, 0 ); popup->setItemEnabled( 801, false ); } return true; } else if ( theParent.compare("ObjectBrowser")==0 ) { popup->removeItem(QAD_TopLabel_Popup_ID); int id = popup->idAt(0); // separator if (id < 0) popup->removeItem(id); // checking for GEOM label in the selected list SALOME_ListIteratorOfListIO It( Sel->StoredIObjects() ); Handle(SALOME_InteractiveObject) anIObject; bool useSubItems = false; bool needOpen = false; bool needDisplay = false; bool needErase = false; SALOMEDS::GenericAttribute_var aTmpAttr; VTKViewer_RenderWindowInteractor* myRenderInter= ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy-> getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor(); for(;It.More();It.Next()) { anIObject = It.Value(); if ( !anIObject->hasEntry() ) continue; if (myRenderInter->isInViewer(anIObject) && myRenderInter->isVisible(anIObject)) needErase = true; else needDisplay = true; SALOMEDS::SObject_var obj = GeomGUI->myActiveStudy->getStudyDocument() ->FindObjectID( anIObject->getEntry() ); if (!obj->_is_nil()) { GEOM::GEOM_Shape_var aShape; if (obj->FindAttribute(aTmpAttr, "AttributeIOR")){ char *str = SALOMEDS::AttributeIOR::_narrow(aTmpAttr)->Value(); if (str && strlen(str)) aShape = GeomGUI->myComponentGeom->GetIORFromString(str); } else if (obj->FindAttribute(aTmpAttr, "AttributePersistentRef")) needOpen = true; if (aShape->_is_nil()) { SALOMEDS::ChildIterator_var anIter = GeomGUI->myActiveStudy->getStudyDocument()->NewChildIterator(obj); while (anIter->More()) { SALOMEDS::SObject_var subobj = anIter->Value(); if (subobj->FindAttribute(aTmpAttr, "AttributeIOR")) { useSubItems = true; needDisplay = true; needErase = true; } else if (subobj->FindAttribute(aTmpAttr, "AttributePersistentRef")) { needOpen = true; useSubItems = true; } anIter->Next(); } } } } // remove useless popup items if (nbSel != 1) popup->removeItem(901); // rename if (useSubItems) popup->removeItem(QAD_DisplayOnly_Popup_ID); // display only if (!needOpen) { int index = popup->indexOf(9024); popup->removeItem(9024); // open popup->removeItemAt(index); // separator under Open if (!needDisplay) popup->removeItem(QAD_Display_Popup_ID); if (!needErase) popup->removeItem(QAD_Erase_Popup_ID); if (!needDisplay && !needErase) { int id = popup->idAt(popup->count()-1); // last item popup->removeItem(id); // separator } } else { popup->removeItem(QAD_DisplayOnly_Popup_ID); // display only popup->removeItem(QAD_Display_Popup_ID); popup->removeItem(QAD_Erase_Popup_ID); if (nbSel!=1) { int id = popup->idAt(popup->count()-1); // last item popup->removeItem(id); // separator } } return true; // MESSAGE ( " CUSTOM POPUP VIEWER VTK done.") } } else { // other viewer types not supported. while (1) { int id = popup->idAt(0); if (id <= QAD_TopLabel_Popup_ID && id != -1) popup->removeItemAt(0); else break; } popup->removeItem(QAD_DisplayOnly_Popup_ID); popup->removeItem(QAD_Display_Popup_ID); popup->removeItem(QAD_Erase_Popup_ID); int id = popup->idAt(popup->count()-1); // last item if (id < 0 && id != -1) popup->removeItem(id); // separator return false; } return false; } void GeometryGUI::BuildPresentation(const Handle(SALOME_InteractiveObject)& theIO) { /* Create or retrieve an object GeomGUI */ GeometryGUI::GetOrCreateGeometryGUI(QAD_Application::getDesktop()); SALOMEDS::Study_var aStudy = GeomGUI->myActiveStudy->getStudyDocument(); SALOMEDS::StudyBuilder_var aStudyBuilder = aStudy->NewBuilder(); OCCViewer_Viewer3d* v3d; Handle(AIS_InteractiveContext) ic; vtkRenderer* Renderer; if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { v3d = ((OCCViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); ic = v3d->getAISContext(); } else if ( GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { Renderer = ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRenderer(); } else return; if (theIO.IsNull()) MESSAGE("BuildPresentation(): null SALOME_InteractiveObject passed") if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_VTK ) { // VTK SALOMEDS::SObject_var fatherSF = aStudy->FindObjectID(GeomGUI->myActiveStudy->getActiveStudyFrame()->entry()); SALOMEDS::SObject_var obj = aStudy->FindObjectID( theIO->getEntry() ); VTKViewer_RenderWindowInteractor* myRenderInter= ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRWInteractor(); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeName_var aName; SALOMEDS::AttributeIOR_var anIOR; if(myRenderInter->isInViewer(theIO)) { myRenderInter->Display(theIO, false); } else { // Create new actor if ( !obj->_is_nil() ) { if ( obj->FindAttribute(anAttr, "AttributeIOR")) { // this SObject may be GEOM module root SObject bool useSubItems = false; SALOMEDS::ChildIterator_var anIter = GeomGUI->myActiveStudy->getStudyDocument()->NewChildIterator(obj); if (GeomGUI->myComponentGeom->GetIORFromString(SALOMEDS::AttributeIOR::_narrow(anAttr)->Value())->_is_nil()) { while (anIter->More() && !useSubItems) { SALOMEDS::SObject_var subobj = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttr; if (subobj->FindAttribute(aTmpAttr, "AttributeIOR")) { if (!GeomGUI->myComponentGeom->GetIORFromString(SALOMEDS::AttributeIOR::_narrow(aTmpAttr)->Value())->_is_nil()) { anAttr = aTmpAttr; obj = subobj; useSubItems = true; } else anIter->Next(); } else anIter->Next(); } } while(useSubItems?anIter->More():!anAttr->_is_nil()) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); GEOM::GEOM_Shape_var aShape = GeomGUI->myComponentGeom->GetIORFromString(anIOR->Value()); TopoDS_Shape Shape = ShapeReader.GetShape(GeomGUI->myComponentGeom,aShape); if (obj->FindAttribute(anAttr, "AttributeName")) { aName = SALOMEDS::AttributeName::_narrow(anAttr); vtkRenderer* theRenderer = ((VTKViewer_ViewFrame*)GeomGUI->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getRenderer(); vtkActorCollection* theAllActors = theRenderer->GetActors(); theAllActors->InitTraversal(); vtkActor* actor = (vtkActor*)theAllActors->GetNextActor(); Handle(SALOME_InteractiveObject) anIObj; // don't create new study object if it already exists bool isDisplayed = false; while(!(actor==NULL)) { SALOME_Actor* Gactor = SALOME_Actor::SafeDownCast(actor); if (Gactor!=NULL) { if (Gactor->hasIO()) { if (strcmp(Gactor->getIO()->getEntry(),obj->GetID())==0) { isDisplayed = true; anIObj = Gactor->getIO(); if (!anIObj.IsNull()) myRenderInter->Display(anIObj, false); } } } actor=(vtkActor*)(theAllActors->GetNextActor()); } if (!isDisplayed) { // open transaction QAD_Operation* op = new SALOMEGUI_ImportOperation( GeomGUI->myActiveStudy ); op->start(); SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(fatherSF); aStudyBuilder->Addreference(newObj1, obj); // commit transaction op->finish(); vtkRenderWindow *renWin = theRenderer->GetRenderWindow(); int themode = myRenderInter->GetDisplayMode(); vtkActorCollection* theActors = GEOM_AssemblyBuilder::BuildActors(Shape,0,themode,Standard_True); theActors->InitTraversal(); vtkActor* anActor = (vtkActor*)theActors->GetNextActor(); while(!(anActor==NULL)) { GEOM_Actor* GActor = GEOM_Actor::SafeDownCast( anActor ); Handle(GEOM_InteractiveObject) IO = new GEOM_InteractiveObject(anIOR->Value(), Fatherior,"GEOM"); IO->setEntry(obj->GetID()); GActor->setIO( IO ); GActor->setName( theIO->getName() ); theRenderer->AddActor(GActor); // renWin->Render(); anActor = (vtkActor*)theActors->GetNextActor(); } } } // next item iteration if (useSubItems) { anIter->Next(); anAttr = SALOMEDS::GenericAttribute::_nil(); while (anIter->More() && anAttr->_is_nil()) { SALOMEDS::SObject_var subobject = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttribute; if (subobject->FindAttribute(aTmpAttribute, "AttributeIOR")) { anAttr = aTmpAttribute; obj = subobject; } else anIter->Next(); } } else anAttr = SALOMEDS::GenericAttribute::_nil(); } } } } // No viewer update should be done here! //myRenderInter->Render(); //GeomGUI->myActiveStudy->updateObjBrowser( true ); } else if (GeomGUI->myActiveStudy->getActiveStudyFrame()->getTypeView() == VIEW_OCC ) { SALOMEDS::SObject_var fatherSF = aStudy->FindObjectID( GeomGUI->myActiveStudy->getActiveStudyFrame()->entry()); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeName_var aName; SALOMEDS::AttributeIOR_var anIOR; if ( v3d->isInViewer( theIO, true ) ) { Standard_Boolean found; Handle(GEOM_AISShape) aSh = GeomGUI->ConvertIOinGEOMAISShape( theIO, found, true ); if ( found ) { ic->Display(aSh, false); ic->AddOrRemoveCurrentObject(aSh, false); } } else { SALOMEDS::SObject_var obj = aStudy->FindObjectID( theIO->getEntry() ); if ( !obj->_is_nil() ) { MESSAGE("BuildPresentation(): SObject not null") if ( obj->FindAttribute(anAttr, "AttributeIOR")) { MESSAGE("BuildPresentation(): SObject has IOR") // this SObject may be GEOM module root SObject bool useSubItems = false; SALOMEDS::ChildIterator_var anIter = GeomGUI->myActiveStudy->getStudyDocument()->NewChildIterator(obj); if (GeomGUI->myComponentGeom->GetIORFromString(SALOMEDS::AttributeIOR::_narrow(anAttr)->Value())->_is_nil()) { while (anIter->More() && !useSubItems) { SALOMEDS::SObject_var subobj = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttr; if (subobj->FindAttribute(aTmpAttr, "AttributeIOR")) { if (!GeomGUI->myComponentGeom->GetIORFromString(SALOMEDS::AttributeIOR::_narrow(aTmpAttr)->Value())->_is_nil()) { anAttr = aTmpAttr; obj = subobj; useSubItems = true; } else anIter->Next(); } else anIter->Next(); } } while(useSubItems?anIter->More():!anAttr->_is_nil()) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); GEOM::GEOM_Shape_var aShape = GeomGUI->myComponentGeom->GetIORFromString(anIOR->Value()); TopoDS_Shape Shape = ShapeReader.GetShape(GeomGUI->myComponentGeom,aShape); if (Shape.IsNull()) MESSAGE("BuildPresentation(): TopoDS_Shape is null!") if (obj->FindAttribute(anAttr, "AttributeName")) { MESSAGE("BuildPresentation(): SObject has Name") aName = SALOMEDS::AttributeName::_narrow(anAttr); // searchin for already displayed objects with the same shape AIS_ListOfInteractive aDisplayed; ic->DisplayedObjects(aDisplayed); AIS_ListIteratorOfListOfInteractive anIObjects(aDisplayed); Handle(AIS_Shape) anAISShape; for(;anIObjects.More();anIObjects.Next()) { anAISShape = Handle(AIS_Shape)::DownCast(anIObjects.Value()); if (!anAISShape.IsNull()) { if (anAISShape->Shape().IsSame(Shape)) break; anAISShape.Nullify(); } } if (!anAISShape.IsNull()) { if (!ic->IsDisplayed(anAISShape)) ic->Display(anAISShape, false); } else { if (!useSubItems) { // open transaction QAD_Operation* op = new SALOMEGUI_ImportOperation( GeomGUI->myActiveStudy ); op->start(); if (fatherSF->_is_nil()) MESSAGE("BuildPresentation(): fatherSF is nil!") SALOMEDS::SObject_var newObj1 = aStudyBuilder->NewObject(fatherSF); aStudyBuilder->Addreference(newObj1, obj); // commit transaction op->finish(); } Handle(GEOM_AISShape) aSh = new GEOM_AISShape(Shape, aName->Value()); aSh->SetShadingColor( GeomGUI->myShadingColor ); Handle(GEOM_InteractiveObject) IO = new GEOM_InteractiveObject(anIOR->Value(), Fatherior, "GEOM"); IO->setEntry(obj->GetID()); aSh->setIO( IO ); aSh->setName( aName->Value() ); ic->Display (aSh, false); if (!useSubItems) ic->AddOrRemoveCurrentObject(aSh, false); } } // next item iteration if (useSubItems) { anIter->Next(); anAttr=SALOMEDS::GenericAttribute::_nil(); while (anIter->More() && anAttr->_is_nil()) { SALOMEDS::SObject_var subobject = anIter->Value(); SALOMEDS::GenericAttribute_var aTmpAttribute; if (subobject->FindAttribute(aTmpAttribute, "AttributeIOR")) { anAttr = aTmpAttribute; obj = subobject; } else anIter->Next(); } } else anAttr = SALOMEDS::GenericAttribute::_nil(); } } } } // No viewer update should be done here! //GeomGUI->myActiveStudy->updateObjBrowser( true ); //ic->UpdateCurrentViewer(); } } //======================================================================= // function : Parameter() // purpose : return a parameter (float) from a dialog box // // avalue1 : is a float or integer used as a default value displayed // aTitle1 : is the title for aValue1 // aTitle : is the main title // bottom : maximum value to be entered // top : minimum value to be entered // decimals : number of decimals //======================================================================= double GeometryGUI::Parameter( Standard_Boolean& res, const char* aValue1, const char* aTitle1, const char* aTitle, const double bottom, const double top, const int decimals ) { GeometryGUI_aParameterDlg * Dialog = new GeometryGUI_aParameterDlg(aValue1, aTitle1, QAD_Application::getDesktop(), aTitle, TRUE, 0, bottom, top, decimals) ; int r = Dialog->exec() ; float X = 0.0 ; if ( r == QDialog::Accepted ) { res = Standard_True; X = Dialog->getValue(); } else res = Standard_False; delete Dialog; return X; } //======================================================================= // function : OnSketchSegment() // purpose : //======================================================================= void GeometryGUI::OnSketchSegment() { this->mySketcher.ChangeMode(SEGMENT); } //======================================================================= // function : OnSketchArc() // purpose : //======================================================================= void GeometryGUI::OnSketchArc() { this->mySketcher.ChangeMode(ARC_CHORD); } //======================================================================= // function : OnSketchSetAngle() // purpose : //======================================================================= void GeometryGUI::OnSketchSetAngle() { Standard_Real anAngle = this->mySketcher.GetSegmentAngle()/PI180; Sketch::fitInResol(anAngle); Standard_Boolean res = false ; QString Value = QString("%1").arg( anAngle ); anAngle = Parameter(res, Value, tr("GEOM_MEN_ANGLE"), tr("GEOM_MEN_ENTER_ANGLE"), -180.0, +180.0, 6 )*PI180 ; if( res ) { this->mySketcher.SetSegmentAngle(anAngle); QMenuBar* Mb = this->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(3133,&pp); pp->setItemChecked(3133,false); item = Mb->findItem(3134,&pp); pp->setItemChecked(3134,false); } } //======================================================================= // function : OnSketchSetx() // purpose : //======================================================================= void GeometryGUI::OnSketchSetx() { Standard_Boolean res = false; double X = Parameter( res, "0.", tr("GEOM_MEN_X"), tr("GEOM_MEN_SKETCHER_X"), 2.0 * Precision::Confusion(), 1E6, 6 ) ; if (res) this->mySketcher.SetXDimension(X); QMenuBar* Mb = this->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(3133,&pp); pp->setItemChecked(3133,false); item = Mb->findItem(3134,&pp); pp->setItemChecked(3134,false); } //======================================================================= // function : OnSketchSety() // purpose : //======================================================================= void GeometryGUI::OnSketchSety() { Standard_Boolean res = false; double Y = Parameter( res, "0.", tr("GEOM_MEN_Y"), tr("GEOM_MEN_SKETCHER_Y"), 2.0 * Precision::Confusion(), 1E6, 6 ) ; if (res) this->mySketcher.SetYDimension(Y); QMenuBar* Mb = this->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(3133,&pp); pp->setItemChecked(3133,false); item = Mb->findItem(3134,&pp); pp->setItemChecked(3134,false); } //======================================================================= // function : OnSketchDelete() // purpose : //======================================================================= void GeometryGUI::OnSketchDelete() { if (GeomGUI->mySketcher.GetmyEdgesNumber() == 1 ) { QMenuBar* Mb = GeomGUI->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(313,&pp); pp->setItemEnabled( 313, false); // SKETCH CONTRAINTS GeomGUI->mySketcher.SetTransitionStatus(NOCONSTRAINT); } if (this->mySketcher.Delete()) GeomGUI->ResetState(); } //======================================================================= // function : OnSketchClose() // purpose : //======================================================================= void GeometryGUI::OnSketchClose() { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)this->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) myContext = v3d->getAISContext(); TopoDS_Wire W = this->mySketcher.Close(); if ( !W.IsNull() ) { // GEOM::GEOM_Gen::ListOfIOR_var listShapes = new GEOM::GEOM_Gen::ListOfIOR; listShapes->length(0); unsigned int i = 0; BRepTools_WireExplorer Ex(W); while ( Ex.More() ) { TopoDS_Edge E = Ex.Current(); gp_Pnt pt1 , pt2 ; pt1 = BRep_Tool::Pnt(TopExp::FirstVertex(E)); pt2 = BRep_Tool::Pnt(TopExp::LastVertex(E)); gp_Pnt CenterPoint; Handle(Geom_Curve) Curve; Handle(Geom_Circle) Circle; gp_Circ Circ; Standard_Real First,Last; Curve = BRep_Tool::Curve(E,First,Last); if(Curve->IsKind(STANDARD_TYPE(Geom_Circle))) { Circle = Handle(Geom_Circle)::DownCast(Curve); // pointer on geom_circ Circ = Circle->Circ(); // gp_Circ Curve->D0( (First + Last) / 2. , CenterPoint ); GEOM::PointStruct pI = myComponentGeom->MakePointStruct( pt1.X(), pt1.Y(), pt1.Z() ); GEOM::PointStruct pC = myComponentGeom->MakePointStruct( CenterPoint.X(), CenterPoint.Y(), CenterPoint.Z() ); GEOM::PointStruct pE = myComponentGeom->MakePointStruct( pt2.X(), pt2.Y(), pt2.Z() ); GEOM::GEOM_Shape_var arc; try { arc = myComponentGeom->MakeArc(pI, pC, pE) ; } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } listShapes->length(i+1); listShapes[i] = strdup(arc->Name()); i++; } else { GEOM::PointStruct pI = myComponentGeom->MakePointStruct( pt1.X(), pt1.Y(), pt1.Z() ); GEOM::PointStruct pE = myComponentGeom->MakePointStruct( pt2.X(), pt2.Y(), pt2.Z() ); GEOM::GEOM_Shape_var segment; try { segment = myComponentGeom->MakeEdge(pI,pE) ; } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } listShapes->length(i+1); listShapes[i] = strdup(segment->Name()); i++; } Ex.Next(); } GEOM::GEOM_Shape_var Wire = myComponentGeom->MakeWire(listShapes) ; TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, Wire); Standard_CString type; GetShapeTypeString(S,type); Wire->NameType( type ); if ( Display(Wire, "" )) { QAD_Application::getDesktop()->putInfo(tr("GEOM_PRP_DONE")); } } GeomGUI->ResetState(); QMenuBar* Mb = this->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(313,&pp); pp->setItemEnabled( 313, false); // SKETCH CONTRAINTS GeomGUI->mySketcher.SetTransitionStatus(NOCONSTRAINT); } //======================================================================= // function : OnSketchEnd() // purpose : //======================================================================= void GeometryGUI::OnSketchEnd() { OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)this->myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) myContext = v3d->getAISContext(); TopoDS_Wire W = this->mySketcher.End(); if (!W.IsNull()) { // GEOM::GEOM_Gen::ListOfIOR_var listShapes = new GEOM::GEOM_Gen::ListOfIOR; listShapes->length(0); unsigned int i = 0; BRepTools_WireExplorer Ex(W); while ( Ex.More() ) { TopoDS_Edge E = TopoDS::Edge( Ex.Current() ); gp_Pnt pt1 , pt2 ; pt1 = BRep_Tool::Pnt(TopExp::FirstVertex(E)); pt2 = BRep_Tool::Pnt(TopExp::LastVertex(E)); gp_Pnt CenterPoint; Handle(Geom_Curve) Curve; Handle(Geom_Circle) Circle; gp_Circ Circ; Standard_Real First,Last; Curve = BRep_Tool::Curve(E,First,Last); if(Curve->IsKind(STANDARD_TYPE(Geom_Circle))) { Circle = Handle(Geom_Circle)::DownCast(Curve); // pointer on geom_circ Circ = Circle->Circ(); // gp_Circ Curve->D0( (First + Last) / 2. , CenterPoint ); GEOM::PointStruct pI = myComponentGeom->MakePointStruct( pt1.X(), pt1.Y(), pt1.Z() ); GEOM::PointStruct pC = myComponentGeom->MakePointStruct( CenterPoint.X(), CenterPoint.Y(), CenterPoint.Z() ); GEOM::PointStruct pE = myComponentGeom->MakePointStruct( pt2.X(), pt2.Y(), pt2.Z() ); GEOM::GEOM_Shape_var arc; try { arc = myComponentGeom->MakeArc(pI, pC, pE) ; } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } listShapes->length(i+1); listShapes[i] = strdup(arc->Name()); i++; } else { GEOM::PointStruct pI = myComponentGeom->MakePointStruct( pt1.X(), pt1.Y(), pt1.Z() ); GEOM::PointStruct pE = myComponentGeom->MakePointStruct( pt2.X(), pt2.Y(), pt2.Z() ); GEOM::GEOM_Shape_var segment; try { segment = myComponentGeom->MakeEdge(pI,pE) ; } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } listShapes->length(i+1); listShapes[i] = strdup(segment->Name()); i++; } Ex.Next(); } GEOM::GEOM_Shape_var Wire = myComponentGeom->MakeWire(listShapes) ; TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, Wire); Standard_CString type; GetShapeTypeString(S,type); Wire->NameType( type ); if ( Display(Wire, "") ) { QAD_Application::getDesktop()->putInfo(tr("GEOM_PRP_DONE")); } } GeomGUI->ResetState(); QMenuBar* Mb = this->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(313,&pp); pp->setItemEnabled( 313, false); // SKETCH CONTRAINTS GeomGUI->mySketcher.SetTransitionStatus(NOCONSTRAINT); } //======================================================================= // function : OnSettingsNoconstraint() // purpose : //======================================================================= void GeometryGUI::OnSettingsNoconstraint() { this->mySketcher.SetTransitionStatus(NOCONSTRAINT); } //======================================================================= // function : OnSettingsPerpendicular() // purpose : //======================================================================= void GeometryGUI::OnSettingsPerpendicular() { this->mySketcher.SetTransitionStatus(PERPENDICULAR); } //======================================================================= // function : OnSettingsTangent() // purpose : //======================================================================= void GeometryGUI::OnSettingsTangent() { this->mySketcher.SetTransitionStatus(TANGENT); } //======================================================================= // function : OnSketchOptionsOnoffangledimension() // purpose : //======================================================================= void GeometryGUI::OnSketchOptionsOnoffangledimension() { QMenuBar* Mb = this->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(10011,&pp); pp->setItemChecked(10011,!pp->isItemChecked(10011)); this->mySketcher.SetParameterVisibility(ANGLE_PARAMETER,pp->isItemChecked(10011)); } //======================================================================= // function : OnSketchOptionsOnofflengthdimension() // purpose : //======================================================================= void GeometryGUI::OnSketchOptionsOnofflengthdimension() { QMenuBar* Mb = this->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(10010,&pp); pp->setItemChecked(10010,!pp->isItemChecked(10010)); this->mySketcher.SetParameterVisibility(LENGTH_PARAMETER,pp->isItemChecked(10010)); } //======================================================================= // function : OnSketchOptionsOnoffradiusdimension() // purpose : //======================================================================= void GeometryGUI::OnSketchOptionsOnoffradiusdimension() { QMenuBar* Mb = this->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(10012,&pp); pp->setItemChecked(10012,!pp->isItemChecked(10012)); this->mySketcher.SetParameterVisibility(RADIUS_PARAMETER,pp->isItemChecked(10012)); } //======================================================================= // function : OnSketchOptionsOnoffxdimension() // purpose : //======================================================================= void GeometryGUI::OnSketchOptionsOnoffxdimension() { QMenuBar* Mb = this->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(10013,&pp); pp->setItemChecked(10013,!pp->isItemChecked(10013)); this->mySketcher.SetParameterVisibility(XVALUE_PARAMETER,pp->isItemChecked(10013)); } //======================================================================= // function : OnSketchOptionsOnoffydimension() // purpose : //======================================================================= void GeometryGUI::OnSketchOptionsOnoffydimension() { QMenuBar* Mb = this->myDesktop->getMainMenuBar(); QMenuData* pp; QMenuItem* item = Mb->findItem(10014,&pp); pp->setItemChecked(10014,!pp->isItemChecked(10014)); this->mySketcher.SetParameterVisibility(YVALUE_PARAMETER,pp->isItemChecked(10014)); } //======================================================================= // function : Archimede() // purpose : //======================================================================= void GeometryGUI::Archimede( const Handle(SALOME_InteractiveObject)& IO, const double aWeight, const double aWaterDensity, const double aMeshingDeflection ) { try { if ( IO->IsInstance(STANDARD_TYPE(GEOM_InteractiveObject)) ) { Handle(GEOM_InteractiveObject) GIO = Handle(GEOM_InteractiveObject)::DownCast( IO ); GEOM::GEOM_Shape_var Shape = GeomGUI->myComponentGeom->GetIORFromString( GIO->getIOR() ); GEOM::GEOM_Shape_var Result = GeomGUI->myComponentGeom->Archimede( Shape, aWeight, aWaterDensity, aMeshingDeflection); Result->NameType(tr("GEOM_PLANE")); if ( Display(Result, "") ) { QAD_Application::getDesktop()->putInfo(tr("GEOM_PRP_DONE")); } return; } if ( IO->hasEntry() ) { SALOMEDS::Study_var aStudy = GeomGUI->myActiveStudy->getStudyDocument(); SALOMEDS::SObject_var obj = aStudy->FindObjectID( IO->getEntry() ); SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeIOR_var anIOR; if ( !obj->_is_nil() ) { if (obj->FindAttribute(anAttr, "AttributeIOR")) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); GEOM::GEOM_Shape_var Shape = GeomGUI->myComponentGeom->GetIORFromString( anIOR->Value() ); GEOM::GEOM_Shape_var Result = GeomGUI->myComponentGeom->Archimede( Shape, aWeight, aWaterDensity, aMeshingDeflection); Result->NameType(tr("GEOM_PLANE")); if ( Display(Result, "") ) { QAD_Application::getDesktop()->putInfo(tr("GEOM_PRP_DONE")); } } } } } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } } //===================================================================================== // EXPORTED METHODS //===================================================================================== extern "C" { bool OnGUIEvent(int theCommandID, QAD_Desktop* parent) { return GeometryGUI::OnGUIEvent(theCommandID, parent); } bool OnKeyPress (QKeyEvent* pe, QAD_Desktop* parent, QAD_StudyFrame* studyFrame) { return GeometryGUI::OnKeyPress (pe, parent, studyFrame); } bool OnMousePress (QMouseEvent* pe, QAD_Desktop* parent, QAD_StudyFrame* studyFrame) { return GeometryGUI::OnMousePress (pe, parent, studyFrame); } bool OnMouseMove (QMouseEvent* pe, QAD_Desktop* parent, QAD_StudyFrame* studyFrame) { return GeometryGUI::OnMouseMove (pe, parent, studyFrame); } bool SetSettings ( QAD_Desktop* parent ) { return GeometryGUI::SetSettings( parent ); } bool customPopup ( QAD_Desktop* parent, QPopupMenu* popup, const QString & theContext, const QString & theParent, const QString & theObject ) { return GeometryGUI::CustomPopup( parent, popup, theContext, theParent, theObject ); } void definePopup ( QString & theContext, QString & theParent, QString & theObject ) { GeometryGUI::DefinePopup( theContext, theParent, theObject ); } bool activeStudyChanged ( QAD_Desktop* parent ) { GeometryGUI::activeStudyChanged( parent ); } void buildPresentation ( const Handle(SALOME_InteractiveObject)& theIO ) { GeometryGUI::BuildPresentation(theIO); } void supportedViewType(int* buffer, int bufferSize) { if (!buffer || !bufferSize) return; buffer[0] = (int)VIEW_OCC; if (--bufferSize) buffer[1] = (int)VIEW_VTK; } } //===================================================================================== // function : OnFilletGetAll() // purpose : //===================================================================================== bool GeometryGUI::OnFilletGetAll(const TopoDS_Shape& ShapeTopo, const double Radius, const int SubShapeType, const char* ShapeTopoIOR) { GEOM::GEOM_Shape::ListOfSubShapeID_var ListOfID = new GEOM::GEOM_Shape::ListOfSubShapeID; ListOfID->length(0); SALOMEDS::Study_var aStudy = myActiveStudy->getStudyDocument(); SALOMEDS::SObject_var theObj = aStudy->FindObjectIOR( ShapeTopoIOR ); if ( theObj->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_SHAPE_IN_STUDY")); return false ; } try { if( Radius <= Precision::Confusion() ) return false; GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( ShapeTopoIOR ); GEOM::GEOM_Shape_var result = myComponentGeom->MakeFillet(aShape, Radius, SubShapeType, ListOfID) ; if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT")); return false; } TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, result); Standard_CString type; GetShapeTypeString(S,type); result->NameType( type ); if ( Display( result, "" )) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return true; } //===================================================================================== // function : OnFilletGetSelected() // purpose : //===================================================================================== bool GeometryGUI::OnFilletGetSelected(const TopoDS_Shape& ShapeTopo, const char* ShapeTopoIOR, const double Radius, const int SubShapeType, Standard_Integer& aLocalContextId, bool& myUseLocalContext ) { if ( this->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) { return false; } OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); if( myUseLocalContext == false ) { /* No local context opened for fillet method */ myDesktop->putInfo(tr("GEOM_PRP_ABORT")); return false ; } GEOM::GEOM_Shape::ListOfSubShapeID_var ListOfID = new GEOM::GEOM_Shape::ListOfSubShapeID; ic->InitSelected(); int nbSelected = ic->NbSelected(); int i = 0; ic->InitSelected(); while(ic->MoreSelected()) { TopoDS_Shape s = ic->SelectedShape(); if ( s.ShapeType() == TopAbs_FACE ) { TopExp_Explorer Exp( s, TopAbs_EDGE ); TopTools_MapOfShape M ; while ( Exp.More() ) { if( M.Add(Exp.Current() )) { /* if a new edge : do not add doublons indices */ ListOfID->length( i + 1 ); ListOfID[i] = GetIndex( Exp.Current(), ShapeTopo, (int)TopAbs_EDGE ) ; i++ ; } Exp.Next(); } } else { ListOfID->length( i + 1 ); ListOfID[i] = GetIndex( ic->SelectedShape(), ShapeTopo, SubShapeType ); i++; } ic->NextSelected(); } GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( ShapeTopoIOR ); GEOM::GEOM_Shape_var aResult ; try { aResult = myComponentGeom->MakeFillet( aShape, Radius, 6, ListOfID ); /* local context from DialogBox */ ic->CloseLocalContext(aLocalContextId) ; myUseLocalContext = false ; TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, aResult); Standard_CString type; GetShapeTypeString(S,type); aResult->NameType( type ); if ( Display( aResult, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } if ( myUseLocalContext ) { /* local context from DialogBox */ ic->CloseLocalContext(aLocalContextId) ; myUseLocalContext = false ; } this->OnDisplayAll(true); myActiveStudy->updateObjBrowser(); myDesktop->putInfo (tr("GEOM_PRP_READY")); return true ; } //===================================================================================== // function : OnChamferGetAll() // purpose : //===================================================================================== bool GeometryGUI::OnChamferGetAll(const TopoDS_Shape& ShapeTopo, const double D1, const double D2, const int SubShapeType, const char* ShapeTopoIOR) { GEOM::GEOM_Shape::ListOfSubShapeID_var ListOfID = new GEOM::GEOM_Shape::ListOfSubShapeID; ListOfID->length(0); SALOMEDS::Study_var aStudy = myActiveStudy->getStudyDocument(); SALOMEDS::SObject_var theObj = aStudy->FindObjectIOR( ShapeTopoIOR ); if ( theObj->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_SHAPE_IN_STUDY")); return false ; } try { if( D1 <= Precision::Confusion() ) return false; if( D2 <= Precision::Confusion() ) return false; GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( ShapeTopoIOR ); GEOM::GEOM_Shape_var result = myComponentGeom->MakeChamfer(aShape, D1, D2, SubShapeType, ListOfID) ; if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT")); return false; } TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, result); Standard_CString type; GetShapeTypeString(S,type); result->NameType( type ); if ( Display( result, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return true; } //===================================================================================== // function : OnChamferGetSelected() // purpose : //===================================================================================== bool GeometryGUI::OnChamferGetSelected(const TopoDS_Shape& ShapeTopo, const char* ShapeTopoIOR, const double D1, const double D2, const int SubShapeType, Standard_Integer& aLocalContextId, bool& myUseLocalContext) { if ( this->myActiveStudy->getActiveStudyFrame()->getTypeView() > VIEW_OCC ) { return false; } OCCViewer_Viewer3d* v3d = ((OCCViewer_ViewFrame*)myActiveStudy->getActiveStudyFrame()->getRightFrame()->getViewFrame())->getViewer(); Handle (AIS_InteractiveContext) ic = v3d->getAISContext(); if( myUseLocalContext == false ) { /* No local context opened for chamfer method */ myDesktop->putInfo(tr("GEOM_PRP_ABORT")); return false ; } GEOM::GEOM_Shape::ListOfSubShapeID_var ListOfID = new GEOM::GEOM_Shape::ListOfSubShapeID; ic->InitSelected(); int nbSelected = ic->NbSelected(); int i = 0; ic->InitSelected(); while(ic->MoreSelected()) { TopoDS_Shape s = ic->SelectedShape(); if ( s.ShapeType() == TopAbs_FACE ) { TopExp_Explorer Exp( s, TopAbs_EDGE ); TopTools_MapOfShape M ; while ( Exp.More() ) { if( M.Add(Exp.Current() )) { /* if a new edge : do not add doublons indices */ ListOfID->length( i + 1 ); ListOfID[i] = GetIndex( Exp.Current(), ShapeTopo, (int)TopAbs_EDGE ) ; i++ ; } Exp.Next(); } } else { ListOfID->length( i + 1 ); ListOfID[i] = GetIndex( ic->SelectedShape(), ShapeTopo, SubShapeType ) ; i++; } ic->NextSelected(); } GEOM::GEOM_Shape_var aShape = myComponentGeom->GetIORFromString( ShapeTopoIOR ); GEOM::GEOM_Shape_var aResult ; try { aResult = myComponentGeom->MakeChamfer( aShape, D1, D2, 6, ListOfID ); /* local context from DialogBox */ ic->CloseLocalContext(aLocalContextId) ; myUseLocalContext = false ; TopoDS_Shape S = ShapeReader.GetShape(myComponentGeom, aResult); Standard_CString type; GetShapeTypeString(S,type); aResult->NameType( type ); if ( Display( aResult, "") ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } if ( myUseLocalContext ) { /* local context from DialogBox */ ic->CloseLocalContext(aLocalContextId) ; myUseLocalContext = false ; } this->OnDisplayAll(true); myActiveStudy->updateObjBrowser(); myDesktop->putInfo (tr("GEOM_PRP_READY")); return true ; } //===================================================================================== // function : MakeCDGAndDisplay() // purpose : //===================================================================================== void GeometryGUI::MakeCDGAndDisplay(GEOM::GEOM_Shape_ptr Shape) { try { GEOM::GEOM_Shape_var result = myComponentGeom->MakeCDG( Shape ); if ( result->_is_nil() ) { myDesktop->putInfo(tr("GEOM_PRP_ABORT") ); return ; } result->NameType( tr("GEOM_POINT") ); if ( Display( result ) ) myDesktop->putInfo(tr("GEOM_PRP_DONE")); } catch (const SALOME::SALOME_Exception& S_ex) { QtCatchCorbaException(S_ex); } return ; } bool GeometryGUI::SObjectExist(SALOMEDS::SObject_ptr theFatherObject, const char* IOR) { SALOMEDS::Study_var aStudy = GeomGUI->myActiveStudy->getStudyDocument(); SALOMEDS::ChildIterator_var it = aStudy->NewChildIterator(theFatherObject); SALOMEDS::SObject_var RefSO; SALOMEDS::GenericAttribute_var anAttr; SALOMEDS::AttributeIOR_var anIOR; for (; it->More();it->Next()) { SALOMEDS::SObject_var SO= it->Value(); if (SO->FindAttribute(anAttr, "AttributeIOR") ) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); if ( strcmp( anIOR->Value(), IOR ) == 0 ) return true; } if ( SO->ReferencedObject( RefSO ) ) { if (RefSO->FindAttribute(anAttr, "AttributeIOR") ) { anIOR = SALOMEDS::AttributeIOR::_narrow(anAttr); if ( strcmp( anIOR->Value(), IOR ) == 0 ) return true; } } } return false; }