///////////////////////////////////////////////////////////////////////////////// // // 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 // for more details. // ///////////////////////////////////////////////////////////////////////////////// #include "RicNewSummaryPlotFeature.h" #include "RiaApplication.h" #include "RiaPreferences.h" #include "RiaSummaryTools.h" #include "RicEditSummaryPlotFeature.h" #include "RicSummaryCurveCreator.h" #include "RicSummaryCurveCreatorDialog.h" #include "RimEnsembleCurveFilter.h" #include "RimEnsembleCurveFilterCollection.h" #include "RimRegularLegendConfig.h" #include "RimSummaryCurveFilter.h" #include "RimSummaryPlot.h" #include "RimSummaryPlotCollection.h" #include "RimSummaryCase.h" #include "RimSummaryCaseCollection.h" #include "RimProject.h" #include "RimSummaryCaseMainCollection.h" #include "RiuPlotMainWindow.h" #include "cvfAssert.h" #include "cafSelectionManagerTools.h" #include CAF_CMD_SOURCE_INIT(RicNewSummaryPlotFeature, "RicNewSummaryPlotFeature"); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicNewSummaryPlotFeature::isCommandEnabled() { RimSummaryPlotCollection* sumPlotColl = nullptr; caf::PdmObject* selObj = dynamic_cast(caf::SelectionManager::instance()->selectedItem()); if (selObj) { sumPlotColl = RiaSummaryTools::parentSummaryPlotCollection(selObj); } auto ensembleFilter = dynamic_cast(selObj); auto ensembleFilterColl = dynamic_cast(selObj); auto legendConfig = dynamic_cast(selObj); if (ensembleFilter || ensembleFilterColl || legendConfig) return false; if (sumPlotColl) return true; // Multiple case selections std::vector selectedItems = caf::selectedObjectsByTypeStrict(); for (auto item : selectedItems) { if (!dynamic_cast(item) && !dynamic_cast(item)) return false; } return true; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewSummaryPlotFeature::onActionTriggered(bool isChecked) { RimProject* project = RiaApplication::instance()->project(); CVF_ASSERT(project); std::vector selectedCases = caf::selectedObjectsByType(); std::vector selectedGroups = caf::selectedObjectsByType(); std::vector sourcesToSelect(selectedCases.begin(), selectedCases.end()); if (sourcesToSelect.empty() && selectedGroups.empty()) { const auto allSingleCases = project->firstSummaryCaseMainCollection()->topLevelSummaryCases(); const auto allGroups = project->summaryGroups(); std::vector 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) { if (group->isEnsemble()) { sourcesToSelect.push_back(group); } else { auto groupCases = group->allSummaryCases(); sourcesToSelect.insert(sourcesToSelect.end(), groupCases.begin(), groupCases.end()); } } auto dialog = RicEditSummaryPlotFeature::curveCreatorDialog(); if (!dialog->isVisible()) { dialog->show(); } else { dialog->raise(); } dialog->updateFromDefaultCases(sourcesToSelect); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewSummaryPlotFeature::setupActionLook(QAction* actionToSetup) { actionToSetup->setText("Open Summary Plot Editor"); actionToSetup->setIcon(QIcon(":/SummaryPlotLight16x16.png")); } //================================================================================================== /// //================================================================================================== #include "RiuPlotMainWindowTools.h" #include "RicNewSummaryCurveFeature.h" #include "RimMainPlotCollection.h" #include "RicSummaryPlotFeatureImpl.h" CAF_CMD_SOURCE_INIT(RicNewDefaultSummaryPlotFeature, "RicNewDefaultSummaryPlotFeature"); std::pair> extractSumPlotCollectionOrSelectedSumCasesFromSelection() { std::vector selectedSumCases; RimSummaryPlotCollection* sumPlotColl = nullptr; std::vector selectedItems; caf::SelectionManager::instance()->selectedItems(selectedItems); if ( selectedItems.size() ) { caf::PdmObject* selObj = dynamic_cast(selectedItems[0]); sumPlotColl = RiaSummaryTools::parentSummaryPlotCollection(selObj); } if (!sumPlotColl) { caf::SelectionManager::instance()->objectsByTypeStrict(&selectedSumCases); } return std::make_pair(sumPlotColl, selectedSumCases); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicNewDefaultSummaryPlotFeature::isCommandEnabled() { auto sumPlotSumCasesPair = extractSumPlotCollectionOrSelectedSumCasesFromSelection(); return sumPlotSumCasesPair.first || sumPlotSumCasesPair.second.size(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewDefaultSummaryPlotFeature::onActionTriggered(bool isChecked) { auto sumPlotSumCasesPair = extractSumPlotCollectionOrSelectedSumCasesFromSelection(); std::vector summaryCasesToUse; if (sumPlotSumCasesPair.first) { auto sumCaseVector = RiaApplication::instance()->project()->allSummaryCases(); if (sumCaseVector.size()) { summaryCasesToUse.push_back(sumCaseVector[0]); } } else if (sumPlotSumCasesPair.second.size()) { summaryCasesToUse = sumPlotSumCasesPair.second; } 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(); RiuPlotMainWindowTools::setExpanded(newPlot); RiuPlotMainWindowTools::selectAsCurrentItem(newPlot); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicNewDefaultSummaryPlotFeature::setupActionLook(QAction* actionToSetup) { actionToSetup->setText("New Summary Plot"); actionToSetup->setIcon(QIcon(":/SummaryPlotLight16x16.png")); }