-// 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_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 QLabel;
+class QSplitter;
class QStringList;
-class HYDROGUI_DataBrowser;
-class HYDROGUI_NameValidator;
-class SUIT_DataObject;
-class HYDROGUI_Zone;
+
class HYDROGUI_CalculationDlg : public HYDROGUI_Wizard
{
void reset();
+ int getMode() const;
+
void setObjectName( const QString& theName );
QString getObjectName() const;
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.
*/
SUIT_DataObject* theTargetParent, int theTargetRow, Qt::DropAction theDropAction );
signals:
+ void changeMode( int theMode );
+
void addObjects();
void removeObjects();
- void splitZones();
+ 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* );
-private:
+ 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;
- QListWidget* myGeomObjects;
+ QComboBox* myPolylineName;
+ // TODO: myLandCoverMapName
+ QComboBox* myStricklerTableName;
+
+ QButtonGroup* myModeButtons;
+
+ QListWidget* myAvailableGeomObjects;
+ HYDROGUI_OrderedListWidget* myGeomObjects;
+
+ HYDROGUI_PriorityWidget* myPriorityWidget;
+
+ QListWidget* myAvailableGroups;
+ QListWidget* myGroups;
HYDROGUI_DataBrowser* myBrowser;
Handle(HYDROData_CalculationCase) myEditedObject;
QComboBox* myBathymetryChoice;
- QLabel* myBatimetryLabel;
+ QLabel* myBathymetryLabel;
HYDROGUI_Zone* myCurrentZone;
};