///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2017 Statoil 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 "RiaSummaryTools.h" #include "RiaApplication.h" #include "RifEclipseSummaryAddress.h" #include "RimOilField.h" #include "RimMainPlotCollection.h" #include "RimProject.h" #include "RimSummaryCaseMainCollection.h" #include "RimSummaryCrossPlot.h" #include "RimSummaryCurve.h" #include "RimSummaryPlot.h" #include "RimSummaryPlotCollection.h" #include "cafPdmObject.h" #include "RimSummaryCrossPlotCollection.h" //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimSummaryPlotCollection* RiaSummaryTools::summaryPlotCollection() { RimProject* project = RiaApplication::instance()->project(); return project->mainPlotCollection()->summaryPlotCollection(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimSummaryCaseMainCollection* RiaSummaryTools::summaryCaseMainCollection() { RimProject* project = RiaApplication::instance()->project(); RimSummaryCaseMainCollection* summaryCaseMainCollection = project->activeOilField()->summaryCaseMainCollection(); CVF_ASSERT(summaryCaseMainCollection); return summaryCaseMainCollection; } //-------------------------------------------------------------------------------------------------- /// Update the summary curves referencing this curve, as the curve is identified by the name //-------------------------------------------------------------------------------------------------- void RiaSummaryTools::notifyCalculatedCurveNameHasChanged(const QString& previousCurveName, const QString& currentCurveName) { RimSummaryPlotCollection* summaryPlotColl = RiaSummaryTools::summaryPlotCollection(); for (RimSummaryPlot* plot : summaryPlotColl->summaryPlots()) { for (RimSummaryCurve* curve : plot->summaryCurves()) { RifEclipseSummaryAddress adr = curve->summaryAddressY(); if (adr.category() == RifEclipseSummaryAddress::SUMMARY_CALCULATED) { if (adr.quantityName() == previousCurveName.toStdString()) { RifEclipseSummaryAddress updatedAdr = RifEclipseSummaryAddress::calculatedAddress(currentCurveName.toStdString()); curve->setSummaryAddressY(updatedAdr); } } } } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimSummaryPlot* RiaSummaryTools::parentSummaryPlot(caf::PdmObject* object) { if (parentCrossPlot(object)) { return nullptr; } RimSummaryPlot* summaryPlot = nullptr; if (object) { object->firstAncestorOrThisOfType(summaryPlot); } return summaryPlot; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimSummaryPlotCollection* RiaSummaryTools::parentSummaryPlotCollection(caf::PdmObject* object) { RimSummaryPlotCollection* summaryPlotColl = nullptr; if (object) { object->firstAncestorOrThisOfType(summaryPlotColl); } return summaryPlotColl; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimSummaryCrossPlot* RiaSummaryTools::parentCrossPlot(caf::PdmObject* object) { RimSummaryCrossPlot* crossPlot = nullptr; if (object) { object->firstAncestorOrThisOfType(crossPlot); } return crossPlot; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimSummaryCrossPlotCollection* RiaSummaryTools::parentCrossPlotCollection(caf::PdmObject* object) { RimSummaryCrossPlotCollection* crossPlotColl = nullptr; if (object) { object->firstAncestorOrThisOfType(crossPlotColl); } return crossPlotColl; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RiaSummaryTools::isSummaryCrossPlot(const RimSummaryPlot* plot) { return dynamic_cast(plot); }