///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2019- 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 "RicCreateSaturationPressurePlotsFeature.h" #include "RiaApplication.h" #include "RimEclipseResultCase.h" #include "RimMainPlotCollection.h" #include "RimProject.h" #include "RimSaturationPressurePlot.h" #include "RimSaturationPressurePlotCollection.h" #include "RiuPlotMainWindowTools.h" #include "cafSelectionManager.h" #include CAF_CMD_SOURCE_INIT(RicCreateSaturationPressurePlotsFeature, "RicCreateSaturationPressurePlotsFeature"); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicCreateSaturationPressurePlotsFeature::isCommandEnabled() { return true; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicCreateSaturationPressurePlotsFeature::onActionTriggered(bool isChecked) { RimProject* project = RiaApplication::instance()->project(); bool launchedFromPlotCollection = true; RimSaturationPressurePlotCollection* collection = caf::SelectionManager::instance()->selectedItemAncestorOfType(); if (!collection) { collection = project->mainPlotCollection()->saturationPressurePlotCollection(); launchedFromPlotCollection = false; } std::vector eclipseCases; { RiaApplication* app = RiaApplication::instance(); std::vector cases; app->project()->allCases(cases); for (auto* rimCase : cases) { auto erc = dynamic_cast(rimCase); if (erc) { eclipseCases.push_back(erc); } } } RimEclipseResultCase* eclipseResultCase = nullptr; if (eclipseCases.size() == 1) { eclipseResultCase = eclipseCases[0]; } if (eclipseResultCase) { eclipseResultCase->ensureReservoirCaseIsOpen(); collection->createSaturationPressurePlots(eclipseResultCase); std::vector plots = collection->plots(); for (auto plot : plots) { plot->loadDataAndUpdate(); plot->zoomAll(); plot->updateConnectedEditors(); } } collection->updateAllRequiredEditors(); RiaApplication::instance()->getOrCreateAndShowMainPlotWindow(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicCreateSaturationPressurePlotsFeature::setupActionLook(QAction* actionToSetup) { RimSaturationPressurePlotCollection* collection = caf::SelectionManager::instance()->selectedItemAncestorOfType(); if (!collection) { actionToSetup->setText("New Grid Cross Plot from 3d View"); } else { actionToSetup->setText("Create Saturation Pressure Plots"); } actionToSetup->setIcon(QIcon(":/SummaryXPlotsLight16x16.png")); }