X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FHYDROGUI%2FHYDROGUI_CalculationOp.h;h=81c19c61dcd4142c75b9524c964d78be9a09a17f;hb=95fae05fbf436c6efd6dcebe37dc8315e9f3147b;hp=0ca60d2ffeb791d7a7ea5b3a4552729a1af35b36;hpb=2e1739ce97c68eccf2cd6599c4440e0cb935abbc;p=modules%2Fhydro.git diff --git a/src/HYDROGUI/HYDROGUI_CalculationOp.h b/src/HYDROGUI/HYDROGUI_CalculationOp.h index 0ca60d2f..81c19c61 100644 --- a/src/HYDROGUI/HYDROGUI_CalculationOp.h +++ b/src/HYDROGUI/HYDROGUI_CalculationOp.h @@ -25,7 +25,16 @@ #include "HYDROGUI_Operation.h" -#include +#include "HYDROData_SplitToZonesTool.h" +#include "HYDROGUI_Shape.h" + +#include +#include + +class SUIT_ViewManager; +class OCCViewer_ViewManager; +class HYDROGUI_CalculationDlg; +class SUIT_DataObject; class HYDROGUI_CalculationOp : public HYDROGUI_Operation { @@ -42,12 +51,87 @@ protected: virtual HYDROGUI_InputPanel* createInputPanel() const; - virtual bool processApply( int& theUpdateFlags, QString& theErrorMsg ); + virtual void onApply(); + virtual bool processApply( int& theUpdateFlags, QString& theErrorMsg, + QStringList& theBrowseObjectsEntries ); + + void setAvailableGroups(); + +protected slots: + /** + * Add geometry objects selected in the module browser to the calculation case. + */ + void onAddObjects(); + /** + * Remove selected objects from the calculation case. + */ + void onRemoveObjects(); + + /** + * Add geometry groups selected in the module browser to the calculation case. + */ + void onAddGroups(); + /** + * Remove selected groups from the calculation case. + */ + void onRemoveGroups(); + + /** + * Set the given bathymetry merge type to the current zone. + */ + void onSetMergeType( int theMergeType, QString& theBathymetryName ); + /** + * Selected zones are moved to the existing region. + */ + void onMoveZones( SUIT_DataObject* theRegionItem, + const QList& theZonesList ); + /** + * Selected zones are moved to the new region to be created. + */ + void onCreateRegion( const QList& theZonesList ); + /** + * Case objects must be splitted to zones if the case has been modified or new. + */ + void onNext( const int ); + void onLastViewClosed( SUIT_ViewManager* ); + /** + * The zone is selected in the browser on the second page of the wizard. + */ + void onClickedInZonesBrowser( SUIT_DataObject* theItem ); + /** + * Hide zones in the viewer. + */ + void onHideZones(); + /** + * Geometry object is selected in the list on the first wizard page + */ + void onObjectsSelected(); + /** + * Boundary polyline is selected in the list on the first wizard page + */ + void onBoundarySelected ( const QString & theObjName ); + +private: + void createPreview(); + void closePreview(); + void setObjectVisibility( Handle(HYDROData_Entity) theEntity, const bool theIsVisible ); + void setZonesVisible( bool theIsVisible ); + void getNamesAndEntries( const HYDROData_SequenceOfObjects& theSeq, + QStringList& theNames, QStringList& theEntries ) const; + + /** + * Ask user to confirm splitting zones recalculation. + * \return true if confirmed + */ + bool confirmRegionsChange() const; private: bool myIsEdit; - Handle(HYDROData_Calculation) myEditedObject; + bool myShowZones; + Handle(HYDROData_CalculationCase) myEditedObject; + SUIT_ViewManager* myActiveViewManager; + OCCViewer_ViewManager* myPreviewViewManager; }; #endif