-// Copyright (C) 2007-2013 CEA/DEN, EDF R&D, OPEN CASCADE
-//
-// Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
-// CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
-//
+// Copyright (C) 2014-2015 EDF-R&D
// 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.
+// version 2.1 of the License, or (at your option) any later version.
//
// This library is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
#include <HYDROData_Entity.h>
-#include <LightApp_Module.h>
+#ifdef WIN32
+ #pragma warning ( disable: 4251 )
+#endif
+#include <LightApp_Module.h>
+#include <LightApp_Application.h>
#include <QEvent>
#include <QStack>
+#include <HYDROGUI_DataObject.h>
-class QGraphicsSceneMouseEvent;
+#ifdef WIN32
+ #pragma warning ( default: 4251 )
+#endif
+class QGraphicsSceneMouseEvent;
class GraphicsView_Viewer;
class OCCViewer_Viewer;
class SVTK_Viewer;
class SUIT_ViewWindow;
class SUIT_ViewManager;
+class HYDROData_StricklerTable;
+
class HYDROGUI_DataModel;
class HYDROGUI_Displayer;
class HYDROGUI_OCCDisplayer;
class HYDROGUI_Shape;
class HYDROGUI_VTKPrs;
class HYDROGUI_Operation;
+class HYDROGUI_Overview;
/**\class HYDROGUI_Module
*\brief The class representing the HYDROGUI module
Q_OBJECT
enum CustomEvent { NewViewEvent = QEvent::User + 100 };
+ enum CustomWindows { OverviewWindow = LightApp_Application::WT_User + 100 };
+
+ enum CursorType
+ {
+ CT_ArrowCursor = 0,
+ CT_UpArrowCursor,
+ CT_CrossCursor,
+ CT_WaitCursor,
+ CT_IBeamCursor,
+ CT_SizeVerCursor,
+ CT_SizeHorCursor,
+ CT_SizeBDiagCursor,
+ CT_SizeFDiagCursor,
+ CT_SizeAllCursor,
+ CT_SplitVCursor,
+ CT_SplitHCursor,
+ CT_PointingHandCursor,
+ CT_ForbiddenCursor,
+ CT_WhatsThisCursor,
+ CT_BusyCursor,
+ CT_OpenHandCursor,
+ CT_ClosedHandCursor,
+ CT_User
+ };
public:
typedef QList<HYDROGUI_VTKPrs*> ListOfVTKPrs;
typedef QMap<int,ListOfVTKPrs> ViewId2ListOfVTKPrs;
+ typedef QMap<int, Handle(HYDROData_StricklerTable)> ViewId2StricklerTable;
+
public:
HYDROGUI_Module();
virtual ~HYDROGUI_Module();
virtual void viewManagers( QStringList& ) const;
virtual void contextMenuPopup( const QString&, QMenu*, QString& );
+ virtual void createPreferences();
virtual void update( const int );
virtual void updateCommandsStatus();
void setObjectVisible( const int theViewId,
const Handle(HYDROData_Entity)& theObject,
const bool theState );
+
+ virtual void preferencesChanged( const QString&, const QString& );
+
+ void resetViewState();
+
/**
* Set IsToUpdate flag for all presentations of the given object to recompute them during
* the next viewer(s) updating.
*/
void setIsToUpdate( const Handle(HYDROData_Entity)& theObject,
const bool theState = true );
+ QList<HYDROGUI_Shape*> getObjectShapes( const int theViewId,
+ ObjectKind theKind ) const;
HYDROGUI_Shape* getObjectShape( const int theViewId,
const Handle(HYDROData_Entity)& theObject ) const;
void setObjectShape( const int theViewId,
*/
virtual bool renameObject( const QString& theEntry, const QString& theName );
- int getObjectDisplayOrder( const int theViewId,
- const Handle(HYDROData_Entity)& theObject ) const;
-
QStack<HYDROGUI_Operation*>& getActiveOperations();
HYDROGUI_Operation* activeOperation();
+ /**
+ * Returns the cursor defined for edition operations in module preferences.
+ * \return specific cursor
+ */
+ QCursor getPrefEditCursor() const;
+
+ void clearCache();
+
+ bool isDraggable( const SUIT_DataObject* what ) const;
+
+ bool isDropAccepted( const SUIT_DataObject* where ) const;
+
+ void dropObjects( const DataObjectList& what, SUIT_DataObject* where,
+ const int row, Qt::DropAction action );
+
+ /**
+ * Returns Strickler table used for Land Cover scalar map coloring in the given view.
+ * @param theViewId the view id
+ * @return the Strickler table used for scalar map coloring of Land Covers in the given view;
+ null - if scalar map coloring is off for the view
+ */
+ Handle(HYDROData_StricklerTable) getLandCoverColoringTable( const int theViewId ) const;
+
+ /**
+ * Set Strickler table to be used for Land Cover scalar map coloring in the given view.
+ * @param theViewId the view id
+ * @param theTable the Strickler table
+ */
+ void setLandCoverColoringTable( const int theViewId,
+ const Handle(HYDROData_StricklerTable)& theTable );
+ /**
+ * Set Land Cover scalar map coloring mode off for the given view.
+ * @param theViewId the view id
+ */
+ void setLandCoversScalarMapModeOff( const int theViewId );
+
+ /**
+ * Check if Land Cover scalar map coloring mode is on in the given view.
+ * @param theViewId the view id
+ * @return true if the mode is on, false if the mode is off
+ */
+ bool isLandCoversScalarMapModeOn( const int theViewId ) const;
+
+ /**
+ * Set object as removed.
+ * @param theObject the removed object
+ */
+ void setObjectRemoved( const Handle(HYDROData_Entity)& theObject );
+
+ void enableLCMActions();
+
+ bool arrowsVisible() const;
+ void setArrowsVisible( bool );
+
protected:
CAM_DataModel* createDataModel();
-
+ void setAutoZoomToAllViewManagers(bool bAutoZoom);
+ void setAutoZoom(SUIT_ViewManager* aVMgr, bool bAutoZoom);
public slots:
virtual bool activateModule( SUIT_Study* );
virtual bool deactivateModule( SUIT_Study* );
+ virtual void onObjectClicked( SUIT_DataObject*, int );
protected:
virtual LightApp_Operation* createOperation( const int ) const;
protected slots:
void onOperation();
void onDelete();
+ void onBathymetrySelection();
+ void onBathymetryText();
bool onUndo( int theNumActions );
virtual void onViewManagerRemoved( SUIT_ViewManager* );
virtual void onViewCreated( SUIT_ViewWindow* );
+ void onViewActivated( SUIT_ViewManager* );
+
void onViewPortMouseEvent( QGraphicsSceneMouseEvent* );
void onMouseMove( SUIT_ViewWindow*, QMouseEvent* );
ViewManagerMap myViewManagerMap;
ViewId2Entry2ObjectStateMap myObjectStateMap;
- QMap<int, QStringList> myObjectDisplayOrderMap;
QStack<HYDROGUI_Operation*> myActiveOperationMap;
ViewId2ListOfShapes myShapesMap;
bool myIsUpdateEnabled;
QStringList myGeomObjectsToImport; ///< entries of GEOM objects to be imported
+
+ ViewId2StricklerTable myLandCoverColoringMap;
+
+ HYDROGUI_Overview* myOverview;
};
#endif