mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-27 16:57:01 -06:00
141 lines
4.8 KiB
C++
141 lines
4.8 KiB
C++
/////////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// 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 <http://www.gnu.org/licenses/gpl.html>
|
|
// for more details.
|
|
//
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
#include "RiaSummaryTools.h"
|
|
|
|
#include "RiaApplication.h"
|
|
|
|
#include "RifEclipseSummaryAddress.h"
|
|
|
|
#include "RimMainPlotCollection.h"
|
|
#include "RimProject.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();
|
|
}
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
/// 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::calculatedCurveAddress(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<const RimSummaryCrossPlot*>(plot);
|
|
}
|