2016-06-13 06:29:40 -05:00
|
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//
|
|
|
|
// Copyright (C) 2016 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 "RimSummaryCurveFilter.h"
|
|
|
|
|
|
|
|
#include "RiaApplication.h"
|
2016-06-30 03:06:15 -05:00
|
|
|
|
2016-06-13 06:29:40 -05:00
|
|
|
#include "RifReaderEclipseSummary.h"
|
2016-06-30 03:06:15 -05:00
|
|
|
|
|
|
|
#include "RigSummaryCaseData.h"
|
|
|
|
|
2016-06-13 06:29:40 -05:00
|
|
|
#include "RimDefines.h"
|
|
|
|
#include "RimEclipseResultCase.h"
|
|
|
|
#include "RimProject.h"
|
2016-06-30 03:06:15 -05:00
|
|
|
#include "RimSummaryCase.h"
|
|
|
|
#include "RimSummaryCurve.h"
|
2016-10-10 04:05:45 -05:00
|
|
|
#include "RimSummaryCurveAppearanceCalculator.h"
|
|
|
|
#include "RimSummaryFilter.h"
|
2016-06-13 06:29:40 -05:00
|
|
|
#include "RimSummaryPlot.h"
|
|
|
|
#include "RimSummaryPlotCollection.h"
|
2016-06-30 03:06:15 -05:00
|
|
|
|
|
|
|
#include "RiuLineSegmentQwtPlotCurve.h"
|
2016-06-13 06:29:40 -05:00
|
|
|
#include "RiuSummaryQwtPlot.h"
|
|
|
|
|
2016-06-30 03:06:15 -05:00
|
|
|
#include "WellLogCommands/RicWellLogPlotCurveFeatureImpl.h"
|
|
|
|
|
2016-06-13 06:29:40 -05:00
|
|
|
#include "cafPdmUiListEditor.h"
|
2016-06-16 09:10:16 -05:00
|
|
|
#include "cafPdmUiPushButtonEditor.h"
|
2016-06-13 06:29:40 -05:00
|
|
|
|
|
|
|
|
2016-06-15 08:18:45 -05:00
|
|
|
QTextStream& operator << (QTextStream& str, const std::vector<RifEclipseSummaryAddress>& sobj)
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return str;
|
|
|
|
}
|
|
|
|
|
|
|
|
QTextStream& operator >> (QTextStream& str, std::vector<RifEclipseSummaryAddress>& sobj)
|
|
|
|
{
|
|
|
|
CVF_ASSERT(false);
|
|
|
|
return str;
|
|
|
|
}
|
|
|
|
|
2016-06-13 06:29:40 -05:00
|
|
|
|
|
|
|
CAF_PDM_SOURCE_INIT(RimSummaryCurveFilter, "SummaryCurveFilter");
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RimSummaryCurveFilter::RimSummaryCurveFilter()
|
|
|
|
{
|
2016-06-21 07:17:50 -05:00
|
|
|
CAF_PDM_InitObject("Curve Filter", ":/SummaryCurveFilter16x16.png", "", "");
|
2016-06-13 06:29:40 -05:00
|
|
|
|
2016-06-19 14:34:30 -05:00
|
|
|
CAF_PDM_InitFieldNoDefault(&m_selectedSummaryCases, "SummaryCases", "Cases", "", "", "");
|
2016-10-10 08:38:31 -05:00
|
|
|
m_selectedSummaryCases.uiCapability()->setUiTreeChildrenHidden(true);
|
2016-06-19 14:34:30 -05:00
|
|
|
m_selectedSummaryCases.uiCapability()->setUiEditorTypeName(caf::PdmUiListEditor::uiEditorTypeName());
|
2016-06-20 05:12:00 -05:00
|
|
|
m_selectedSummaryCases.uiCapability()->setAutoAddingOptionFromValue(false);
|
2016-06-20 09:54:20 -05:00
|
|
|
m_selectedSummaryCases.xmlCapability()->setIOWritable(false);
|
|
|
|
m_selectedSummaryCases.xmlCapability()->setIOReadable(false);
|
2016-06-22 07:34:56 -05:00
|
|
|
m_selectedSummaryCases.uiCapability()->setUiLabelPosition(caf::PdmUiItemInfo::TOP);
|
2016-06-19 14:34:30 -05:00
|
|
|
|
2016-06-13 06:29:40 -05:00
|
|
|
CAF_PDM_InitFieldNoDefault(&m_selectedVariableDisplayField, "SelectedVariableDisplayVar", "Variables", "", "", "");
|
|
|
|
m_selectedVariableDisplayField.xmlCapability()->setIOWritable(false);
|
|
|
|
m_selectedVariableDisplayField.xmlCapability()->setIOReadable(false);
|
|
|
|
m_selectedVariableDisplayField.uiCapability()->setUiReadOnly(true);
|
2016-06-17 06:30:25 -05:00
|
|
|
m_selectedVariableDisplayField.uiCapability()->setUiHidden(true);
|
2016-06-13 06:29:40 -05:00
|
|
|
|
2016-06-15 10:31:50 -05:00
|
|
|
CAF_PDM_InitFieldNoDefault(&m_summaryFilter, "VarListFilter", "Filter", "", "", "");
|
2016-10-10 08:38:31 -05:00
|
|
|
m_summaryFilter.uiCapability()->setUiTreeChildrenHidden(true);
|
2016-06-15 10:31:50 -05:00
|
|
|
m_summaryFilter.uiCapability()->setUiHidden(true);
|
|
|
|
m_summaryFilter = new RimSummaryFilter();
|
|
|
|
|
2016-06-13 06:29:40 -05:00
|
|
|
CAF_PDM_InitFieldNoDefault(&m_uiFilterResultMultiSelection, "FilterResultSelection", "Filter Result", "", "", "");
|
2016-06-15 10:31:50 -05:00
|
|
|
m_uiFilterResultMultiSelection.xmlCapability()->setIOWritable(false);
|
|
|
|
m_uiFilterResultMultiSelection.xmlCapability()->setIOReadable(false);
|
2016-06-13 06:29:40 -05:00
|
|
|
m_uiFilterResultMultiSelection.uiCapability()->setUiEditorTypeName(caf::PdmUiListEditor::uiEditorTypeName());
|
|
|
|
m_uiFilterResultMultiSelection.uiCapability()->setUiLabelPosition(caf::PdmUiItemInfo::HIDDEN);
|
|
|
|
m_uiFilterResultMultiSelection.uiCapability()->setAutoAddingOptionFromValue(false);
|
|
|
|
|
|
|
|
CAF_PDM_InitFieldNoDefault(&m_curves, "FilteredCurves", "Filtered Curves", "", "", "");
|
|
|
|
m_curves.uiCapability()->setUiHidden(true);
|
2016-10-10 08:38:31 -05:00
|
|
|
m_curves.uiCapability()->setUiTreeChildrenHidden(false);
|
2016-06-16 09:10:16 -05:00
|
|
|
|
|
|
|
CAF_PDM_InitFieldNoDefault(&m_applyButtonField, "ApplySelection", "Apply", "", "", "");
|
|
|
|
m_applyButtonField.xmlCapability()->setIOWritable(false);
|
|
|
|
m_applyButtonField.xmlCapability()->setIOReadable(false);
|
|
|
|
m_applyButtonField = false;
|
|
|
|
m_applyButtonField.uiCapability()->setUiEditorTypeName(caf::PdmUiPushButtonEditor::uiEditorTypeName());
|
|
|
|
m_applyButtonField.uiCapability()->setUiLabelPosition(caf::PdmUiItemInfo::HIDDEN);
|
2016-08-09 04:35:48 -05:00
|
|
|
|
2016-10-05 05:01:43 -05:00
|
|
|
CAF_PDM_InitField(&m_showCurves, "IsActive", true, "Show Curves", "", "", "");
|
|
|
|
m_showCurves.uiCapability()->setUiHidden(true);
|
2016-08-09 04:35:48 -05:00
|
|
|
|
|
|
|
CAF_PDM_InitField(&m_useAutoAppearanceAssignment, "UseAutoAppearanceAssignment", true, "Auto", "", "", "" );
|
|
|
|
|
|
|
|
CAF_PDM_InitFieldNoDefault(&m_caseAppearanceType, "CaseAppearanceType", "Case", "", "", "");
|
|
|
|
CAF_PDM_InitFieldNoDefault(&m_variableAppearanceType, "VariableAppearanceType", "Vector", "", "", "");
|
|
|
|
CAF_PDM_InitFieldNoDefault(&m_wellAppearanceType, "WellAppearanceType", "Well", "", "", "");
|
|
|
|
CAF_PDM_InitFieldNoDefault(&m_groupAppearanceType, "GroupAppearanceType", "Group", "", "", "");
|
|
|
|
CAF_PDM_InitFieldNoDefault(&m_regionAppearanceType, "RegionAppearanceType", "Region", "", "", "");
|
|
|
|
|
2016-10-10 04:05:45 -05:00
|
|
|
CAF_PDM_InitFieldNoDefault(&m_plotAxis, "PlotAxis", "Axis", "", "", "");
|
2016-06-13 06:29:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RimSummaryCurveFilter::~RimSummaryCurveFilter()
|
|
|
|
{
|
2016-06-16 09:10:16 -05:00
|
|
|
delete m_summaryFilter();
|
2016-06-13 06:29:40 -05:00
|
|
|
m_curves.deleteAllChildObjects();
|
|
|
|
}
|
|
|
|
|
2016-06-30 03:06:15 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2016-06-30 06:21:04 -05:00
|
|
|
void RimSummaryCurveFilter::createCurves(RimSummaryCase* summaryCase, const QString& stringFilter)
|
2016-06-30 03:06:15 -05:00
|
|
|
{
|
2016-06-30 06:21:04 -05:00
|
|
|
if (summaryCase)
|
2016-06-30 03:06:15 -05:00
|
|
|
{
|
|
|
|
std::vector<RimSummaryCase*> selectedCases;
|
2016-06-30 06:21:04 -05:00
|
|
|
selectedCases.push_back(summaryCase);
|
2016-06-30 03:06:15 -05:00
|
|
|
|
|
|
|
m_summaryFilter->setCompleteVarStringFilter(stringFilter);
|
|
|
|
|
|
|
|
std::set<std::pair<RimSummaryCase*, RifEclipseSummaryAddress> > newCurveDefinitions;
|
|
|
|
|
|
|
|
createSetOfCasesAndResultAdresses(selectedCases, *m_summaryFilter, &newCurveDefinitions);
|
|
|
|
|
|
|
|
createCurvesFromCurveDefinitions(newCurveDefinitions);
|
|
|
|
}
|
|
|
|
}
|
2016-06-13 06:29:40 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
QList<caf::PdmOptionItemInfo> RimSummaryCurveFilter::calculateValueOptions(const caf::PdmFieldHandle* fieldNeedingOptions, bool* useOptionsOnly)
|
|
|
|
{
|
|
|
|
QList<caf::PdmOptionItemInfo> optionList;
|
|
|
|
|
2016-06-19 14:34:30 -05:00
|
|
|
if (fieldNeedingOptions == &m_selectedSummaryCases)
|
2016-06-13 06:29:40 -05:00
|
|
|
{
|
|
|
|
RimProject* proj = RiaApplication::instance()->project();
|
|
|
|
std::vector<RimSummaryCase*> cases;
|
|
|
|
|
|
|
|
proj->allSummaryCases(cases);
|
|
|
|
|
|
|
|
for (size_t i = 0; i < cases.size(); i++)
|
|
|
|
{
|
|
|
|
RimSummaryCase* rimCase = cases[i];
|
|
|
|
|
|
|
|
optionList.push_back(caf::PdmOptionItemInfo(rimCase->caseName(), QVariant::fromValue(caf::PdmPointer<caf::PdmObjectHandle>(rimCase))));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else if(fieldNeedingOptions == &m_uiFilterResultMultiSelection)
|
|
|
|
{
|
2016-08-04 04:15:31 -05:00
|
|
|
std::set<RifEclipseSummaryAddress> addrUnion = findPossibleSummaryAddresses();
|
2016-06-13 06:29:40 -05:00
|
|
|
|
2016-06-19 14:34:30 -05:00
|
|
|
for(const auto& address: addrUnion)
|
|
|
|
{
|
|
|
|
std::string name = address.uiText();
|
|
|
|
QString s = QString::fromStdString(name);
|
|
|
|
optionList.push_back(caf::PdmOptionItemInfo(s, QVariant::fromValue(address)));
|
2016-06-13 06:29:40 -05:00
|
|
|
}
|
|
|
|
}
|
2016-06-19 14:34:30 -05:00
|
|
|
|
|
|
|
if(useOptionsOnly) *useOptionsOnly = true;
|
|
|
|
|
2016-06-13 06:29:40 -05:00
|
|
|
return optionList;
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RimSummaryCurveFilter::defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering)
|
|
|
|
{
|
2016-06-22 07:34:56 -05:00
|
|
|
caf::PdmUiGroup* curveDataGroup = uiOrdering.addNewGroup("Summary Vectors");
|
2016-06-19 14:34:30 -05:00
|
|
|
curveDataGroup->add(&m_selectedSummaryCases);
|
2016-06-13 06:29:40 -05:00
|
|
|
curveDataGroup->add(&m_selectedVariableDisplayField);
|
|
|
|
|
2016-06-20 10:55:11 -05:00
|
|
|
caf::PdmUiGroup* curveVarSelectionGroup = curveDataGroup->addNewGroup("Vector Selection");
|
2016-06-13 06:29:40 -05:00
|
|
|
|
2016-06-16 02:50:47 -05:00
|
|
|
m_summaryFilter->defineUiOrdering(uiConfigName, *curveVarSelectionGroup);
|
2016-06-13 06:29:40 -05:00
|
|
|
|
|
|
|
curveVarSelectionGroup->add(&m_uiFilterResultMultiSelection);
|
2016-08-09 04:35:48 -05:00
|
|
|
|
|
|
|
caf::PdmUiGroup* appearanceGroup = uiOrdering.addNewGroup("Appearance settings");
|
|
|
|
appearanceGroup->add(&m_useAutoAppearanceAssignment);
|
2016-10-05 07:22:45 -05:00
|
|
|
if(!m_useAutoAppearanceAssignment())
|
|
|
|
{
|
|
|
|
appearanceGroup->add(&m_caseAppearanceType);
|
|
|
|
appearanceGroup->add(&m_variableAppearanceType);
|
|
|
|
appearanceGroup->add(&m_wellAppearanceType);
|
|
|
|
appearanceGroup->add(&m_groupAppearanceType);
|
|
|
|
appearanceGroup->add(&m_regionAppearanceType);
|
|
|
|
}
|
2016-08-09 04:35:48 -05:00
|
|
|
|
|
|
|
// Set sensitivity
|
|
|
|
{
|
|
|
|
m_caseAppearanceType.uiCapability()->setUiReadOnly(m_useAutoAppearanceAssignment);
|
|
|
|
m_variableAppearanceType.uiCapability()->setUiReadOnly(m_useAutoAppearanceAssignment);
|
|
|
|
m_wellAppearanceType.uiCapability()->setUiReadOnly(m_useAutoAppearanceAssignment);
|
|
|
|
m_groupAppearanceType.uiCapability()->setUiReadOnly(m_useAutoAppearanceAssignment);
|
|
|
|
m_regionAppearanceType.uiCapability()->setUiReadOnly(m_useAutoAppearanceAssignment);
|
|
|
|
}
|
|
|
|
|
2016-10-10 04:05:45 -05:00
|
|
|
uiOrdering.add(&m_plotAxis);
|
2016-06-16 09:10:16 -05:00
|
|
|
uiOrdering.add(&m_applyButtonField);
|
2016-10-10 04:05:45 -05:00
|
|
|
|
2016-06-13 07:50:28 -05:00
|
|
|
uiOrdering.setForgetRemainingFields(true);
|
2016-06-13 06:29:40 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RimSummaryCurveFilter::fieldChangedByUi(const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue)
|
|
|
|
{
|
2016-06-16 09:10:16 -05:00
|
|
|
if(changedField == &m_uiFilterResultMultiSelection)
|
2016-06-13 06:29:40 -05:00
|
|
|
{
|
2016-06-16 09:10:16 -05:00
|
|
|
|
|
|
|
}
|
|
|
|
else if (changedField == &m_applyButtonField)
|
|
|
|
{
|
|
|
|
syncCurvesFromUiSelection();
|
|
|
|
loadDataAndUpdate();
|
|
|
|
m_applyButtonField = false;
|
2016-06-22 07:34:56 -05:00
|
|
|
|
|
|
|
RimSummaryPlot* plot = nullptr;
|
2016-09-21 06:59:41 -05:00
|
|
|
firstAncestorOrThisOfType(plot);
|
2016-10-11 12:40:45 -05:00
|
|
|
plot->updateAxes();
|
2016-06-13 06:29:40 -05:00
|
|
|
}
|
2016-10-05 05:01:43 -05:00
|
|
|
else if (changedField == &m_showCurves)
|
|
|
|
{
|
|
|
|
for(RimSummaryCurve* curve : m_curves)
|
|
|
|
{
|
|
|
|
curve->updateCurveVisibility();
|
|
|
|
}
|
|
|
|
if (m_parentQwtPlot) m_parentQwtPlot->replot();
|
|
|
|
}
|
2016-10-10 04:05:45 -05:00
|
|
|
else if (changedField == &m_plotAxis)
|
|
|
|
{
|
2016-10-10 08:52:18 -05:00
|
|
|
updatePlotAxisForCurves();
|
2016-10-10 04:05:45 -05:00
|
|
|
}
|
2016-06-13 06:29:40 -05:00
|
|
|
}
|
|
|
|
|
2016-06-13 07:50:28 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RimSummaryCurveFilter::setParentQwtPlot(QwtPlot* plot)
|
|
|
|
{
|
2016-06-16 09:10:16 -05:00
|
|
|
m_parentQwtPlot = plot;
|
2016-06-13 07:50:28 -05:00
|
|
|
for (RimSummaryCurve* curve : m_curves)
|
|
|
|
{
|
|
|
|
curve->setParentQwtPlot(plot);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2016-06-17 06:30:25 -05:00
|
|
|
void RimSummaryCurveFilter::detachQwtCurves()
|
2016-06-13 07:50:28 -05:00
|
|
|
{
|
|
|
|
for(RimSummaryCurve* curve : m_curves)
|
|
|
|
{
|
|
|
|
curve->detachQwtCurve();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-22 04:34:26 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RimSummaryCurve* RimSummaryCurveFilter::findRimCurveFromQwtCurve(const QwtPlotCurve* qwtCurve) const
|
|
|
|
{
|
|
|
|
for(RimSummaryCurve* rimCurve: m_curves)
|
|
|
|
{
|
|
|
|
if(rimCurve->qwtPlotCurve() == qwtCurve)
|
|
|
|
{
|
|
|
|
return rimCurve;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2016-06-15 08:18:45 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
2016-06-16 09:10:16 -05:00
|
|
|
void RimSummaryCurveFilter::syncCurvesFromUiSelection()
|
|
|
|
{
|
2016-06-16 09:49:31 -05:00
|
|
|
// Create a search map containing whats supposed to be curves
|
2016-06-16 09:10:16 -05:00
|
|
|
|
|
|
|
std::set<std::pair<RimSummaryCase*, RifEclipseSummaryAddress> > newCurveDefinitions;
|
|
|
|
|
|
|
|
// Populate the newCurveDefinitions from the Gui
|
2016-08-04 04:15:31 -05:00
|
|
|
|
|
|
|
std::set<RifEclipseSummaryAddress> addrUnion = findPossibleSummaryAddresses();
|
|
|
|
|
2016-06-19 14:34:30 -05:00
|
|
|
for (RimSummaryCase* currentCase: m_selectedSummaryCases)
|
2016-06-16 09:10:16 -05:00
|
|
|
{
|
2016-06-21 08:56:09 -05:00
|
|
|
if (!currentCase || !currentCase->caseData() || !currentCase->caseData()->summaryReader()) continue;
|
|
|
|
|
|
|
|
RifReaderEclipseSummary* reader = currentCase->caseData()->summaryReader();
|
|
|
|
|
2016-06-16 09:10:16 -05:00
|
|
|
for(const RifEclipseSummaryAddress& addr: m_uiFilterResultMultiSelection.v())
|
|
|
|
{
|
2016-06-21 08:56:09 -05:00
|
|
|
if(!reader->hasAddress(addr)) continue;
|
2016-08-04 04:15:31 -05:00
|
|
|
if (addrUnion.count(addr) == 0 ) continue; // Wash the possible "old" ui selection with new filter
|
|
|
|
|
2016-06-16 09:10:16 -05:00
|
|
|
newCurveDefinitions.insert(std::make_pair(currentCase, addr));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-06-21 08:56:09 -05:00
|
|
|
m_curves.deleteAllChildObjects();
|
|
|
|
|
2016-06-30 03:06:15 -05:00
|
|
|
createCurvesFromCurveDefinitions(newCurveDefinitions);
|
2016-06-16 09:10:16 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RimSummaryCurveFilter::syncUiSelectionFromCurves()
|
2016-06-15 08:18:45 -05:00
|
|
|
{
|
2016-06-16 09:49:31 -05:00
|
|
|
// Create a search map containing whats supposed to be uiSelected
|
2016-06-20 05:12:00 -05:00
|
|
|
std::set<RimSummaryCase*> referredCases;
|
2016-06-16 09:49:31 -05:00
|
|
|
std::set<RifEclipseSummaryAddress> existingCurveDefinitions;
|
|
|
|
|
|
|
|
// Populate the existingCurveDefinitions from the existing curves
|
2016-06-16 09:10:16 -05:00
|
|
|
for(RimSummaryCurve* curve: m_curves)
|
|
|
|
{
|
2016-06-16 09:49:31 -05:00
|
|
|
existingCurveDefinitions.insert(curve->summaryAddress());
|
2016-06-20 05:12:00 -05:00
|
|
|
referredCases.insert(curve->summaryCase());
|
|
|
|
}
|
|
|
|
|
2016-08-04 04:15:31 -05:00
|
|
|
if (m_curves.size()) // Only sync the selected cases if we actually have some curves. To avoid user getting an empty variable list accidentally
|
2016-06-20 05:12:00 -05:00
|
|
|
{
|
2016-08-04 04:15:31 -05:00
|
|
|
m_selectedSummaryCases.clear();
|
|
|
|
|
|
|
|
for(RimSummaryCase* currCase: referredCases)
|
|
|
|
{
|
|
|
|
m_selectedSummaryCases.push_back(currCase);
|
|
|
|
}
|
2016-06-16 09:49:31 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
m_uiFilterResultMultiSelection.v().clear();
|
2016-06-19 14:34:30 -05:00
|
|
|
|
2016-06-16 09:49:31 -05:00
|
|
|
for(const RifEclipseSummaryAddress& addr: existingCurveDefinitions)
|
|
|
|
{
|
|
|
|
m_uiFilterResultMultiSelection.v().push_back(addr);
|
2016-06-16 09:10:16 -05:00
|
|
|
}
|
2016-06-15 08:18:45 -05:00
|
|
|
}
|
|
|
|
|
2016-06-16 09:10:16 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RimSummaryCurveFilter::defineEditorAttribute(const caf::PdmFieldHandle* field, QString uiConfigName, caf::PdmUiEditorAttribute * attribute)
|
|
|
|
{
|
|
|
|
if(&m_applyButtonField == field)
|
|
|
|
{
|
|
|
|
caf::PdmUiPushButtonEditorAttribute* attrib = dynamic_cast<caf::PdmUiPushButtonEditorAttribute*> (attribute);
|
|
|
|
attrib->m_buttonText = "Apply" ;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-10-10 08:52:18 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RimSummaryCurveFilter::updatePlotAxisForCurves()
|
|
|
|
{
|
|
|
|
for (RimSummaryCurve* curve : m_curves)
|
|
|
|
{
|
|
|
|
curve->setPlotAxis(m_plotAxis());
|
|
|
|
curve->updateQwtPlotAxis();
|
|
|
|
}
|
2016-10-11 12:40:45 -05:00
|
|
|
|
|
|
|
RimSummaryPlot* plot = nullptr;
|
|
|
|
firstAncestorOrThisOfType(plot);
|
|
|
|
plot->updateAxes();
|
2016-10-10 08:52:18 -05:00
|
|
|
}
|
|
|
|
|
2016-06-16 09:10:16 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RimSummaryCurveFilter::loadDataAndUpdate()
|
|
|
|
{
|
|
|
|
for (RimSummaryCurve* curve: m_curves)
|
|
|
|
{
|
|
|
|
curve->loadDataAndUpdate();
|
|
|
|
}
|
2016-06-16 09:49:31 -05:00
|
|
|
|
|
|
|
syncUiSelectionFromCurves();
|
2016-06-16 09:10:16 -05:00
|
|
|
}
|
2016-06-22 07:34:56 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
std::set<std::string> RimSummaryCurveFilter::unitNames()
|
|
|
|
{
|
|
|
|
std::set<std::string> unitNames;
|
|
|
|
for(RimSummaryCurve* curve: m_curves)
|
|
|
|
{
|
|
|
|
if (curve->isCurveVisible()) unitNames.insert( curve->unitName());
|
|
|
|
}
|
|
|
|
return unitNames;
|
|
|
|
}
|
2016-06-30 03:06:15 -05:00
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RimSummaryCurveFilter::createSetOfCasesAndResultAdresses(
|
|
|
|
const std::vector<RimSummaryCase*>& cases,
|
|
|
|
const RimSummaryFilter& filter,
|
|
|
|
std::set<std::pair<RimSummaryCase*, RifEclipseSummaryAddress> >* curveDefinitions) const
|
|
|
|
{
|
|
|
|
for (RimSummaryCase* currentCase : cases)
|
|
|
|
{
|
|
|
|
if (!currentCase || !currentCase->caseData() || !currentCase->caseData()->summaryReader()) continue;
|
|
|
|
|
|
|
|
RifReaderEclipseSummary* reader = currentCase->caseData()->summaryReader();
|
|
|
|
|
|
|
|
const std::vector<RifEclipseSummaryAddress> allAddresses = reader->allResultAddresses();
|
|
|
|
int addressCount = static_cast<int>(allAddresses.size());
|
|
|
|
for (int i = 0; i < addressCount; i++)
|
|
|
|
{
|
|
|
|
if (!filter.isIncludedByFilter(allAddresses[i])) continue;
|
|
|
|
|
|
|
|
curveDefinitions->insert(std::make_pair(currentCase, allAddresses[i]));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-08 08:14:34 -05:00
|
|
|
|
2016-06-30 03:06:15 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RimSummaryCurveFilter::createCurvesFromCurveDefinitions(const std::set<std::pair<RimSummaryCase*, RifEclipseSummaryAddress> >& curveDefinitions)
|
|
|
|
{
|
|
|
|
int colorIndex = 2;
|
|
|
|
int lineStyleIdx = -1;
|
|
|
|
|
|
|
|
RimSummaryCase* prevCase = nullptr;
|
|
|
|
RimPlotCurve::LineStyleEnum lineStyle = RimPlotCurve::STYLE_SOLID;
|
2016-08-09 04:35:48 -05:00
|
|
|
RimSummaryCurveAppearanceCalculator curveLookCalc(curveDefinitions);
|
|
|
|
|
|
|
|
if (!m_useAutoAppearanceAssignment())
|
|
|
|
{
|
|
|
|
curveLookCalc.assignDimensions( m_caseAppearanceType(),
|
|
|
|
m_variableAppearanceType(),
|
|
|
|
m_wellAppearanceType(),
|
|
|
|
m_groupAppearanceType(),
|
|
|
|
m_regionAppearanceType());
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
RimSummaryCurveAppearanceCalculator::CurveAppearanceType caseAppearance;
|
|
|
|
RimSummaryCurveAppearanceCalculator::CurveAppearanceType variAppearance;
|
|
|
|
RimSummaryCurveAppearanceCalculator::CurveAppearanceType wellAppearance;
|
|
|
|
RimSummaryCurveAppearanceCalculator::CurveAppearanceType gropAppearance;
|
|
|
|
RimSummaryCurveAppearanceCalculator::CurveAppearanceType regiAppearance;
|
|
|
|
|
|
|
|
curveLookCalc.getDimensions(&caseAppearance,
|
|
|
|
&variAppearance,
|
|
|
|
&wellAppearance,
|
|
|
|
&gropAppearance,
|
|
|
|
®iAppearance);
|
|
|
|
|
|
|
|
m_caseAppearanceType = caseAppearance;
|
|
|
|
m_variableAppearanceType = variAppearance;
|
|
|
|
m_wellAppearanceType = wellAppearance;
|
|
|
|
m_groupAppearanceType = gropAppearance;
|
|
|
|
m_regionAppearanceType = regiAppearance;
|
|
|
|
}
|
2016-06-30 03:06:15 -05:00
|
|
|
|
|
|
|
for (auto& caseAddrPair : curveDefinitions)
|
|
|
|
{
|
|
|
|
RimSummaryCase* currentCase = caseAddrPair.first;
|
|
|
|
|
|
|
|
RimSummaryCurve* curve = new RimSummaryCurve();
|
|
|
|
curve->setParentQwtPlot(m_parentQwtPlot);
|
|
|
|
curve->setSummaryCase(currentCase);
|
|
|
|
curve->setSummaryAddress(caseAddrPair.second);
|
|
|
|
m_curves.push_back(curve);
|
2016-08-08 08:14:34 -05:00
|
|
|
|
|
|
|
curveLookCalc.setupCurveLook(curve);
|
2016-06-30 03:06:15 -05:00
|
|
|
}
|
|
|
|
}
|
2016-07-06 06:35:24 -05:00
|
|
|
|
2016-08-08 08:14:34 -05:00
|
|
|
|
|
|
|
|
2016-07-06 06:35:24 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RimSummaryCurveFilter::updateCaseNameHasChanged()
|
|
|
|
{
|
|
|
|
for (RimSummaryCurve* curve : m_curves)
|
|
|
|
{
|
|
|
|
curve->updateCurveName();
|
|
|
|
curve->updateConnectedEditors();
|
|
|
|
}
|
|
|
|
}
|
2016-08-04 04:15:31 -05:00
|
|
|
|
2016-10-05 05:01:43 -05:00
|
|
|
|
2016-10-10 04:05:45 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
RimDefines::PlotAxis RimSummaryCurveFilter::associatedPlotAxis() const
|
|
|
|
{
|
|
|
|
return m_plotAxis();
|
|
|
|
}
|
|
|
|
|
2016-10-10 08:52:18 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
void RimSummaryCurveFilter::setPlotAxis(RimDefines::PlotAxis plotAxis)
|
|
|
|
{
|
|
|
|
m_plotAxis = plotAxis;
|
|
|
|
updateConnectedEditors();
|
|
|
|
|
2016-10-11 12:40:45 -05:00
|
|
|
updatePlotAxisForCurves();
|
2016-10-10 08:52:18 -05:00
|
|
|
}
|
|
|
|
|
2016-10-05 05:01:43 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
bool RimSummaryCurveFilter::isCurvesVisible()
|
|
|
|
{
|
|
|
|
return m_showCurves();
|
|
|
|
}
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
caf::PdmFieldHandle* RimSummaryCurveFilter::objectToggleField()
|
|
|
|
{
|
|
|
|
return &m_showCurves;
|
|
|
|
}
|
|
|
|
|
2016-08-04 04:15:31 -05:00
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
///
|
|
|
|
//--------------------------------------------------------------------------------------------------
|
|
|
|
std::set<RifEclipseSummaryAddress> RimSummaryCurveFilter::findPossibleSummaryAddresses()
|
|
|
|
{
|
|
|
|
std::set<RifEclipseSummaryAddress> addrUnion;
|
|
|
|
|
|
|
|
for(RimSummaryCase* currCase: m_selectedSummaryCases)
|
|
|
|
{
|
|
|
|
RifReaderEclipseSummary* reader = nullptr;
|
|
|
|
if(currCase && currCase->caseData()) reader = currCase->caseData()->summaryReader();
|
|
|
|
|
|
|
|
if(reader)
|
|
|
|
{
|
|
|
|
const std::vector<RifEclipseSummaryAddress> allAddresses = reader->allResultAddresses();
|
|
|
|
int addressCount = static_cast<int>(allAddresses.size());
|
|
|
|
|
|
|
|
for(int i = 0; i <addressCount; i++)
|
|
|
|
{
|
|
|
|
if(!m_summaryFilter->isIncludedByFilter(allAddresses[i])) continue;
|
|
|
|
addrUnion.insert(allAddresses[i]);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return addrUnion;
|
|
|
|
}
|