mirror of
https://github.com/OPM/ResInsight.git
synced 2025-02-25 18:55:39 -06:00
#3318 Plot editor performance. Several performance fixes
This commit is contained in:
@@ -34,6 +34,8 @@
|
||||
#include "RimSummaryPlotCollection.h"
|
||||
#include "RimSummaryCase.h"
|
||||
#include "RimSummaryCaseCollection.h"
|
||||
#include "RimProject.h"
|
||||
#include "RimSummaryCaseMainCollection.h"
|
||||
|
||||
#include "RiuPlotMainWindow.h"
|
||||
|
||||
@@ -89,6 +91,23 @@ void RicNewSummaryPlotFeature::onActionTriggered(bool isChecked)
|
||||
|
||||
std::vector<caf::PdmObject*> sourcesToSelect(selectedCases.begin(), selectedCases.end());
|
||||
|
||||
if (sourcesToSelect.empty() && selectedGroups.empty())
|
||||
{
|
||||
const auto allSingleCases = project->firstSummaryCaseMainCollection()->topLevelSummaryCases();
|
||||
const auto allGroups = project->summaryGroups();
|
||||
std::vector<RimSummaryCaseCollection*> allEnsembles;
|
||||
for (const auto group : allGroups) if (group->isEnsemble()) allEnsembles.push_back(group);
|
||||
|
||||
if (!allSingleCases.empty())
|
||||
{
|
||||
sourcesToSelect.push_back(allSingleCases.front());
|
||||
}
|
||||
else if (!allEnsembles.empty())
|
||||
{
|
||||
sourcesToSelect.push_back(allEnsembles.front());
|
||||
}
|
||||
}
|
||||
|
||||
// Append grouped cases
|
||||
for (auto group : selectedGroups)
|
||||
{
|
||||
|
||||
@@ -77,6 +77,7 @@ const QString RicSummaryCurveCreator::CONFIGURATION_NAME = "CurveCreatorCfg";
|
||||
/// Internal functions
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
int ensembleCurveCount(const std::set<RiaSummaryCurveDefinition>& allCurveDefs);
|
||||
template <typename T> std::vector<T> toVector(const std::set<T>& set);
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
@@ -360,7 +361,9 @@ void RicSummaryCurveCreator::syncPreviewCurvesFromUiSelection()
|
||||
for (const auto& curve : currentCurvesInPreviewPlot)
|
||||
{
|
||||
RimSummaryCase* sumCase = curve->summaryCaseY();
|
||||
RiaSummaryCurveDefinition curveDef = RiaSummaryCurveDefinition(sumCase, curve->summaryAddressY(), sumCase ? sumCase->ensemble() : nullptr);
|
||||
|
||||
if (sumCase->ensemble()) continue;
|
||||
RiaSummaryCurveDefinition curveDef = RiaSummaryCurveDefinition(sumCase, curve->summaryAddressY());
|
||||
if (deleteCurveDefs.count(curveDef) > 0) curvesToDelete.insert(curve);
|
||||
}
|
||||
}
|
||||
@@ -435,13 +438,13 @@ void RicSummaryCurveCreator::updatePreviewCurvesFromCurveDefinitions(
|
||||
initCurveAppearanceCalculator(curveLookCalc);
|
||||
|
||||
// Delete curves
|
||||
for (const auto& curveSet : curveSetsToDelete)
|
||||
if(!curveSetsToDelete.empty())
|
||||
{
|
||||
m_previewPlot->ensembleCurveSetCollection()->deleteCurveSet(curveSet);
|
||||
m_previewPlot->ensembleCurveSetCollection()->deleteCurveSets(toVector(curveSetsToDelete));
|
||||
}
|
||||
for (const auto& curve : curvesToDelete)
|
||||
if(!curvesToDelete.empty())
|
||||
{
|
||||
m_previewPlot->deleteCurve(curve);
|
||||
m_previewPlot->deleteCurves(toVector(curvesToDelete));
|
||||
}
|
||||
|
||||
size_t ensembleCurveCnt = ensembleCurveCount(allCurveDefsToDisplay);
|
||||
@@ -1008,3 +1011,11 @@ int ensembleCurveCount(const std::set<RiaSummaryCurveDefinition>& allCurveDefs)
|
||||
return std::count_if(
|
||||
allCurveDefs.begin(), allCurveDefs.end(), [](const RiaSummaryCurveDefinition& def) { return def.isEnsembleCurve(); });
|
||||
}
|
||||
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
///
|
||||
//--------------------------------------------------------------------------------------------------
|
||||
template <typename T> std::vector<T> toVector(const std::set<T>& set)
|
||||
{
|
||||
return std::vector<T>(set.begin(), set.end());
|
||||
}
|
||||
|
||||
@@ -23,6 +23,8 @@
|
||||
#include "RicSummaryCurveCreator.h"
|
||||
#include "RicSummaryCurveCreatorSplitterUi.h"
|
||||
|
||||
#include "RifReaderEclipseSummary.h"
|
||||
|
||||
#include "RiuPlotMainWindow.h"
|
||||
#include "RiuTools.h"
|
||||
|
||||
@@ -84,4 +86,5 @@ void RicSummaryCurveCreatorDialog::slotDialogFinished()
|
||||
{
|
||||
plotwindow->cleanUpTemporaryWidgets();
|
||||
}
|
||||
RifReaderEclipseSummary::purgeCache();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user