///////////////////////////////////////////////////////////////////////////////// // // 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 // for more details. // ///////////////////////////////////////////////////////////////////////////////// #include "RicPasteAsciiDataToSummaryPlotFeature.h" #include "OperationsUsingObjReferences/RicPasteFeatureImpl.h" #include "RicNewSummaryPlotFeature.h" #include "RicPasteAsciiDataToSummaryPlotFeatureUi.h" #include "RiaLogging.h" #include "RimSummaryPlot.h" #include "RimSummaryPlotCollection.h" #include "RimAsciiDataCurve.h" #include "RimSummaryCurveAppearanceCalculator.h" #include "RifColumnBasedAsciiParser.h" #include "cafPdmDefaultObjectFactory.h" #include "cafPdmDocument.h" #include "cafPdmObjectGroup.h" #include "cafSelectionManager.h" #include "cafPdmUiPropertyViewDialog.h" #include "cafPdmSettings.h" #include "cvfAssert.h" #include "cvfColor3.h" #include #include #include #include CAF_CMD_SOURCE_INIT(RicPasteAsciiDataToSummaryPlotFeature, "RicPasteAsciiDataToSummaryPlotFeature"); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicPasteAsciiDataToSummaryPlotFeature::isCommandEnabled() { caf::PdmObjectHandle* destinationObject = dynamic_cast(caf::SelectionManager::instance()->selectedItem()); RimSummaryPlot* summaryPlot = nullptr; destinationObject->firstAncestorOrThisOfType(summaryPlot); if (!summaryPlot) { RimSummaryPlotCollection* summaryPlotCollection = nullptr; destinationObject->firstAncestorOrThisOfType(summaryPlotCollection); if (!summaryPlotCollection) { return false; } } return hasPastedText(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicPasteAsciiDataToSummaryPlotFeature::onActionTriggered(bool isChecked) { caf::PdmObjectHandle* destinationObject = dynamic_cast(caf::SelectionManager::instance()->selectedItem()); RimSummaryPlot* summaryPlot = nullptr; destinationObject->firstAncestorOrThisOfType(summaryPlot); RicPasteAsciiDataToSummaryPlotFeatureUi pasteOptions; if (!summaryPlot) pasteOptions.createNewPlot(); caf::PdmSettings::readFieldsFromApplicationStore(&pasteOptions); caf::PdmUiPropertyViewDialog propertyDialog(NULL, &pasteOptions, "Set Paste Options", ""); if (propertyDialog.exec() != QDialog::Accepted) return; if (!summaryPlot) { RimSummaryPlotCollection* summaryPlotCollection = nullptr; destinationObject->firstAncestorOrThisOfType(summaryPlotCollection); if (!summaryPlotCollection) { return; } summaryPlot = createSummaryPlotAndAddToPlotCollection(summaryPlotCollection); } caf::PdmSettings::writeFieldsToApplicationStore(&pasteOptions); QString text = getPastedData(); std::vector curves = parseCurves(text, pasteOptions); for (RimAsciiDataCurve* curve : curves) { summaryPlot->addAsciiDataCruve(curve); } summaryPlot->updateConnectedEditors(); summaryPlot->loadDataAndUpdate(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RicPasteAsciiDataToSummaryPlotFeature::setupActionLook(QAction* actionToSetup) { actionToSetup->setText("Paste Excel Data to Summary Curve"); RicPasteFeatureImpl::setIconAndShortcuts(actionToSetup); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- QString RicPasteAsciiDataToSummaryPlotFeature::getPastedData() { if (hasPastedText()) { QClipboard* clipboard = QApplication::clipboard(); return clipboard->text(); } return QString(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RicPasteAsciiDataToSummaryPlotFeature::hasPastedText() { QClipboard* clipboard = QApplication::clipboard(); const QMimeData* mimeData = clipboard->mimeData(); if (mimeData->hasText() && mimeData->text().size() > 12) { QString text = mimeData->text(); if (text.size() > 12) return true; } return false; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::vector RicPasteAsciiDataToSummaryPlotFeature::parseCurves(QString& data, const RicPasteAsciiDataToSummaryPlotFeatureUi& settings) { std::vector curves; RifColumnBasedAsciiParser parser = RifColumnBasedAsciiParser(data, settings.dateFormat(), settings.decimalLocale(), settings.cellSeparator()); if (parser.headers().empty()) { return curves; } std::map< CurveType, std::vector > curveToTypeMap; QString curvePrefix = settings.curvePrefix(); for (size_t i = 0; i < parser.headers().size(); i++) { RimAsciiDataCurve* curve = new RimAsciiDataCurve(); curve->setTimeSteps(parser.timeSteps()); curve->setValues(parser.columnValues(i)); if (curvePrefix.isEmpty()) { curve->setTitle(parser.headers()[i]); } else { curve->setTitle(QString("%1: %2").arg(curvePrefix).arg(parser.headers()[i])); } // Appearance curve->setSymbol(settings.pointSymbol()); curve->setLineStyle(settings.lineStyle()); curve->setSymbolSkipDinstance(settings.symbolSkipDinstance()); curveToTypeMap[guessCurveType(parser.headers()[i])].push_back(curve); curves.push_back(curve); } for (auto& it : curveToTypeMap) { for (int i = 0; i < static_cast(it.second.size()); ++i) { cvf::Color3f color; switch (it.first) { case CURVE_GAS: color = RimSummaryCurveAppearanceCalculator::cycledGreenColor(i); break; case CURVE_OIL: color = RimSummaryCurveAppearanceCalculator::cycledRedColor(i); break; case CURVE_WAT: color = RimSummaryCurveAppearanceCalculator::cycledBlueColor(i); break; default: color = RimSummaryCurveAppearanceCalculator::cycledNoneRGBBrColor(i); break; } it.second[i]->setColor(color); } } return curves; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RicPasteAsciiDataToSummaryPlotFeature::CurveType RicPasteAsciiDataToSummaryPlotFeature::guessCurveType(const QString& curveName) { if (curveName.contains("SW") || curveName.contains("water", Qt::CaseInsensitive)) { return CURVE_WAT; } else if (curveName.contains("oil", Qt::CaseInsensitive)) { return CURVE_OIL; } else if (curveName.contains("gas", Qt::CaseInsensitive)) { return CURVE_GAS; } return CURVE_UNKNOWN; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimSummaryPlot* RicPasteAsciiDataToSummaryPlotFeature::createSummaryPlotAndAddToPlotCollection(RimSummaryPlotCollection *plotCollection) { auto summaryPlot = new RimSummaryPlot(); summaryPlot->setDescription(QString("Summary Plot %1").arg(plotCollection->summaryPlots.size() + 1)); plotCollection->summaryPlots().push_back(summaryPlot); plotCollection->updateConnectedEditors(); summaryPlot->loadDataAndUpdate(); return summaryPlot; }