///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2015- Statoil ASA // Copyright (C) 2015- Ceetron Solutions AS // // 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 "RicAddWellLogToPlotFeature.h" #include "RicNewWellLogPlotFeatureImpl.h" #include "RicWellLogPlotCurveFeatureImpl.h" #include "RimMainPlotCollection.h" #include "RimProject.h" #include "RimWellLogFile.h" #include "RimWellLogFileChannel.h" #include "RimWellLogFileCurve.h" #include "RimWellLogPlot.h" #include "RimWellLogPlotCollection.h" #include "RimWellLogTrack.h" #include "RimWellPath.h" #include "RimWellPathCollection.h" #include "RiuPlotMainWindowTools.h" #include "RigWellLogFile.h" #include "RiuQwtPlotWidget.h" #include "cafSelectionManager.h" #include CAF_CMD_SOURCE_INIT( RicAddWellLogToPlotFeature, "RicAddWellLogToPlotFeature" ); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicAddWellLogToPlotFeature::isCommandEnabled() { std::vector selection = selectedWellLogs(); return selection.size() > 0; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicAddWellLogToPlotFeature::onActionTriggered( bool isChecked ) { std::vector selection = selectedWellLogs(); if ( selection.size() < 1 ) return; RimWellLogPlot* plot = RicNewWellLogPlotFeatureImpl::createWellLogPlot(); RimWellLogTrack* plotTrack = new RimWellLogTrack(); plot->addPlot( plotTrack ); plotTrack->setDescription( QString( "Track %1" ).arg( plot->plotCount() ) ); plot->loadDataAndUpdate(); for ( size_t wlIdx = 0; wlIdx < selection.size(); wlIdx++ ) { RimWellLogFileChannel* wellLog = selection[wlIdx]; auto wellPath = wellLog->firstAncestorOrThisOfType(); auto wellLogFile = wellLog->firstAncestorOrThisOfType(); if ( wellLogFile ) { RimWellLogFileCurve* curve = new RimWellLogFileCurve; cvf::Color3f curveColor = RicWellLogPlotCurveFeatureImpl::curveColorFromTable( plotTrack->curveCount() ); curve->setColor( curveColor ); plotTrack->addCurve( curve ); RigWellLogFile* wellLogDataFile = wellLogFile->wellLogFileData(); CVF_ASSERT( wellLogDataFile ); if ( wlIdx == 0 ) { // Initialize plot with depth unit from the first log file plot->setDepthUnit( wellLogDataFile->depthUnit() ); } curve->setWellPath( wellPath ); curve->setWellLogChannelName( wellLog->name() ); curve->setWellLogFile( wellLogFile ); curve->loadDataAndUpdate( true ); } } plot->updateLayout(); RiuPlotMainWindowTools::showPlotMainWindow(); RiuPlotMainWindowTools::onObjectAppended( plot, plotTrack ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicAddWellLogToPlotFeature::setupActionLook( QAction* actionToSetup ) { actionToSetup->setText( "Add To New Plot" ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::vector RicAddWellLogToPlotFeature::selectedWellLogs() { std::vector selection; caf::SelectionManager::instance()->objectsByType( &selection ); return selection; }