///////////////////////////////////////////////////////////////////////////////// // // 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. // ///////////////////////////////////////////////////////////////////////////////// #pragma once #include "cafPdmField.h" #include "cafPdmObject.h" #include "cafPdmPointer.h" #include "cafPdmPtrField.h" #include "cafPdmChildField.h" #include "RiaDefines.h" #include "RifEclipseSummaryAddressQMetaType.h" #include "RimPlotCurve.h" #include "cafAppEnum.h" class RifSummaryReaderInterface; class RimSummaryCase; class RimSummaryFilter; class RiuLineSegmentQwtPlotCurve; class RimSummaryCurveAutoName; class RimSummaryAddress; //================================================================================================== /// /// //================================================================================================== class RimSummaryCurve : public RimPlotCurve { CAF_PDM_HEADER_INIT; public: RimSummaryCurve(); virtual ~RimSummaryCurve(); void setSummaryCase(RimSummaryCase* sumCase); RimSummaryCase* summaryCase() const; RifEclipseSummaryAddress summaryAddress(); void setSummaryAddress(const RifEclipseSummaryAddress& address); std::string unitName(); std::vector yValues() const; std::vector xValues() const; const std::vector& timeSteps() const; void setYAxis(RiaDefines::PlotAxis plotAxis); RiaDefines::PlotAxis yAxis() const; void updateQwtPlotAxis(); void applyCurveAutoNameSettings(const RimSummaryCurveAutoName& autoNameSettings); protected: // RimPlotCurve overrides virtual QString createCurveAutoName() override; virtual void updateZoomInParentPlot() override; virtual void onLoadDataAndUpdate(bool updateParentPlot) override; private: RifSummaryReaderInterface* yValuesSummaryReader() const; void calculateCurveInterpolationFromAddress(); // Overridden PDM methods virtual void fieldChangedByUi(const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue); virtual QList calculateValueOptions(const caf::PdmFieldHandle* fieldNeedingOptions, bool* useOptionsOnly); virtual void defineUiOrdering(QString uiConfigName, caf::PdmUiOrdering& uiOrdering) override; static void appendOptionItemsForSummaryAddresses(QList* options, RimSummaryCase* summaryCase, RimSummaryFilter* summaryFilter); bool isCrossPlotCurve() const; private: // Y values caf::PdmPtrField m_yValuesSummaryCase; caf::PdmChildField m_yValuesCurveVariable; caf::PdmField m_yValuesSelectedVariableDisplayField; caf::PdmChildField m_yValuesSummaryFilter; caf::PdmField m_yValuesUiFilterResultSelection; // X values caf::PdmPtrField m_xValuesSummaryCase; caf::PdmChildField m_xValuesCurveVariable; caf::PdmField m_xValuesSelectedVariableDisplayField; caf::PdmChildField m_xValuesSummaryFilter; caf::PdmField m_xValuesUiFilterResultSelection; caf::PdmChildField m_curveNameConfig; caf::PdmField> m_plotAxis; };