-// 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
// 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 <HYDROData_Calculation.h>
+#include <HYDROData_CalculationCase.h>
+#include <HYDROData_LandCoverMap.h>
class HYDROGUI_ObjSelector;
+class HYDROGUI_DataBrowser;
+class HYDROGUI_NameValidator;
+class HYDROGUI_Zone;
+class HYDROGUI_OrderedListWidget;
+class HYDROGUI_PriorityWidget;
+
+class SUIT_DataObject;
+
+class QButtonGroup;
class QGroupBox;
class QLineEdit;
class QListWidget;
class QComboBox;
-class HYDROGUI_DataBrowser;
+class QLabel;
+class QSplitter;
+class QStringList;
+
class HYDROGUI_CalculationDlg : public HYDROGUI_Wizard
{
void reset();
+ int getMode() const;
+
void setObjectName( const QString& theName );
QString getObjectName() const;
- void setEditedObject( const Handle(HYDROData_Calculation) theCase );
+ void setEditedObject( const Handle(HYDROData_CalculationCase) theCase );
- void setGeomObjects( const QStringList& theObjects );
- void setSelectedGeomObjects( const QStringList& theObjects );
+ void setAllGeomObjects( const QStringList& theObjects, const QStringList& theObjectsEntries );
+ QStringList getAllGeomObjects() const;
+ void setPolylineNames( const QStringList& theObjects, const QStringList& theObjectsEntries );
+ // TODO: setLandCoverMapsNames(...)
+ void setStricklerTableNames( const QStringList& theObjects, const QStringList& theObjectsEntries );
QStringList getSelectedGeomObjects() const;
+ QStringList getSelectedAvailableGeomObjects() const;
+ QStringList getSelectedGroups() const;
+ QStringList getSelectedAvailableGroups() const;
+ HYDROGUI_Zone* getCurrentZone() const;
+
+ void setAvailableGroups( const QStringList& );
+
+ void setEditZonesEnabled( const bool theIsEnabled );
+
+ HYDROData_ListOfRules getRules() const;
+ void setRules( const HYDROData_ListOfRules& theRules ) const;
+
+public slots:
+ void setMode( int theMode );
+ void setBoundary( const QString& theObjName );
+ void includeGeomObjects( const QStringList& theObjects );
+ void excludeGeomObjects( const QStringList& theObjects );
+ void includeGroups( const QStringList& theObjects );
+ void excludeGroups( const QStringList& theObjects );
+ void onEmptyName();
+ void onAlreadyExists( QString theName );
+ void refreshZonesBrowser();
+ void onDataChanged();
+ void onOrderChanged();
+ void onRuleChanged();
+
+ void setStricklerTable( const QString& theStricklerTableName, bool theBlockSignals = true );
+
+ /**
+ * Process items selection: hide/show bathymetry merge type selector.
+ */
+ void onSelected( SUIT_DataObject* theObject );
+ /**
+ * Process merge type selection: set the selected bathymetry merge type for the currently selected zone.
+ */
+ void onMergeTypeSelected( int theIndex );
+ /**
+ * Process zones moving. Create a new region with dropped zones or add to existing one.
+ */
+ void onZonesDropped( const QList<SUIT_DataObject*>& theList,
+ SUIT_DataObject* theTargetParent, int theTargetRow, Qt::DropAction theDropAction );
+
+signals:
+ void changeMode( int theMode );
+
+ void addObjects();
+ void removeObjects();
+ void objectsSelected();
+ void orderChanged( bool& isConfirmed );
+ void ruleChanged( bool& isConfirmed );
+
+ void addGroups();
+ void removeGroups();
+ void groupsSelected();
+
+ void boundarySelected( const QString & theObjName );
+ void setMergeType( int theMergeType, QString& theBathymetryName );
+ void createRegion( const QList<SUIT_DataObject*>& theZonesList );
+ void moveZones( SUIT_DataObject* theRegion, const QList<SUIT_DataObject*>& theZonesList );
+ void clickedInZonesBrowser( SUIT_DataObject* );
+
+ void landCoverMapSelected();
+
+ void StricklerTableSelected( const QString & theObjName );
+
+ void regenerateColors();
+
+protected:
+
+ virtual bool acceptCurrent() const;
+
+protected slots:
+ void OnNewRegion();
private:
-
+ QList<Handle(HYDROData_Entity)> getGeometryObjects();
+
+ Handle(HYDROData_LandCoverMap) getLandCoverMap();
+
QWizardPage* createObjectsPage();
+ QWizardPage* createGroupsPage();
+ QWizardPage* createLandCoverMapPage();
QWizardPage* createZonesPage();
-
+
+ QSplitter* mySplitter;
+
QGroupBox* myObjectNameGroup;
QLineEdit* myObjectName;
+ HYDROGUI_NameValidator* myValidator;
+
+ QComboBox* myPolylineName;
+ // TODO: myLandCoverMapName
+ QComboBox* myStricklerTableName;
+
+ QButtonGroup* myModeButtons;
+
+ QListWidget* myAvailableGeomObjects;
+ HYDROGUI_OrderedListWidget* myGeomObjects;
+
+ HYDROGUI_PriorityWidget* myPriorityWidget;
- QListWidget* myGeomObjects;
+ QListWidget* myAvailableGroups;
+ QListWidget* myGroups;
- HYDROGUI_DataBrowser* myBrowser;
- Handle(HYDROData_Calculation) myEditedObject;
- QComboBox* myBathymetryChoice;
+ HYDROGUI_DataBrowser* myBrowser;
+ Handle(HYDROData_CalculationCase) myEditedObject;
+ QComboBox* myBathymetryChoice;
+ QLabel* myBathymetryLabel;
+ HYDROGUI_Zone* myCurrentZone;
};
#endif