///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2017 Statoil ASA // // ResInsight is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // ResInsight is distributed in the hope that it will be useful, but WITHOUT ANY // WARRANTY; without even the implied warranty of MERCHANTABILITY or // FITNESS FOR A PARTICULAR PURPOSE. // // See the GNU General Public License at // for more details. // ///////////////////////////////////////////////////////////////////////////////// #include "RicNewFishbonesSubsFeature.h" #include "WellPathCommands/RicWellPathsUnitSystemSettingsImpl.h" #include "RiaApplication.h" #include "RigWellPath.h" #include "Rim3dView.h" #include "RimFishboneWellPathCollection.h" #include "RimFishbonesCollection.h" #include "RimFishbonesMultipleSubs.h" #include "RimProject.h" #include "RimWellPathCollection.h" #include "RimWellPathCompletions.h" #include "RiuMainWindow.h" #include "cafSelectionManager.h" #include #include #include CAF_CMD_SOURCE_INIT( RicNewFishbonesSubsFeature, "RicNewFishbonesSubsFeature" ); //--------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewFishbonesSubsFeature::onActionTriggered( bool isChecked ) { RimFishbonesCollection* fishbonesCollection = selectedFishbonesCollection(); CVF_ASSERT( fishbonesCollection ); RimWellPath* wellPath; fishbonesCollection->firstAncestorOrThisOfTypeAsserted( wellPath ); if ( !RicWellPathsUnitSystemSettingsImpl::ensureHasUnitSystem( wellPath ) ) return; RimFishbonesMultipleSubs* obj = new RimFishbonesMultipleSubs; fishbonesCollection->appendFishbonesSubs( obj ); double wellPathTipMd = wellPath->endMD(); if ( wellPathTipMd != HUGE_VAL ) { double startMd = wellPathTipMd - 150 - 100; if ( startMd < 100 ) startMd = 100; obj->setMeasuredDepthAndCount( startMd, 12.5, 13 ); } RicNewFishbonesSubsFeature::askUserToSetUsefulScaling( fishbonesCollection ); RimWellPathCollection* wellPathCollection = nullptr; fishbonesCollection->firstAncestorOrThisOfType( wellPathCollection ); if ( wellPathCollection ) { wellPathCollection->uiCapability()->updateConnectedEditors(); } RiuMainWindow::instance()->selectAsCurrentItem( obj ); RimProject* proj; fishbonesCollection->firstAncestorOrThisOfTypeAsserted( proj ); proj->reloadCompletionTypeResultsInAllViews(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimFishbonesCollection* RicNewFishbonesSubsFeature::selectedFishbonesCollection() { std::vector allSelectedItems; caf::SelectionManager::instance()->selectedItems( allSelectedItems ); if ( allSelectedItems.size() != 1u ) return nullptr; RimFishbonesCollection* objToFind = nullptr; caf::PdmUiItem* pdmUiItem = allSelectedItems.front(); caf::PdmObjectHandle* objHandle = dynamic_cast( pdmUiItem ); if ( objHandle ) { objHandle->firstAncestorOrThisOfType( objToFind ); } if ( objToFind == nullptr ) { std::vector wellPaths; caf::SelectionManager::instance()->objectsByType( &wellPaths ); if ( !wellPaths.empty() ) { return wellPaths[0]->fishbonesCollection(); } RimWellPathCompletions* completions = caf::SelectionManager::instance()->selectedItemOfType(); if ( completions ) { return completions->fishbonesCollection(); } } return objToFind; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewFishbonesSubsFeature::setupActionLook( QAction* actionToSetup ) { actionToSetup->setIcon( QIcon( ":/FishBoneGroup16x16.png" ) ); actionToSetup->setText( "Create Fishbones" ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicNewFishbonesSubsFeature::isCommandEnabled() { if ( selectedFishbonesCollection() ) { return true; } return false; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewFishbonesSubsFeature::askUserToSetUsefulScaling( RimFishbonesCollection* fishboneCollection ) { // Always reset well path collection scale factor CVF_ASSERT( fishboneCollection ); RimWellPathCollection* wellPathColl = nullptr; fishboneCollection->firstAncestorOrThisOfTypeAsserted( wellPathColl ); wellPathColl->wellPathRadiusScaleFactor = 0.01; Rim3dView* activeView = RiaApplication::instance()->activeReservoirView(); if ( !activeView ) return; RiaApplication* app = RiaApplication::instance(); QString sessionKey = "AutoAdjustSettingsForFishbones"; bool autoAdjustSettings = false; QVariant v = app->cacheDataObject( sessionKey ); if ( !v.isValid() ) { double currentScaleFactor = activeView->scaleZ(); if ( fabs( currentScaleFactor - 1.0 ) < 0.1 ) return; QMessageBox msgBox; msgBox.setIcon( QMessageBox::Question ); QString questionText; questionText = QString( "When displaying Fishbones structures, the view scaling should be set to 1.\n\nDo you " "want ResInsight to automatically set view scaling to 1?" ); msgBox.setText( questionText ); msgBox.setStandardButtons( QMessageBox::Yes | QMessageBox::No ); int ret = msgBox.exec(); if ( ret == QMessageBox::Yes ) { autoAdjustSettings = true; } app->setCacheDataObject( sessionKey, autoAdjustSettings ); } else { autoAdjustSettings = v.toBool(); } if ( autoAdjustSettings ) { activeView->setScaleZAndUpdate( 1.0 ); activeView->scheduleCreateDisplayModelAndRedraw(); activeView->updateZScaleLabel(); RiuMainWindow::instance()->updateScaleValue(); } }