X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROGUI%2FHYDROGUI_CalculationOp.h;h=b4961a357602834508caf5b5bc35d7c9de151037;hb=419118d6b16f91ec37912b242cfe7469a585d16e;hp=0e9e6ab5ad6e190c4865cd92411927ef48355b3e;hpb=2cf9e838e652ae811d9b3931914771ad1836c6b8;p=modules%2Fhydro.git diff --git a/src/HYDROGUI/HYDROGUI_CalculationOp.h b/src/HYDROGUI/HYDROGUI_CalculationOp.h index 0e9e6ab5..b4961a35 100644 --- a/src/HYDROGUI/HYDROGUI_CalculationOp.h +++ b/src/HYDROGUI/HYDROGUI_CalculationOp.h @@ -80,6 +80,21 @@ protected slots: */ void onRemoveGroups(); + /** + * Change the creation mode related to land covers. + * @param theMode the mode to set + */ + void onChangeLandCoverMode( int theMode ); + + /** + * Add land covers selected in the module browser to the calculation case. + */ + void onAddLandCovers(); + /** + * Remove selected land covers from the calculation case. + */ + void onRemoveLandCovers(); + /** * Set the given bathymetry merge type to the current zone. */ @@ -103,48 +118,72 @@ protected slots: */ void onClickedInZonesBrowser( SUIT_DataObject* theItem ); /** - * Hide zones in the viewer. + * Slot called on back button click. */ - void onHideZones(); + void onBack( const int ); /** * Geometry object is selected in the list on the first wizard page */ void onObjectsSelected(); + /** + * Land cover is selected in the list on the third wizard page + */ + void onLandCoversSelected(); /** * Boundary polyline is selected in the list on the first wizard page */ - void onBoundarySelected ( const QString & theObjName ); + void onBoundarySelected( const QString & theObjName ); + /** + * Strickler table name is selected in the list on the third wizard page + */ + void onStricklerTableSelected( const QString & theObjName ); + + void onOrderChanged( bool& isConfirmed ); + void onOrderLandCoverChanged( bool& isConfirmed ); private: void createPreview(); void closePreview(); void setObjectVisibility( Handle(HYDROData_Entity) theEntity, const bool theIsVisible ); void setZonesVisible( bool theIsVisible ); + void setGeomObjectsVisible( bool theIsVisible ); void getNamesAndEntries( const HYDROData_SequenceOfObjects& theSeq, QStringList& theNames, QStringList& theEntries ) const; /** - * Ask user to confirm splitting zones recalculation after regions list modification. - * \return true if confirmed + * Internal method that used to assign unique default colors for zones */ - bool confirmRegionsChange() const; - + void AssignDefaultZonesColors(); /** - * Ask user to confirm splitting zones recalculation after mode change. - * \return true if confirmed - */ - bool confirmModeChange() const; - - /** - * Ask user to confirm the operation continuation with warning. - * @param theWarning the warning - * \return true if confirmed - */ - bool confirmContinueWithWarning( const HYDROData_Warning& theWarning ) const; + * Internal method that used to generate default color for zone + * @param theIndex the index of color to be generated + * @param theSaturation the saturation of the color in the range 0 to 1, + * and the bigger it is, the stronger the color is. Grayish colors have + * saturation near 0, very strong colors have saturation near 1. + * The defalt value is 0.5. + * @param theValue the value in the range 0 to 1, represents lightness or + * brightness of the color. 0 is black, 1 is as far from black as possible. + * The defalt value is 0.95. + * \return the generated color + */ + QColor GenerateDefaultZonesColor( int theIndex, + float theSaturation = 0.5, + float theValue = 0.95 ) const; + + void setRules( HYDROData_CalculationCase::DataTag theDataTag ); + + bool confirmRegionsChange() const; + bool confirmModeChange() const; + bool confirmOrderChange() const; + bool confirmContinueWithWarning( const HYDROData_Warning& theWarning ) const; + + bool confirmLandCoverModeChange() const; + bool confirmLandCoverOrderChange() const; private: bool myIsEdit; bool myShowZones; + bool myShowGeomObjects; Handle(HYDROData_CalculationCase) myEditedObject; SUIT_ViewManager* myActiveViewManager;