}
}
-void HYDROGUI_CalculationOp::onSetMergeType( int theMergeType, QString& theAltitudeName )
+void HYDROGUI_CalculationOp::onSetMergeType( int theMergeType, QString& theMergeObjectName )
{
HYDROGUI_CalculationDlg* aPanel =
::qobject_cast<HYDROGUI_CalculationDlg*>( inputPanel() );
HYDROGUI_Zone* aZone = aPanel->getCurrentZone();
if ( aZone )
{
- aZone->setMergeType( theMergeType, theAltitudeName );
+ aZone->setMergeType( theMergeType, theMergeObjectName );
HYDROGUI_Shape* aShape = module()->getObjectShape( HYDROGUI_Module::VMR_PreviewCaseZones, aZone->modelObject() );
if ( aShape )
{
HYDROGUI_Zone* aZone = aPanel->getCurrentZone();
if ( aZone )
{
- aZone->setMergeStricklerType( theMergeType, theStricklerTypeName );
+ aZone->setMergeType( theMergeType, theStricklerTypeName );
HYDROGUI_Shape* aShape = module()->getObjectShape( HYDROGUI_Module::VMR_PreviewCaseZones, aZone->modelObject() );
if ( aShape )
{
myEditedObject->SetAssignmentLandCoverMode( (HYDROData_CalculationCase::AssignmentMode)aPanel->getLandCoverMode() );
}
}
+
+ closePreview( false );
+ createPreview( true );
}
else if( theIndex==3 )
{
//aPanel->setEditedObject( myEditedObject );
aPanel->refreshZonesBrowser();
- closePreview();
+ closePreview( false );
createPreview( false );
anIsToUpdateOb = true;
aPanel->setEditLandCoverZonesEnabled( aMode == HYDROData_CalculationCase::MANUAL );
bool anIsToUpdateOb = false;
- if ( myEditedObject->IsMustBeUpdated() )
+ bool anIsToUpdate = myEditedObject->IsMustBeUpdated();
+ if ( anIsToUpdate )
{
myShowZones = true;
myEditedObject->Update();
AssignDefaultZonesColors( true );
aPanel->refreshLandCoverZonesBrowser();
-
- closePreview();
- createPreview( true );
anIsToUpdateOb = true;
-
- myEditedObject->SetToUpdate( true );
}
- else
+
+ closePreview( false );
+ createPreview( true );
+
+ if ( !anIsToUpdate )
{
// Hide zones
setZonesVisible( false, false );
void HYDROGUI_CalculationOp::onHideZones( const int theIndex )
{
- if( theIndex==3 )
+ if( theIndex==1 )
+ {
+ closePreview( false );
+ createPreview( false );
+ }
+ if( theIndex==2 )
{
+ closePreview( false );
+ createPreview( true );
+
// Hide zones
setZonesVisible( false, false );
+ // Hide land covers
+ setZonesVisible( false, true );
}
- else if( theIndex==4 )
+ else if( theIndex==3 )
{
+ AssignDefaultZonesColors( false );
+
+ closePreview( false );
+ createPreview( false );
+
// Hide land cover zones
setZonesVisible( false, true );
+ // Show zones
+ setZonesVisible( true, false );
}
}
HYDROData_ListOfRules aRules;
Handle(HYDROData_Entity) anObject1, anObject2;
HYDROData_PriorityType aPriority;
- HYDROData_Zone::MergeAltitudesType aMergeType;
+ HYDROData_Zone::MergeType aMergeType;
HYDROData_CalculationCase::DataTag aDataTag = HYDROData_CalculationCase::DataTag_CustomRules;
for ( int anIndex = 0; ; anIndex++ )
{
closePreview();
}
-void HYDROGUI_CalculationOp::closePreview()
+void HYDROGUI_CalculationOp::closePreview( bool theRemoveViewManager )
{
SUIT_DataBrowser* aOb = ((LightApp_Application*)module()->application())->objectBrowser();
QList<QShortcut*> aShortcuts = aOb->findChildren<QShortcut*>();
}
}
- disconnect( myPreviewViewManager, SIGNAL( lastViewClosed( SUIT_ViewManager* ) ),
- this, SLOT( onLastViewClosed( SUIT_ViewManager* ) ) );
+ if ( theRemoveViewManager )
+ {
+ disconnect( myPreviewViewManager, SIGNAL( lastViewClosed( SUIT_ViewManager* ) ),
+ this, SLOT( onLastViewClosed( SUIT_ViewManager* ) ) );
- module()->getApp()->removeViewManager( myPreviewViewManager ); // myPreviewViewManager is deleted here
- myPreviewViewManager = NULL;
+ module()->getApp()->removeViewManager( myPreviewViewManager ); // myPreviewViewManager is deleted here
+ myPreviewViewManager = NULL;
+ }
}
- if( myActiveViewManager )
+ if( myActiveViewManager && theRemoveViewManager )
{
HYDROGUI_Tool::SetActiveViewManager( module(), myActiveViewManager );
myActiveViewManager = NULL;