-// GEOM GEOMGUI : GUI for Geometry component
+// Copyright (C) 2007-2010 CEA/DEN, EDF R&D, OPEN CASCADE
//
-// Copyright (C) 2003 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
+// Copyright (C) 2003-2007 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
// 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
+// See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
//
-//
-//
-// File : GeometryGUI.h
-// Author : Lucien PIGNOLONI
-// Module : GEOM
-// $Header$
+// GEOM GEOMGUI : GUI for Geometry component
+// File : GeometryGUI.h
+// Author : Vadim SANDLER, Open CASCADE S.A.S. (vadim.sandler@opencascade.com)
+//
#ifndef GEOMETRYGUI_H
#define GEOMETRYGUI_H
-#include "SalomeApp_Module.h"
+#include "GEOM_GEOMGUI.hxx"
-#include "GEOMGUI.h"
-#include "GEOM_Client.hxx"
-#include "SALOME_InteractiveObject.hxx"
+#include <SalomeApp_Module.h>
-#include "SALOMEDSClient.hxx"
+#include <GEOM_Client.hxx>
+#include <SALOME_InteractiveObject.hxx>
+#include <SALOMEDSClient.hxx>
+
+#include "GEOMGUI.h"
// QT Includes
-#include <qmap.h>
+#include <QMap>
// OCCT Includes
#include <gp_Ax3.hxx>
+#include <Graphic3d_HArray1OfBytes.hxx>
// IDL headers
#include "SALOMEconfig.h"
#include CORBA_CLIENT_HEADER(SALOMEDS)
-#ifdef WNT
-#include <SALOME_WNT.hxx>
-#else
-#define SALOME_WNT_EXPORT
-#endif
+// minimum allowed value for deflection coefficient
+#define DEFLECTION_MIN 1e-06
-//#if defined WNT
-//#include <SALOME_WNT.hxx>
-//#else
-//#define SALOME_WNT_EXPORT
-//#endif
+//Define separators
+#define NAME_SEPARATOR '_' // character used to separate parameter names
+#define DIGIT_SEPARATOR ':' // character used to separate numeric parameter values (color = r:g:b)
-#if defined WNT && defined WIN32 && defined SALOME_WNT_EXPORTS
-#define GEOMGUI_WNT_EXPORT __declspec( dllexport )
-#else
-#define GEOMGUI_WNT_EXPORT
-#endif
+#define VISIBILITY_PROP "Visibility" //Object visibility property
+#define OPACITY_PROP "Opacity" //Object opacity property
+#define TRANSPARENCY_PROP "Transparency" //Object transparency property
+#define DISPLAY_MODE_PROP "DisplayMode" //Object display mode property
+#define ISOS_PROP "Isos" //Number of the Isos property of the object
+#define COLOR_PROP "Color" //Color of the object
+#define VECTOR_MODE_PROP "VectorMode" //Vector mode property
+#define DEFLECTION_COEFF_PROP "DeflectionCoeff" //Deflection coeff property
+#define MARKER_TYPE_PROP "MarkerType" // Marker type property
-typedef QMap<QString, GEOMGUI*> GUIMap;
class QDialog;
-class QPopupMenu;
+class QMenu;
class GEOMGUI_OCCSelector;
-class SalomeApp_VTKSelector;
+class LightApp_VTKSelector;
+class LightApp_Selection;
class SUIT_ViewManager;
+class SalomeApp_Study;
//=================================================================================
// class : GeometryGUI
// purpose :
//=================================================================================
-class GEOMGUI_WNT_EXPORT GeometryGUI : public SalomeApp_Module
+class GEOMGUI_EXPORT GeometryGUI : public SalomeApp_Module
{
Q_OBJECT;
// Destructor
~GeometryGUI();
- virtual SalomeApp_Displayer* displayer();
+ virtual LightApp_Displayer* displayer();
virtual void initialize( CAM_Application* );
virtual QString engineIOR() const;
- static bool InitGeomGen(); //BugID IPAL9186: SRN: To be called by Python scripts
+ static Handle(Graphic3d_HArray1OfBytes) getTexture( SalomeApp_Study*, int, int&, int& );
+
+ static bool InitGeomGen();
- static GEOM::GEOM_Gen_var GetGeomGen();// { return GeometryGUI::myComponentGeom; }
+ static GEOM::GEOM_Gen_var GetGeomGen();
static CORBA::Object_var ClientSObjectToObject (_PTR(SObject) theSObject);
static SALOMEDS::Study_var ClientStudyToStudy (_PTR(Study) theStudy);
- GEOM_Client& GetShapeReader() { return myShapeReader; }
- Standard_CString& GetFatherior() { return myFatherior; }
- //void SetState( const int state ) { myState = state; }
- //int GetState() const { return myState; }
+ static void Modified( bool = true );
+
+ GEOM_Client& GetShapeReader() { static SHAPE_READER(myShapeReader);return myShapeReader; }
// Get active dialog box
QDialog* GetActiveDialogBox(){ return myActiveDialogBox; }
void EmitSignalCloseAllDialogs();
void EmitSignalDefaultStepValueChanged( double newVal );
+ // Process action
void OnGUIEvent( int id );
- virtual bool OnKeyPress( QKeyEvent*, SUIT_ViewWindow* );
- virtual bool OnMousePress( QMouseEvent*, SUIT_ViewWindow* );
- virtual bool OnMouseMove( QMouseEvent*, SUIT_ViewWindow* );
-
-// virtual bool SetSettings();
-// virtual void SupportedViewType ( int* buffer, int bufferSize );
- virtual void BuildPresentation( const Handle(SALOME_InteractiveObject)&, SUIT_ViewWindow* = 0 );
-
-// virtual void DefinePopup( QString & theContext, QString & theParent, QString & theObject);
-// virtual bool CustomPopup( QAD_Desktop* parent, QPopupMenu* popup, const QString& theContext,
-// const QString& theParent, const QString& theObject );
-
// The Working Plane management
void SetWorkingPlane( gp_Ax3 wp ) { myWorkingPlane = wp; }
gp_Ax3 GetWorkingPlane() { return myWorkingPlane; }
virtual void windows( QMap<int, int>& ) const;
virtual void viewManagers( QStringList& ) const;
- virtual void contextMenuPopup( const QString&, QPopupMenu*, QString& );
+ virtual void contextMenuPopup( const QString&, QMenu*, QString& );
virtual void createPreferences();
virtual void preferencesChanged( const QString&, const QString& );
+ int getLocalSelectionMode() const;
+ void setLocalSelectionMode(const int mode);
+ virtual void storeVisualParameters (int savePoint);
+ virtual void restoreVisualParameters(int savePoint);
public slots:
virtual bool deactivateModule( SUIT_Study* );
virtual bool activateModule( SUIT_Study* );
+ virtual void OnKeyPress ( SUIT_ViewWindow*, QKeyEvent* );
+ virtual void OnMousePress( SUIT_ViewWindow*, QMouseEvent* );
+ virtual void OnMouseMove ( SUIT_ViewWindow*, QMouseEvent* );
+
+protected slots:
+ virtual void onViewManagerAdded( SUIT_ViewManager* );
+ virtual void onViewManagerRemoved( SUIT_ViewManager* );
private slots:
void OnGUIEvent();
- void onViewManagerAdded( SUIT_ViewManager* );
- void onViewManagerRemoved( SUIT_ViewManager* );
void onWindowActivated( SUIT_ViewWindow* );
+ void onViewAboutToShow();
signals :
void SignalDeactivateActiveDialog();
void SignalDefaultStepValueChanged( double newVal );
protected:
- virtual SalomeApp_Selection* createSelection() const;
+ virtual LightApp_Selection* createSelection() const;
private:
GEOMGUI* getLibrary( const QString& libraryName );
void createGeomAction( const int id, const QString& po_id,
- const QString& icon_id = QString(""),
- const int key = 0, const bool toggle = false );
+ const QString& icon_id = QString(""),
+ const int key = 0, const bool toggle = false,
+ const QString& shortcutAction = QString() );
void createPopupItem( const int, const QString& clients, const QString& types,
- const bool isSingle = false, const int isVisible = -1,
- const bool isExpandAll = false, const bool isOCC = false,
- const int parentId = -1 );
+ const bool isSingle = false, const int isVisible = -1,
+ const bool isExpandAll = false, const bool isOCC = false,
+ const int parentId = -1 );
+
+ void createOriginAndBaseVectors();
public:
static GEOM::GEOM_Gen_var myComponentGeom; // GEOM engine!!!
+
private:
+
+ typedef QMap<long, Handle(Graphic3d_HArray1OfBytes)> TextureMap;
+ typedef QMap<long, TextureMap> StudyTextureMap;
+ typedef QMap<QString, GEOMGUI*> GUIMap;
+
GUIMap myGUIMap; // GUI libraries map
QDialog* myActiveDialogBox; // active dialog box
- GEOM_Client myShapeReader; // geom shape reader
- Standard_CString myFatherior;
- int myState; // identify a method
gp_Ax3 myWorkingPlane;
QMap<int,QString> myRules; // popup rules
+ static StudyTextureMap myTextureMap; // texture map
- QPtrList<GEOMGUI_OCCSelector> myOCCSelectors;
- QPtrList<SalomeApp_VTKSelector> myVTKSelectors;
+ QList<GEOMGUI_OCCSelector*> myOCCSelectors;
+ QList<LightApp_VTKSelector*> myVTKSelectors;
- SalomeApp_Displayer* myDisplayer;
+ LightApp_Displayer* myDisplayer;
+ int myLocalSelectionMode; //Select Only
-friend class DisplayGUI;
+ friend class DisplayGUI;
};
#endif