-// Copyright (C) 2007-2015 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
#include <HYDROData_Entity.h>
-#include <LightApp_Module.h>
+#ifdef WIN32
+ #pragma warning ( disable: 4251 )
+#endif
+#include <LightApp_Module.h>
#include <QEvent>
#include <QStack>
-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;
CT_ArrowCursor = 0,
CT_UpArrowCursor,
CT_CrossCursor,
- CT_IBeamCursor,
CT_WaitCursor,
- CT_BusyCursor,
- CT_ForbiddenCursor,
- CT_PointingHandCursor,
- CT_WhatsThisCursor,
+ CT_IBeamCursor,
CT_SizeVerCursor,
CT_SizeHorCursor,
CT_SizeBDiagCursor,
CT_SizeAllCursor,
CT_SplitVCursor,
CT_SplitHCursor,
+ CT_PointingHandCursor,
+ CT_ForbiddenCursor,
+ CT_WhatsThisCursor,
+ CT_BusyCursor,
CT_OpenHandCursor,
CT_ClosedHandCursor,
CT_User
typedef QList<HYDROGUI_VTKPrs*> ListOfVTKPrs;
typedef QMap<int,ListOfVTKPrs> ViewId2ListOfVTKPrs;
+ typedef QMap<int, Handle(HYDROData_StricklerTable)> ViewId2StricklerTable;
+
public:
HYDROGUI_Module();
virtual ~HYDROGUI_Module();
void setObjectVisible( const int theViewId,
const Handle(HYDROData_Entity)& theObject,
const bool theState );
+
+ virtual void preferencesChanged( const QString&, const QString& );
+
/**
* Set IsToUpdate flag for all presentations of the given object to recompute them during
* the next viewer(s) updating.
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();
+
+ /**
+ * 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();
+
protected:
CAM_DataModel* createDataModel();
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 );
bool myIsUpdateEnabled;
QStringList myGeomObjectsToImport; ///< entries of GEOM objects to be imported
+
+ ViewId2StricklerTable myLandCoverColoringMap;
};
#endif