///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2018- Equinor 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 "RicNewWellPathListTargetFeature.h" CAF_CMD_SOURCE_INIT( RicNewWellPathListTargetFeature, "RicNewWellPathListTargetFeature" ); #include "RimModeledWellPath.h" #include "RimWellPathGeometryDef.h" #include "RimWellPathTarget.h" #include "cafSelectionManager.h" #include //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicNewWellPathListTargetFeature::isCommandEnabled() { { std::vector objects; caf::SelectionManager::instance()->objectsByType( &objects ); if ( objects.size() > 0 ) { return true; } } { std::vector objects; caf::SelectionManager::instance()->objectsByType( &objects, caf::SelectionManager::FIRST_LEVEL ); if ( objects.size() > 0 ) { return true; } } return false; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewWellPathListTargetFeature::onActionTriggered( bool isChecked ) { std::vector selectedTargets; caf::SelectionManager::instance()->objectsByType( &selectedTargets, caf::SelectionManager::FIRST_LEVEL ); if ( selectedTargets.size() > 0 ) { auto firstTarget = selectedTargets.front(); RimWellPathGeometryDef* wellGeomDef = nullptr; firstTarget->firstAncestorOrThisOfTypeAsserted( wellGeomDef ); auto afterBeforePair = wellGeomDef->findActiveTargetsAroundInsertionPoint( firstTarget ); cvf::Vec3d newPos = cvf::Vec3d::ZERO; if ( !afterBeforePair.first && afterBeforePair.second ) { newPos = afterBeforePair.second->targetPointXYZ(); newPos.z() = -wellGeomDef->referencePointXyz().z(); } else if ( afterBeforePair.first && afterBeforePair.second ) { newPos = 0.5 * ( afterBeforePair.first->targetPointXYZ() + afterBeforePair.second->targetPointXYZ() ); } else if ( afterBeforePair.first && !afterBeforePair.second ) { std::vector activeTargets = wellGeomDef->activeWellTargets(); size_t targetCount = activeTargets.size(); if ( targetCount > 1 ) { newPos = activeTargets[targetCount - 1]->targetPointXYZ(); cvf::Vec3d nextLastToLast = newPos - activeTargets[targetCount - 2]->targetPointXYZ(); newPos += 0.5 * nextLastToLast; } else { newPos = afterBeforePair.first->targetPointXYZ() + cvf::Vec3d( 0, 0, 200 ); } } RimWellPathTarget* newTarget = new RimWellPathTarget; newTarget->setAsPointTargetXYD( {newPos[0], newPos[1], -newPos[2]} ); wellGeomDef->insertTarget( firstTarget, newTarget ); wellGeomDef->updateConnectedEditors(); wellGeomDef->updateWellPathVisualization(); return; } std::vector geomDefs; caf::SelectionManager::instance()->objectsByType( &geomDefs ); if ( geomDefs.size() > 0 ) { RimWellPathGeometryDef* wellGeomDef = geomDefs[0]; std::vector activeTargets = wellGeomDef->activeWellTargets(); size_t targetCount = activeTargets.size(); if ( targetCount == 0 ) { wellGeomDef->appendTarget(); } else { cvf::Vec3d newPos = cvf::Vec3d::ZERO; if ( targetCount > 1 ) { newPos = activeTargets[targetCount - 1]->targetPointXYZ(); cvf::Vec3d nextLastToLast = newPos - activeTargets[targetCount - 2]->targetPointXYZ(); newPos += 0.5 * nextLastToLast; } else if ( targetCount > 0 ) { newPos = activeTargets[targetCount - 1]->targetPointXYZ() + cvf::Vec3d( 0, 0, 200 ); } RimWellPathTarget* newTarget = new RimWellPathTarget; newTarget->setAsPointTargetXYD( {newPos[0], newPos[1], -newPos[2]} ); wellGeomDef->insertTarget( nullptr, newTarget ); } wellGeomDef->updateConnectedEditors(); wellGeomDef->updateWellPathVisualization(); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewWellPathListTargetFeature::setupActionLook( QAction* actionToSetup ) { actionToSetup->setText( "New Target" ); actionToSetup->setIcon( QIcon( ":/Well.png" ) ); }