Salome HOME
Merge branch 'BR_v14_rc' into BR_quadtree
[modules/hydro.git] / src / HYDROGUI / HYDROGUI_Module.h
index 6aa6f6da2dd5692b097f792513705ce84286fe8e..3798c08d62a01fea7729a6b25c898e1291286927 100644 (file)
@@ -1,8 +1,4 @@
-// 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
@@ -39,6 +35,8 @@ class SVTK_Viewer;
 class SUIT_ViewWindow;
 class SUIT_ViewManager;
 
+class Handle(HYDROData_StricklerTable);
+
 class HYDROGUI_DataModel;
 class HYDROGUI_Displayer;
 class HYDROGUI_OCCDisplayer;
@@ -62,12 +60,8 @@ class HYDROGUI_Module : public LightApp_Module
     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,
@@ -75,6 +69,10 @@ class HYDROGUI_Module : public LightApp_Module
     CT_SizeAllCursor,
     CT_SplitVCursor,
     CT_SplitHCursor,
+    CT_PointingHandCursor,
+    CT_ForbiddenCursor,
+    CT_WhatsThisCursor,
+    CT_BusyCursor,
     CT_OpenHandCursor,
     CT_ClosedHandCursor,
     CT_User
@@ -113,6 +111,8 @@ public:
   typedef QList<HYDROGUI_VTKPrs*> ListOfVTKPrs;
   typedef QMap<int,ListOfVTKPrs> ViewId2ListOfVTKPrs;
 
+  typedef QMap<int, Handle(HYDROData_StricklerTable)> ViewId2StricklerTable;
+
 public:
   HYDROGUI_Module();
   virtual ~HYDROGUI_Module();
@@ -202,12 +202,47 @@ public:
   QStack<HYDROGUI_Operation*>&    getActiveOperations();
   HYDROGUI_Operation*             activeOperation();
 
+  /**
+   * Returns the cursor defined for edition operations in module preferences.
+   * \return specific cursor
+   */
+  QCursor                         getPrefEditCursor() const;
+
+  /**
+   * 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;
+
 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;
@@ -276,6 +311,8 @@ private:
   bool                            myIsUpdateEnabled;
 
   QStringList                     myGeomObjectsToImport; ///< entries of GEOM objects to be imported
+
+  ViewId2StricklerTable           myLandCoverColoringMap;
 };
 
 #endif