Files
ResInsight/ApplicationLibCode/Commands/OsduImportCommands/RicWellPathsImportOsduFeature.cpp

124 lines
4.3 KiB
C++
Raw Normal View History

2015-08-14 09:45:57 +02:00
/////////////////////////////////////////////////////////////////////////////////
//
2024-02-28 08:10:52 +01:00
// Copyright (C) 2024- Equinor ASA
2019-06-14 10:45:47 +02:00
//
2015-08-14 09:45:57 +02:00
// 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.
2019-06-14 10:45:47 +02:00
//
2015-08-14 09:45:57 +02:00
// 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.
2019-06-14 10:45:47 +02:00
//
// See the GNU General Public License at <http://www.gnu.org/licenses/gpl.html>
2015-08-14 09:45:57 +02:00
// for more details.
//
/////////////////////////////////////////////////////////////////////////////////
2024-02-26 15:40:13 +01:00
#include "RicWellPathsImportOsduFeature.h"
#include "Cloud/RiaOsduConnector.h"
#include "RiaApplication.h"
#include "RiaColorTables.h"
#include "RiaGuiApplication.h"
2024-02-28 08:10:52 +01:00
#include "RiaLogging.h"
#include "RiaPreferences.h"
2024-02-28 08:10:52 +01:00
#include "RiaPreferencesOsdu.h"
#include "RigWellPath.h"
#include "RimFileWellPath.h"
2024-02-28 08:10:52 +01:00
#include "RimOilField.h"
#include "RimOsduWellPath.h"
#include "RimProject.h"
#include "RimTools.h"
2024-02-28 08:10:52 +01:00
#include "RimWellPathCollection.h"
#include "RiuMainWindow.h"
#include "RiuWellImportWizard.h"
#include "cafDataLoadController.h"
#include "cafProgressInfo.h"
2024-02-28 08:10:52 +01:00
#include "cvfObject.h"
#include <QAction>
#include <QDir>
2024-02-28 08:10:52 +01:00
CAF_CMD_SOURCE_INIT( RicWellPathsImportOsduFeature, "RicWellPathsImportOsduFeature" );
//--------------------------------------------------------------------------------------------------
2019-06-14 10:45:47 +02:00
///
//--------------------------------------------------------------------------------------------------
2024-02-28 08:10:52 +01:00
void RicWellPathsImportOsduFeature::onActionTriggered( bool isChecked )
{
RiaApplication* app = RiaApplication::instance();
if ( !app->project() ) return;
2017-10-17 12:48:36 +02:00
if ( !app->preferences() ) return;
2024-02-28 08:10:52 +01:00
RimProject* project = RimProject::current();
if ( !project ) return;
if ( project->oilFields.empty() ) return;
RimOilField* oilField = project->activeOilField();
if ( !oilField ) return;
RiaOsduConnector* osduConnector = app->makeOsduConnector();
if ( !osduConnector )
{
RiaLogging::error( "Failed to create OSDU connector" );
return;
}
2024-02-28 08:10:52 +01:00
2024-07-29 11:30:28 +02:00
RiuWellImportWizard wellImportwizard( osduConnector, RiuMainWindow::instance() );
if ( QDialog::Accepted == wellImportwizard.exec() )
{
2024-02-28 08:10:52 +01:00
std::vector<RiuWellImportWizard::WellInfo> importedWells = wellImportwizard.importedWells();
caf::ProgressInfo progress( importedWells.size(), "Importing wells from OSDU", false, true );
int colorIndex = 0;
std::vector<RimOsduWellPath*> newWells;
2024-02-28 08:10:52 +01:00
for ( auto w : importedWells )
{
auto wellPath = new RimOsduWellPath;
wellPath->setName( w.name );
wellPath->setWellId( w.wellId );
wellPath->setWellboreId( w.wellboreId );
wellPath->setWellboreTrajectoryId( w.wellboreTrajectoryId );
wellPath->setDatumElevationFromOsdu( w.datumElevation );
wellPath->setWellPathColor( RiaColorTables::wellPathsPaletteColors().cycledColor3f( colorIndex++ ) );
newWells.push_back( wellPath );
oilField->wellPathCollection->addWellPath( wellPath );
}
const QString wellPathGeometryKeyword = "WELL_PATH_GEOMETRY";
caf::DataLoadController* dataLoadController = caf::DataLoadController::instance();
progress.setProgressDescription( QString( "Reading well path geometry." ) );
for ( RimWellPath* wellPath : newWells )
{
dataLoadController->loadData( *wellPath, wellPathGeometryKeyword, progress );
}
dataLoadController->blockUntilDone( wellPathGeometryKeyword );
oilField->wellPathCollection->updateConnectedEditors();
2024-02-28 08:10:52 +01:00
project->updateConnectedEditors();
app->project()->scheduleCreateDisplayModelAndRedrawAllViews();
}
}
//--------------------------------------------------------------------------------------------------
2019-06-14 10:45:47 +02:00
///
//--------------------------------------------------------------------------------------------------
2024-02-28 08:10:52 +01:00
void RicWellPathsImportOsduFeature::setupActionLook( QAction* actionToSetup )
{
2024-02-28 08:10:52 +01:00
actionToSetup->setText( "Import Well Paths from &OSDU" );
actionToSetup->setIcon( QIcon( ":/WellCollection.png" ) );
}