Salome HOME
#571 - Land Cover: calculation of Strickler coefficient
[modules/hydro.git] / src / HYDROGUI / HYDROGUI_Operations.cxx
index 5eeeefa50ac8a2e772c017b2bbe290f4145b3246..109b1a55de78cfa9fd7a981e8e9bab284b91ed1a 100644 (file)
 #include "HYDROGUI_RiverBottomOp.h"
 #include "HYDROGUI_ProfileInterpolateOp.h"
 #include "HYDROGUI_SubmersibleOp.h"
+#include "HYDROGUI_StricklerTableOp.h"
+#include "HYDROGUI_DuplicateOp.h"
+#include "HYDROGUI_LandCoverOp.h"
+#include "HYDROGUI_PolylineExtractionOp.h"
 
 #include <HYDROData_Document.h>
 #include <HYDROData_Obstacle.h>
@@ -149,6 +153,14 @@ void HYDROGUI_Module::createActions()
   createAction( CreateDigueId, "CREATE_DIGUE", "CREATE_DIGUE_ICO" );
   createAction( EditDigueId, "EDIT_DIGUE", "EDIT_DIGUE_ICO" );
 
+  createAction( ImportStricklerTableFromFileId, "IMPORT_STRICKLER_TABLE", "IMPORT_STRICKLER_TABLE_ICO" );
+  createAction( ExportStricklerTableFromFileId, "EXPORT_STRICKLER_TABLE", "EXPORT_STRICKLER_TABLE_ICO" );
+  createAction( EditStricklerTableId, "EDIT_STRICKLER_TABLE", "EDIT_STRICKLER_TABLE_ICO" );
+  createAction( DuplicateStricklerTableId, "DUPLICATE_STRICKLER_TABLE", "DUPLICATE_STRICKLER_TABLE_ICO" );
+
+  createAction( CreateLandCoverId, "CREATE_LAND_COVER", "CREATE_LAND_COVER_ICO" );
+  createAction( EditLandCoverId, "EDIT_LAND_COVER", "EDIT_LAND_COVER_ICO" );
+
   createAction( ImportObstacleFromFileId, "IMPORT_OBSTACLE_FROM_FILE", "IMPORT_OBSTACLE_FROM_FILE_ICO" );
   createAction( ImportGeomObjectAsObstacleId, "IMPORT_GEOM_OBJECT_AS_OBSTACLE", "IMPORT_GEOM_OBJECT_ICO" );
   createAction( ImportGeomObjectAsPolylineId, "IMPORT_GEOM_OBJECT_AS_POLYLINE", "IMPORT_GEOM_OBJECT_ICO" );
@@ -191,6 +203,7 @@ void HYDROGUI_Module::createActions()
   createAction( SubmersibleId, "SUBMERSIBLE", "SUBMERSIBLE_ICO" );
   createAction( ExportPolylineId, "EXPORT_POLYLINE", "EXPORT_POLYLINE_ICO" );
 
+  createAction( PolylineExtraction, "POLYLINE_EXTRACTION" );
 }
 
 void HYDROGUI_Module::createMenus()
@@ -212,11 +225,13 @@ void HYDROGUI_Module::createMenus()
   createMenu( ImportImageId, aHydroId, -1, -1 );
   createMenu( ImportPolylineId, aHydroId, -1, -1 );
   createMenu( ImportBathymetryId, aHydroId, -1, -1 );
+  createMenu( ImportStricklerTableFromFileId, aHydroId, -1, -1 );
   createMenu( CreatePolylineId, aHydroId, -1, -1 );
   createMenu( CreatePolyline3DId, aHydroId, -1, -1 );
   createMenu( CreateImmersibleZoneId, aHydroId, -1, -1 );
   createMenu( CreateChannelId, aHydroId, -1, -1 );
-  createMenu( CreateDigueId, aHydroId, -1, -1 );
+  createMenu( CreateDigueId, aHydroId, -1, -1 );  
+  createMenu( CreateLandCoverId, aHydroId, -1, -1 );  
 
   int aNewProfileId = createMenu( tr( "MEN_DESK_PROFILE" ), aHydroId, -1 );
   createMenu( CreateProfileId, aNewProfileId, -1, -1 );
@@ -278,6 +293,12 @@ void HYDROGUI_Module::createToolbars()
   createTool( CreateBoxId, aToolBar );
   createTool( CreateCylinderId, aToolBar );
 
+  createTool( separator(), aToolBar );
+  createTool( ImportStricklerTableFromFileId, aToolBar );
+
+  createTool( separator(), aToolBar );
+  createTool( CreateLandCoverId, aToolBar );
+
   createTool( separator(), aToolBar );
   createTool( CreateCalculationId, aToolBar );
 
@@ -474,6 +495,18 @@ LightApp_Operation* HYDROGUI_Module::createOperation( const int theId ) const
   case EditDigueId:
     anOp = new HYDROGUI_DigueOp( aModule, theId == EditDigueId );
     break;
+  case ImportStricklerTableFromFileId:
+  case ExportStricklerTableFromFileId:
+  case EditStricklerTableId:
+    anOp = new HYDROGUI_StricklerTableOp( aModule, theId );
+    break;
+  case CreateLandCoverId:
+  case EditLandCoverId:
+    anOp = new HYDROGUI_LandCoverOp( aModule, theId == EditLandCoverId );
+    break;
+  case DuplicateStricklerTableId:
+    anOp = new HYDROGUI_DuplicateOp( aModule );
+    break;
   case CreateCalculationId:
   case EditCalculationId:
     anOp = new HYDROGUI_CalculationOp( aModule, theId == EditCalculationId );
@@ -542,6 +575,9 @@ LightApp_Operation* HYDROGUI_Module::createOperation( const int theId ) const
   case SubmersibleId:
     anOp = new HYDROGUI_SubmersibleOp( aModule );
     break;
+  case PolylineExtraction:
+    anOp = new HYDROGUI_PolylineExtractionOp( aModule );
+    break;
   }
 
   if( !anOp )