X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROGUI%2FHYDROGUI_CalculationDlg.h;h=d6105168c3d8807675d5ba204a60bd93d406b9b0;hb=298c1759f9b1d4a7dc316742b7a13008eb4234e1;hp=24604f33d7aeacc3356a5a554d4ba21e91677bef;hpb=fac101f1c5d6414dbf85c260a0c0af46b9553fd3;p=modules%2Fhydro.git diff --git a/src/HYDROGUI/HYDROGUI_CalculationDlg.h b/src/HYDROGUI/HYDROGUI_CalculationDlg.h index 24604f33..d6105168 100644 --- a/src/HYDROGUI/HYDROGUI_CalculationDlg.h +++ b/src/HYDROGUI/HYDROGUI_CalculationDlg.h @@ -1,12 +1,8 @@ -// 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 @@ -20,11 +16,13 @@ // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com // + #ifndef HYDROGUI_CALCULATIONDLG_H #define HYDROGUI_CALCULATIONDLG_H #include "HYDROGUI_Wizard.h" #include +#include class HYDROGUI_ObjSelector; class HYDROGUI_DataBrowser; @@ -56,6 +54,7 @@ public: void reset(); int getMode() const; + int getLandCoverMode() const; void setObjectName( const QString& theName ); QString getObjectName() const; @@ -64,9 +63,14 @@ public: void setAllGeomObjects( const QStringList& theObjects, const QStringList& theObjectsEntries ); QStringList getAllGeomObjects() const; + void setAllLandCovers( const QStringList& theObjects, const QStringList& theObjectsEntries ); + QStringList getAllLandCovers() const; void setPolylineNames( const QStringList& theObjects, const QStringList& theObjectsEntries ); + void setStricklerTableNames( const QStringList& theObjects, const QStringList& theObjectsEntries ); QStringList getSelectedGeomObjects() const; + QStringList getSelectedLandCovers() const; QStringList getSelectedAvailableGeomObjects() const; + QStringList getSelectedAvailableLandCovers() const; QStringList getSelectedGroups() const; QStringList getSelectedAvailableGroups() const; HYDROGUI_Zone* getCurrentZone() const; @@ -74,10 +78,14 @@ public: void setAvailableGroups( const QStringList& ); void setEditZonesEnabled( const bool theIsEnabled ); + void setEditLandCoverZonesEnabled( const bool theIsEnabled ); HYDROData_ListOfRules getRules() const; void setRules( const HYDROData_ListOfRules& theRules ) const; + HYDROData_ListOfRules getLandCoverRules() const; + void setLandCoverRules( const HYDROData_ListOfRules& theRules ) const; + public slots: void setMode( int theMode ); void setBoundary( const QString& theObjName ); @@ -89,6 +97,16 @@ public slots: void onAlreadyExists( QString theName ); void refreshZonesBrowser(); void onDataChanged(); + void onOrderChanged(); + + void setLandCoverMode( int theMode ); + void setStricklerTable( const QString& theStricklerTableName, bool theBlockSignals = true ); + void includeLandCovers( const QStringList& theLandCovers, bool theReset ); + void excludeLandCovers( const QStringList& theLandCovers ); + void refreshLandCoverZonesBrowser(); + void onDataLandCoverChanged(); + void onOrderLandCoverChanged(); + /** * Process items selection: hide/show bathymetry merge type selector. */ @@ -103,12 +121,27 @@ public slots: void onZonesDropped( const QList& theList, SUIT_DataObject* theTargetParent, int theTargetRow, Qt::DropAction theDropAction ); + /** + * Process items selection: hide/show Strickler type merge type selector. + */ + void onLandCoverZoneSelected( SUIT_DataObject* theObject ); + /** + * Process merge type selection: set the selected Strickler type merge type for the currently selected zone. + */ + void onMergeStricklerTypeSelected( int theIndex ); + /** + * Process land cover zones moving. Create a new region with dropped zones or add to existing one. + */ + void onLandCoverZonesDropped( const QList& theList, + SUIT_DataObject* theTargetParent, int theTargetRow, Qt::DropAction theDropAction ); + signals: - void changeMode( int theMode ); + void changeMode( int theMode ); void addObjects(); void removeObjects(); void objectsSelected(); + void orderChanged( bool& isConfirmed ); void addGroups(); void removeGroups(); @@ -117,43 +150,73 @@ signals: void boundarySelected( const QString & theObjName ); void setMergeType( int theMergeType, QString& theBathymetryName ); void createRegion( const QList& theZonesList ); - void moveZones( SUIT_DataObject* theRegion, const QList& theZonesList ); + void moveZones( SUIT_DataObject* theRegion, const QList& theZonesList, bool theLandCover ); void clickedInZonesBrowser( SUIT_DataObject* ); + void changeLandCoverMode( int theMode ); + + void addLandCovers(); + void removeLandCovers(); + void landCoversSelected(); + void orderLandCoverChanged( bool& isConfirmed ); + + void createLandCoverRegion( const QList& theLandCoverZonesList ); + + void StricklerTableSelected( const QString & theObjName ); + void setMergeStricklerType( int theMergeType, QString& theStricklerTypeName ); + protected: virtual bool acceptCurrent() const; +protected slots: + void OnNewRegion(); + void OnNewLandCoverRegion(); + private: - QList getGeometryObjects(); + QList getGeometryObjects(); + QList getLandCovers(); QWizardPage* createObjectsPage(); QWizardPage* createGroupsPage(); + QWizardPage* createLandCoversPage(); QWizardPage* createZonesPage(); + QWizardPage* createLandCoverZonesPage(); QSplitter* mySplitter; + QSplitter* myLandCoverSplitter; QGroupBox* myObjectNameGroup; QLineEdit* myObjectName; HYDROGUI_NameValidator* myValidator; QComboBox* myPolylineName; + QComboBox* myStricklerTableName; QButtonGroup* myModeButtons; + QButtonGroup* myLandCoverModeButtons; QListWidget* myAvailableGeomObjects; HYDROGUI_OrderedListWidget* myGeomObjects; HYDROGUI_PriorityWidget* myPriorityWidget; + HYDROGUI_PriorityWidget* myLandCoverPriorityWidget; QListWidget* myAvailableGroups; QListWidget* myGroups; + QListWidget* myAvailableLandCovers; + HYDROGUI_OrderedListWidget* myLandCovers; + HYDROGUI_DataBrowser* myBrowser; Handle(HYDROData_CalculationCase) myEditedObject; QComboBox* myBathymetryChoice; QLabel* myBathymetryLabel; HYDROGUI_Zone* myCurrentZone; + + HYDROGUI_DataBrowser* myLandCoverBrowser; + QComboBox* myStricklerTypeChoice; + QLabel* myStricklerTypeLabel; }; #endif