///////////////////////////////////////////////////////////////////////////////// // // 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 "RicWellLogPlotCurveFeatureImpl.h" #include "RicNewWellLogPlotFeatureImpl.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 "RiaApplication.h" #include "RiuWellLogTrack.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->addTrack(plotTrack); plotTrack->setDescription(QString("Track %1").arg(plot->trackCount())); plot->loadDataAndUpdate(); for (size_t wlIdx = 0; wlIdx < selection.size(); wlIdx++) { RimWellLogFileChannel* wellLog = selection[wlIdx]; RimWellPath* wellPath = nullptr; wellLog->firstAncestorOrThisOfType(wellPath); RimWellLogFile* wellLogFile = nullptr; wellLog->firstAncestorOrThisOfType(wellLogFile); 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->calculateAvailableDepthRange(); plot->updateDepthZoom(); plotTrack->viewer()->replot(); RiaApplication::instance()->project()->updateConnectedEditors(); RiuPlotMainWindowTools::showPlotMainWindow(); RiuPlotMainWindowTools::selectAsCurrentItem(plot); RiuPlotMainWindowTools::setExpanded(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; }