// 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.h // Author : Lucien PIGNOLONI // Module : GEOM // $Header$ #ifndef GeometryGUI_HeaderFile #define GeometryGUI_HeaderFile // SALOME Includes #include "QAD_Desktop.h" #include "SALOME_Selection.h" #include "SALOME_InteractiveObject.hxx" #include "GEOM_InteractiveObject.hxx" #include "GEOM_AISShape.hxx" #include "GEOM_Actor.h" #include "GEOM_Sketcher.h" // Open CASCADE Includes #include #include #include #include #include // IDL Headers #include #include CORBA_SERVER_HEADER(GEOM_Gen) #include CORBA_SERVER_HEADER(SALOMEDS) #include CORBA_SERVER_HEADER(SALOMEDS_Attributes) //================================================================================= // //================================================================================= enum { POINT_METHOD, CURRENT_SKETCH } ; //================================================================================= // class : GeometryGUI // purpose : //================================================================================= class GeometryGUI : public QObject { Q_OBJECT /* for QT compatibility */ private : QAD_Desktop* myDesktop; QAD_Study* myActiveStudy; GEOM::GEOM_Gen_var myComponentGeom; QDialog* myActiveDialogBox; /* Unique active dialog box */ Handle(AIS_Shape) mySimulationShape; /* AIS shape used only during topo/geom simulations */ vtkActorCollection* mySimulationActor; /* GEOM Actor used only during topo/geom simulations */ int myNbGeom ; /* Unique name for a geom entity */ int myState ; /* Identify a method */ Sketch mySketcher; Quantity_Color myShadingColor; public : GeometryGUI(); ~GeometryGUI(); static GeometryGUI* GetOrCreateGeometryGUI( QAD_Desktop* desktop ); static GeometryGUI* GetGeometryGUI() ; QAD_Study* GetActiveStudy() ; QAD_Desktop* GetDesktop() ; QDialog* GetActiveDialogBox() ; /* Returns the active DialogBox */ void SetActiveDialogBox(QDialog* aDlg) ; /* Sets 'myActiveDialogBox' a pointer to the active Dialog Box */ void SetState(int aState) ; void ResetState() ; /* Sets myState = -1 a private field to indicate wich method is active */ bool DefineDlgPosition(QWidget* aDlg, int& x, int& y) ; bool SObjectExist(SALOMEDS::SObject_ptr theFatherObject, const char* IOR); void OnEditCopy (); void OnEditDelete (); void OnVTKDisplayOnly (); void OnDisplayOnly (); void OnDisplayAll ( bool onlyPreviousDisplayedObject = false ); void SetDisplayedObjectList(); bool AddInStudy( bool selection = false, const Handle(SALOME_InteractiveObject)& anIO = 0 ); bool Display( GEOM::GEOM_Shape_ptr aShape, Standard_CString name = ""); /* Import and export topology methods */ bool Import(); bool Export(); static int GetIndex(const TopoDS_Shape& subshape, const TopoDS_Shape& shape, int ShapeType) ; static bool VertexToPoint(const TopoDS_Shape& S, gp_Pnt& P) ; static void GetBipointDxDyDz( gp_Pnt P1, gp_Pnt P2, double& dx, double& dy, double& dz) ; static bool GetShapeTypeString( const TopoDS_Shape& aShape, Standard_CString& aTypeString ) ; static bool LinearEdgeExtremities( const TopoDS_Shape& S, gp_Pnt& P1, gp_Pnt& P2) ; static gp_Pnt ConvertClickToPoint( Standard_Real x, Standard_Real y, Handle(V3d_View) aView ) ; /* User dialog 1 parameter returned */ static double Parameter( Standard_Boolean& res, const char* aValue1 = 0, const char* aTitle1 = 0, const char* aTitle = 0, const double bottom = -1E6, const double top = +1E6, const int decimals = 6 ) ; /* Managed by IAPP */ Standard_EXPORT static bool OnGUIEvent ( int theCommandID, QAD_Desktop* parent) ; Standard_EXPORT static bool OnMousePress ( QMouseEvent* pe, QAD_Desktop* parent, QAD_StudyFrame* studyFrame ); Standard_EXPORT static bool OnMouseMove ( QMouseEvent* pe, QAD_Desktop* parent, QAD_StudyFrame* studyFrame ); Standard_EXPORT static bool OnKeyPress ( QKeyEvent* pe, QAD_Desktop* parent, QAD_StudyFrame* studyFrame ); Standard_EXPORT static void activeStudyChanged ( QAD_Desktop* parent ); Standard_EXPORT static bool SetSettings ( QAD_Desktop* parent ); Standard_EXPORT static void DefinePopup( QString & theContext, QString & theParent, QString & theObject ); Standard_EXPORT static bool CustomPopup ( QAD_Desktop* parent, QPopupMenu* popup, const QString& theContext, const QString& theParent, const QString& theObject ); Standard_EXPORT static void BuildPresentation(const Handle(SALOME_InteractiveObject)&); void Archimede( const Handle(SALOME_InteractiveObject)& IO, const double aWeight, const double aWaterDensity, const double aMeshingDeflection ); void MakePointAndDisplay( const double x, const double y, const double z ) ; void MakeVectorAndDisplay( const gp_Pnt P1, const gp_Pnt P2 ); void MakeBoxAndDisplay( const gp_Pnt P1, const gp_Pnt P2 ) ; void MakePlaneAndDisplay( const gp_Pnt P1, const Standard_Real dx, const Standard_Real dy, const Standard_Real dz, const Standard_Real TrimSize ) ; void MakeSphereAndDisplay( const gp_Pnt aCenterPoint, const double aRadius) ; void MakeCircleAndDisplay( const gp_Pnt CenterPoint, const gp_Dir dir, const Standard_Real Radius) ; void MakeEllipseAndDisplay( const gp_Pnt CenterPoint, const gp_Dir dir, const Standard_Real Major_Radius, const Standard_Real Minor_Radius) ; void MakeArcAndDisplay( gp_Pnt InitPoint, gp_Pnt CirclePoint, gp_Pnt EndPoint ) ; void MakeLineAndDisplay( const gp_Pnt InitPoint, const gp_Pnt LastPoint) ; void MakeCylinderAndDisplay( const gp_Pnt BasePoint, const gp_Dir aDir, const double Radius, const double aHeight ) ; void MakeConeAndDisplay( const gp_Pnt BasePoint, const gp_Dir aDir, const double Radius1, const double Radius2, const double aHeight ) ; void MakeTorusAndDisplay( const gp_Pnt BasePoint, const gp_Dir aDir, const double Radius1, const double Radius2 ) ; void MakeBooleanAndDisplay( GEOM::GEOM_Shape_ptr Shape1, GEOM::GEOM_Shape_ptr Shape2, const short operation ) ; void MakeRevolutionAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Pnt loc, const gp_Dir dir, Standard_Real revolAngle ) ; void MakePrismAndDisplay( GEOM::GEOM_Shape_ptr BaseShape, const gp_Pnt P1, const gp_Pnt P2 ) ; void MakePipeAndDisplay( GEOM::GEOM_Shape_ptr aPath, GEOM::GEOM_Shape_ptr aBase ) ; void MakeFillingAndDisplay( GEOM::GEOM_Shape_ptr SectionShape, const short mindeg, const short maxdeg, const double tol3d, const double tol2d, const short nbiter ) ; void MakeRotationAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Pnt loc, const gp_Dir dir, const Standard_Real angle ) ; void MakeTranslationAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Vec V) ; void MakeMultiTranslation1DAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Dir Dir, const double Step, const short NbTimes ) ; void 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 ) ; void MakeMultiRotation1DAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Dir Dir, const gp_Pnt Loc, const short NbTimes ) ; void 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 ) ; void MakeCDGAndDisplay( GEOM::GEOM_Shape_ptr Shape ); void MakeScaleAndDisplay( GEOM::GEOM_Shape_ptr Shape, const gp_Pnt centralPoint, const Standard_Real factor) ; void MakeMirrorAndDisplay( GEOM::GEOM_Shape_ptr Shape1, GEOM::GEOM_Shape_ptr Shape2 ) ; void MakeSewingAndDisplay( GEOM::GEOM_Gen::ListOfIOR& listShapesIOR, const Standard_Real precision ) ; void MakeCompoundAndDisplay( GEOM::GEOM_Gen::ListOfIOR& listShapesIOR ) ; void MakeLinearEdgeAndDisplay( const gp_Pnt P1, const gp_Pnt P2 ) ; void MakeOrientationChangeAndDisplay( GEOM::GEOM_Shape_ptr Shape ) ; void 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 ) ; void MakeWireAndDisplay( GEOM::GEOM_Gen::ListOfIOR& listShapesIOR ) ; void MakeWorkingPlane( const gp_Pnt P, const gp_Dir D) ; void MakeFaceAndDisplay( GEOM::GEOM_Shape_ptr aWire, const Standard_Boolean wantPlanar ) ; /* Simulation management */ bool CreateArrowForLinearEdge( const TopoDS_Shape& tds, TopoDS_Shape& ArrowCone ) ; void DisplaySimulationShape(const TopoDS_Shape& S) ; void EraseSimulationShape() ; /* Selection and objects management */ TopoDS_Shape GetShapeFromIOR( QString IOR ); bool GetTopoFromSelection(SALOME_Selection *Sel, TopoDS_Shape& tds) ; int GetNameOfSelectedIObjects( SALOME_Selection* Sel, QString& aName ) ; GEOM::GEOM_Shape_ptr ConvertIOinGEOMShape( const Handle(SALOME_InteractiveObject)& IO, Standard_Boolean& testResult ) ; Handle(GEOM_AISShape) ConvertIOinGEOMAISShape( const Handle(SALOME_InteractiveObject)& IO, Standard_Boolean& testResult, bool onlyInActiveView = false ) ; Handle(GEOM_AISShape) ConvertIORinGEOMAISShape( const char * IOR, Standard_Boolean& testResult, bool onlyInActiveView = false ) ; GEOM_Actor* ConvertIORinGEOMActor( const char * IOR, Standard_Boolean& testResult, bool onlyInActiveView = false ) ; void ConvertListOfIOInListOfIOR( const SALOME_ListIO& aList, GEOM::GEOM_Gen::ListOfIOR& listIOR ) ; /* Method used by dialog boxes called when used has entered a name of object in a LineEdit */ bool SelectionByNameInDialogs( QWidget* aWidget, const QString& userObjectName, SALOME_Selection *Sel ) ; /* Method opening context for any sub shape selection */ bool PrepareSubShapeSelection( const int SubShapeType, Standard_Integer& returnLocalContextId ) ; /* Method opening context for sub shape selection on an argument shape */ bool PrepareSubShapeSelectionArgumentShape( const TopoDS_Shape& aShape, const int SubShapeType, Standard_Integer& returnLocalContextId ) ; /* Define a list of indices of sub shapes selected in a local context */ bool GetIndexSubShapeSelected( const TopoDS_Shape& ShapeTopo, const int SubShapeType, GEOM::GEOM_Shape::ListOfSubShapeID& ListOfID, Standard_Integer& aLocalContextId, bool& myUseLocalContext ) ; /* Methods for sub shapes explode */ bool OnSubShapeGetAll( const TopoDS_Shape& ShapeTopo, const char* ShapeTopoIOR, const int SubShapeType) ; bool OnSubShapeGetSelected( const TopoDS_Shape& ShapeTopo, const char* ShapeTopoIOR, const int SubShapeType, Standard_Integer& aLocalContextId, bool& myUseLocalContext ) ; /* Remove faces in a shape */ bool OnSuppressFaces( const TopoDS_Shape& ShapeTopo, const char* ShapeTopoIOR, const Standard_Integer& aLocalContextId, bool& myUseLocalContext ) ; /* Remove an hole in a topology (ListOfIdEndFace may be an empty list ) */ bool OnSuppressHole( const char* ShapeTopoIOR, const GEOM::GEOM_Shape::ListOfSubShapeID& ListOfIdFace, const GEOM::GEOM_Shape::ListOfSubShapeID& ListOfIdWire, const GEOM::GEOM_Shape::ListOfSubShapeID& ListOfIdEndFace ) ; /* Remove one or more holes in a face or a shell */ bool OnSuppressHolesInFaceOrShell( const char* ShapeTopoIOR, const GEOM::GEOM_Shape::ListOfSubShapeID& ListOfIdWires ) ; /* Create a face corresponding to a hole on a shape */ bool OnFillingHole( const TopoDS_Shape& MainShape, const char* ShapeTopoIOR, const Standard_Integer& aLocalContextId, bool& myUseLocalContext ) ; /* Method for Fillet */ bool OnFilletGetAll(const TopoDS_Shape& ShapeTopo, const double Radius, const int SubShapeType, const char* ShapeTopoIOR) ; bool OnFilletGetSelected(const TopoDS_Shape& ShapeTopo, const char* ShapeTopoIOR, const double Radius, const int SubShapeType, Standard_Integer& aLocalContextId, bool& myUseLocalContext ); /* Methods for Chamfer */ bool OnChamferGetAll(const TopoDS_Shape& ShapeTopo, const double D1, const double D2, const int SubShapeType, const char* ShapeTopoIOR) ; bool OnChamferGetSelected(const TopoDS_Shape& ShapeTopo, const char* ShapeTopoIOR, const double D1, const double D2, const int SubShapeType, Standard_Integer& aLocalContextId, bool& myUseLocalContext ) ; /* Non modal dialog boxes magement */ void EmitSignalDeactivateDialog() ; void EmitSignalCloseAllDialogs() ; /* Sketcher management */ void OnSketchSegment(); void OnSketchArc(); void OnSketchSetAngle(); void OnSketchSetx(); void OnSketchSety(); void OnSketchDelete(); void OnSketchClose(); void OnSketchEnd(); void OnSketchOptionsOnoffangledimension(); void OnSketchOptionsOnofflengthdimension(); void OnSketchOptionsOnoffradiusdimension(); void OnSketchOptionsOnoffxdimension(); void OnSketchOptionsOnoffydimension(); void OnSettingsNoconstraint(); void OnSettingsPerpendicular(); void OnSettingsTangent(); signals: void SignalDeactivateActiveDialog() ; void SignalCloseAllDialogs() ; void SignalDefaultStepValueChanged( double newVal ) ; }; #endif