mirror of
https://github.com/OPM/ResInsight.git
synced 2025-02-25 18:55:39 -06:00
#4003 Use the preferences settings when creating default summary plots.
Refactored to make assigning default curve appearance easier.
This commit is contained in:
@@ -71,6 +71,7 @@ void RicNewSummaryCurveFeature::onActionTriggered(bool isChecked)
|
||||
|
||||
RimSummaryCurve* newCurve = RicSummaryPlotFeatureImpl::addDefaultCurveToPlot(plot, defaultCase);
|
||||
|
||||
plot->applyDefaultCurveAppearances();
|
||||
plot->loadDataAndUpdate();
|
||||
plot->updateConnectedEditors();
|
||||
|
||||
|
||||
@@ -196,33 +196,33 @@ void RicNewDefaultSummaryPlotFeature::onActionTriggered(bool isChecked)
|
||||
{
|
||||
auto sumPlotSumCasesPair = extractSumPlotCollectionOrSelectedSumCasesFromSelection();
|
||||
|
||||
RimSummaryPlotCollection* sumPlotColl = RiaApplication::instance()->project()->mainPlotCollection()->summaryPlotCollection();
|
||||
|
||||
RimSummaryPlot* newPlot = nullptr;
|
||||
std::vector<RimSummaryCase*> summaryCasesToUse;
|
||||
|
||||
if (sumPlotSumCasesPair.first)
|
||||
{
|
||||
auto sumCaseVector = RiaApplication::instance()->project()->allSummaryCases();
|
||||
|
||||
newPlot = sumPlotColl->createSummaryPlotWithAutoTitle();
|
||||
|
||||
if (sumCaseVector.size())
|
||||
{
|
||||
RicSummaryPlotFeatureImpl::addDefaultCurveToPlot(newPlot, sumCaseVector[0]);
|
||||
summaryCasesToUse.push_back(sumCaseVector[0]);
|
||||
}
|
||||
}
|
||||
else if (sumPlotSumCasesPair.second.size())
|
||||
{
|
||||
newPlot = sumPlotColl->createSummaryPlotWithAutoTitle();
|
||||
|
||||
for (RimSummaryCase* sumCase : sumPlotSumCasesPair.second)
|
||||
{
|
||||
RicSummaryPlotFeatureImpl::addDefaultCurveToPlot(newPlot, sumCase);
|
||||
}
|
||||
summaryCasesToUse = sumPlotSumCasesPair.second;
|
||||
}
|
||||
|
||||
if ( newPlot )
|
||||
if ( summaryCasesToUse.size() )
|
||||
{
|
||||
RimSummaryPlotCollection* sumPlotColl = RiaApplication::instance()->project()->mainPlotCollection()->summaryPlotCollection();
|
||||
RimSummaryPlot* newPlot = sumPlotColl->createSummaryPlotWithAutoTitle();
|
||||
|
||||
for (RimSummaryCase* sumCase : summaryCasesToUse)
|
||||
{
|
||||
RicSummaryPlotFeatureImpl::addDefaultCurvesToPlot(newPlot, sumCase);
|
||||
}
|
||||
|
||||
newPlot->applyDefaultCurveAppearances();
|
||||
newPlot->loadDataAndUpdate();
|
||||
|
||||
sumPlotColl->updateConnectedEditors();
|
||||
|
||||
@@ -441,8 +441,7 @@ void RicSummaryCurveCreator::updatePreviewCurvesFromCurveDefinitions(
|
||||
if (!def.isEnsembleCurve()) summaryCurveDefsToDisplay.insert(def);
|
||||
}
|
||||
|
||||
RimSummaryCurveAppearanceCalculator curveLookCalc(
|
||||
summaryCurveDefsToDisplay, getAllSummaryCaseNames(), getAllSummaryWellNames());
|
||||
RimSummaryCurveAppearanceCalculator curveLookCalc(summaryCurveDefsToDisplay);
|
||||
initCurveAppearanceCalculator(curveLookCalc);
|
||||
|
||||
// Delete curves
|
||||
@@ -528,55 +527,6 @@ void RicSummaryCurveCreator::updatePreviewCurvesFromCurveDefinitions(
|
||||
m_previewPlot->summaryCurveCollection()->updateConnectedEditors();
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
std::set<std::string> RicSummaryCurveCreator::getAllSummaryCaseNames()
|
||||
{
|
||||
std::set<std::string> summaryCaseHashes;
|
||||
RimProject* proj = RiaApplication::instance()->project();
|
||||
|
||||
std::vector<RimSummaryCase*> cases = proj->allSummaryCases();
|
||||
for (RimSummaryCase* rimCase : cases)
|
||||
{
|
||||
summaryCaseHashes.insert(rimCase->summaryHeaderFilename().toUtf8().constData());
|
||||
}
|
||||
|
||||
return summaryCaseHashes;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
std::set<std::string> RicSummaryCurveCreator::getAllSummaryWellNames()
|
||||
{
|
||||
std::set<std::string> summaryWellNames;
|
||||
RimProject* proj = RiaApplication::instance()->project();
|
||||
|
||||
std::vector<RimSummaryCase*> cases = proj->allSummaryCases();
|
||||
for (RimSummaryCase* rimCase : cases)
|
||||
{
|
||||
RifSummaryReaderInterface* reader = nullptr;
|
||||
if (rimCase)
|
||||
{
|
||||
reader = rimCase->summaryReader();
|
||||
}
|
||||
|
||||
if (reader)
|
||||
{
|
||||
const std::set<RifEclipseSummaryAddress> allAddresses = reader->allResultAddresses();
|
||||
|
||||
for (auto& address : allAddresses)
|
||||
{
|
||||
if (address.category() == RifEclipseSummaryAddress::SUMMARY_WELL)
|
||||
{
|
||||
summaryWellNames.insert(address.wellName());
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
return summaryWellNames;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
@@ -816,9 +766,9 @@ void RicSummaryCurveCreator::initCurveAppearanceCalculator(RimSummaryCurveAppear
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RicSummaryCurveCreator::applyAppearanceToAllPreviewCurves()
|
||||
{
|
||||
std::set<RiaSummaryCurveDefinition> allCurveDefs = allPreviewCurveDefs();
|
||||
std::set<RiaSummaryCurveDefinition> allCurveDefs = m_previewPlot->summaryAndEnsembleCurveDefinitions();
|
||||
|
||||
RimSummaryCurveAppearanceCalculator curveLookCalc(allCurveDefs, getAllSummaryCaseNames(), getAllSummaryWellNames());
|
||||
RimSummaryCurveAppearanceCalculator curveLookCalc(allCurveDefs);
|
||||
initCurveAppearanceCalculator(curveLookCalc);
|
||||
|
||||
// Summary curves
|
||||
@@ -842,26 +792,12 @@ void RicSummaryCurveCreator::applyAppearanceToAllPreviewCurves()
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
void RicSummaryCurveCreator::updateAppearanceEditor()
|
||||
{
|
||||
std::set<RiaSummaryCurveDefinition> allCurveDefs = allPreviewCurveDefs();
|
||||
std::set<RiaSummaryCurveDefinition> allCurveDefs = m_previewPlot->summaryAndEnsembleCurveDefinitions();
|
||||
|
||||
RimSummaryCurveAppearanceCalculator curveLookCalc(allCurveDefs, getAllSummaryCaseNames(), getAllSummaryWellNames());
|
||||
RimSummaryCurveAppearanceCalculator curveLookCalc(allCurveDefs);
|
||||
initCurveAppearanceCalculator(curveLookCalc);
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
std::set<RiaSummaryCurveDefinition> RicSummaryCurveCreator::allPreviewCurveDefs() const
|
||||
{
|
||||
std::set<RiaSummaryCurveDefinition> allCurveDefs;
|
||||
|
||||
for (const auto& curve : m_previewPlot->summaryAndEnsembleCurves())
|
||||
{
|
||||
allCurveDefs.insert(RiaSummaryCurveDefinition(curve->summaryCaseY(), curve->summaryAddressY()));
|
||||
}
|
||||
return allCurveDefs;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
|
||||
@@ -89,8 +89,6 @@ private:
|
||||
const std::set<RiaSummaryCurveDefinition>& curveDefsToAdd,
|
||||
const std::set<RimSummaryCurve*>& curvesToDelete,
|
||||
const std::set<RimEnsembleCurveSet*>& curveSetsToDelete);
|
||||
std::set<std::string> getAllSummaryCaseNames();
|
||||
std::set<std::string> getAllSummaryWellNames();
|
||||
|
||||
void populateCurveCreator(const RimSummaryPlot& sourceSummaryPlot);
|
||||
void updateTargetPlot();
|
||||
@@ -102,7 +100,6 @@ private:
|
||||
void initCurveAppearanceCalculator(RimSummaryCurveAppearanceCalculator& curveAppearanceCalc);
|
||||
void applyAppearanceToAllPreviewCurves();
|
||||
void updateAppearanceEditor();
|
||||
std::set<RiaSummaryCurveDefinition> allPreviewCurveDefs() const;
|
||||
void createNewPlot();
|
||||
bool isObservedData(RimSummaryCase *sumCase) const;
|
||||
|
||||
|
||||
@@ -28,6 +28,9 @@
|
||||
|
||||
#include "RiaApplication.h"
|
||||
#include "RiaColorTables.h"
|
||||
#include "RiaPreferences.h"
|
||||
#include "RifSummaryReaderInterface.h"
|
||||
#include "RimSummaryCase.h"
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
@@ -36,6 +39,27 @@ RimSummaryCurve* RicSummaryPlotFeatureImpl::addDefaultCurveToPlot(RimSummaryPlot
|
||||
{
|
||||
if (plot)
|
||||
{
|
||||
RifEclipseSummaryAddress defaultAddressToUse;
|
||||
|
||||
QString curvesTextFilter = RiaApplication::instance()->preferences()->defaultSummaryCurvesTextFilter;
|
||||
QStringList curveFilters = curvesTextFilter.split(";", QString::SkipEmptyParts);
|
||||
|
||||
if ( curveFilters.size() )
|
||||
{
|
||||
const std::set<RifEclipseSummaryAddress>& addrs = summaryCase->summaryReader()->allResultAddresses();
|
||||
|
||||
for ( const auto & addr : addrs )
|
||||
{
|
||||
const QString& filter = curveFilters[0];
|
||||
{
|
||||
if ( addr.isUiTextMatchingFilterText(filter) )
|
||||
{
|
||||
defaultAddressToUse = addr;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
RimSummaryCurve* newCurve = new RimSummaryCurve();
|
||||
|
||||
// Use same counting as RicNewSummaryEnsembleCurveSetFeature::onActionTriggered
|
||||
@@ -49,7 +73,7 @@ RimSummaryCurve* RicSummaryPlotFeatureImpl::addDefaultCurveToPlot(RimSummaryPlot
|
||||
newCurve->setSummaryCaseY(summaryCase);
|
||||
}
|
||||
|
||||
newCurve->setSummaryAddressYAndApplyInterpolation(RifEclipseSummaryAddress::fieldAddress("FOPT"));
|
||||
newCurve->setSummaryAddressYAndApplyInterpolation(defaultAddressToUse);
|
||||
|
||||
return newCurve;
|
||||
}
|
||||
@@ -57,6 +81,45 @@ RimSummaryCurve* RicSummaryPlotFeatureImpl::addDefaultCurveToPlot(RimSummaryPlot
|
||||
return nullptr;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
std::vector<RimSummaryCurve*> RicSummaryPlotFeatureImpl::addDefaultCurvesToPlot(RimSummaryPlot* plot, RimSummaryCase* summaryCase)
|
||||
{
|
||||
std::vector<RimSummaryCurve*> defaultCurves;
|
||||
|
||||
QString curvesTextFilter = RiaApplication::instance()->preferences()->defaultSummaryCurvesTextFilter;
|
||||
QStringList curveFilters = curvesTextFilter.split(";", QString::SkipEmptyParts);
|
||||
|
||||
const std::set<RifEclipseSummaryAddress>& addrs = summaryCase->summaryReader()->allResultAddresses();
|
||||
std::vector<RifEclipseSummaryAddress> curveAddressesToUse;
|
||||
|
||||
for (const auto & addr : addrs)
|
||||
{
|
||||
for (const QString& filter: curveFilters)
|
||||
{
|
||||
if ( addr.isUiTextMatchingFilterText(filter) )
|
||||
{
|
||||
curveAddressesToUse.push_back(addr);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
for (const auto & addr : curveAddressesToUse)
|
||||
{
|
||||
RimSummaryCurve* newCurve = new RimSummaryCurve();
|
||||
plot->addCurveNoUpdate(newCurve);
|
||||
if (summaryCase)
|
||||
{
|
||||
newCurve->setSummaryCaseY(summaryCase);
|
||||
}
|
||||
newCurve->setSummaryAddressYAndApplyInterpolation(addr);
|
||||
defaultCurves.push_back(newCurve);
|
||||
}
|
||||
|
||||
return defaultCurves;
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
@@ -82,13 +145,18 @@ void RicSummaryPlotFeatureImpl::createDefaultSummaryPlot( RimSummaryCase* summar
|
||||
{
|
||||
auto plot = summaryPlotCollection->createSummaryPlotWithAutoTitle();
|
||||
|
||||
auto curve = RicSummaryPlotFeatureImpl::addDefaultCurveToPlot(plot, summaryCase);
|
||||
std::vector<RimSummaryCurve*> curves = RicSummaryPlotFeatureImpl::addDefaultCurvesToPlot(plot, summaryCase);
|
||||
|
||||
plot->applyDefaultCurveAppearances();
|
||||
plot->loadDataAndUpdate();
|
||||
|
||||
summaryPlotCollection->updateConnectedEditors();
|
||||
|
||||
RiuPlotMainWindowTools::setExpanded(curve);
|
||||
RiuPlotMainWindowTools::selectAsCurrentItem(curve);
|
||||
caf::PdmObject* itemToSelect = plot;
|
||||
if (curves.size()) itemToSelect = curves[0];
|
||||
|
||||
RiuPlotMainWindowTools::setExpanded(itemToSelect);
|
||||
RiuPlotMainWindowTools::selectAsCurrentItem(itemToSelect);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -22,12 +22,16 @@ class RimSummaryPlot;
|
||||
class RimSummaryCase;
|
||||
class RimSummaryPlotCollection;
|
||||
|
||||
#include <vector>
|
||||
|
||||
class RicSummaryPlotFeatureImpl
|
||||
{
|
||||
public:
|
||||
static RimSummaryCurve* addDefaultCurveToPlot(RimSummaryPlot* plot, RimSummaryCase* summaryCase);
|
||||
static std::vector<RimSummaryCurve*> addDefaultCurvesToPlot(RimSummaryPlot* plot, RimSummaryCase* summaryCase);
|
||||
static void ensureAtLeastOnePlot(RimSummaryPlotCollection* summaryPlotCollection, RimSummaryCase* summaryCase);
|
||||
static void createDefaultSummaryPlot(RimSummaryCase* summaryCase);
|
||||
|
||||
|
||||
};
|
||||
|
||||
|
||||
Reference in New Issue
Block a user