///////////////////////////////////////////////////////////////////////////////// // // Copyright (C) 2019- Equinor 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. // ///////////////////////////////////////////////////////////////////////////////// #pragma once #include "RigGridCrossPlotCurveGrouping.h" #include "RigEclipseCrossPlotDataExtractor.h" #include "RimCheckableNamedObject.h" #include "RimNameConfig.h" #include "cafAppEnum.h" #include "cafPdmChildArrayField.h" #include "cafPdmChildField.h" #include "cafPdmField.h" #include "cafPdmObject.h" #include "cafPdmPtrField.h" #include #include #include class RifEclipseDataTableFormatter; class RimCase; class RimGridCrossPlotCurve; class RimGridView; class RimEclipseCase; class RimEclipseCellColors; class RimEclipseResultDefinition; class RimRegularLegendConfig; class QwtPlot; class QwtPlotCurve; class QString; class RimGridCrossPlotCurveSetNameConfig : public RimNameConfig { CAF_PDM_HEADER_INIT; public: RimGridCrossPlotCurveSetNameConfig(RimNameConfigHolderInterface* parent = nullptr); caf::PdmField addCaseName; caf::PdmField addAxisVariables; caf::PdmField addTimestep; caf::PdmField addGrouping; protected: void defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering) override; }; //================================================================================================== /// /// //================================================================================================== class RimGridCrossPlotCurveSet : public RimCheckableNamedObject, public RimNameConfigHolderInterface { CAF_PDM_HEADER_INIT; public: typedef caf::AppEnum CurveGroupingEnum; enum NameComponents { GCP_CASE_NAME, GCP_AXIS_VARIABLES, GCP_TIME_STEP, GCP_GROUP_NAME }; public: RimGridCrossPlotCurveSet(); ~RimGridCrossPlotCurveSet() = default; void setCellFilterView(RimGridView* cellFilterView); void loadDataAndUpdate(bool updateParentPlot); void setParentQwtPlotNoReplot(QwtPlot* parent); QString xAxisName() const; QString yAxisName() const; int indexInPlot() const; QString createAutoName() const override; QString groupTitle() const; QString groupParameter() const; void detachAllCurves(); void cellFilterViewUpdated(); RimRegularLegendConfig* legendConfig() const; std::vector< RimGridCrossPlotCurve*> curves() const; QString caseNameString() const; QString axisVariableString() const; QString timeStepString() const; std::vector groupStrings() const; std::map nameComponents() const; void updateCurveNames(size_t curveSetIndex, size_t curveSetCount); void updateLegend(); bool groupingByCategoryResult() const; bool groupingEnabled() const; void swapAxisProperties(bool updatePlot); void exportFormattedData(RifEclipseDataTableFormatter& formatter) const; bool isXAxisLogarithmic() const; bool isYAxisLogarithmic() const; protected: void initAfterRead() override; void onLoadDataAndUpdate(bool updateParentPlot); void createCurves(const RigEclipseCrossPlotResult& result); QString createGroupName(size_t curveIndex) const; std::map calculateCellVisibility(RimEclipseCase* eclipseCase) const; void defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering) override; void fieldChangedByUi(const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue) override; QList calculateValueOptions(const caf::PdmFieldHandle* fieldNeedingOptions, bool* useOptionsOnly) override; void triggerPlotNameUpdateAndReplot(); void updateDataSetName(); void performAutoNameUpdate() override; void setDefaults(); void defineEditorAttribute(const caf::PdmFieldHandle* field, QString uiConfigName, caf::PdmUiEditorAttribute* attribute) override; void defineUiTreeOrdering(caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName = "") override; bool hasMultipleTimeSteps() const; void filterInvalidCurveValues(RigEclipseCrossPlotResult* result); private: caf::PdmPtrField m_case; caf::PdmField m_timeStep; caf::PdmPtrField m_cellFilterView; caf::PdmField m_grouping; caf::PdmChildField m_xAxisProperty; caf::PdmChildField m_yAxisProperty; caf::PdmChildField m_groupingProperty; caf::PdmChildField m_nameConfig; caf::PdmChildArrayField m_crossPlotCurves; std::map m_groupedResults; };