///////////////////////////////////////////////////////////////////////////////// // // 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(); // Y Axis functions void setSummaryCaseY(RimSummaryCase* sumCase); RimSummaryCase* summaryCaseY() const; void setSummaryAddressY(const RifEclipseSummaryAddress& address); RifEclipseSummaryAddress summaryAddressY() const; std::string unitNameY() const; std::vector valuesY() const; void setLeftOrRightAxisY(RiaDefines::PlotAxis plotAxis); RiaDefines::PlotAxis axisY() const; const std::vector& timeStepsY() const; // X Axis functions void setSummaryCaseX(RimSummaryCase* sumCase); RimSummaryCase* summaryCaseX() const; RifEclipseSummaryAddress summaryAddressX() const; void setSummaryAddressX(const RifEclipseSummaryAddress& address); std::string unitNameX() const; std::vector valuesX() const; // Other void updateQwtPlotAxis(); void applyCurveAutoNameSettings(const RimSummaryCurveAutoName& autoNameSettings); virtual QString curveExportDescription() const override; protected: // RimPlotCurve overrides virtual QString createCurveAutoName() override; virtual void updateZoomInParentPlot() override; virtual void onLoadDataAndUpdate(bool updateParentPlot) override; private: RifSummaryReaderInterface* valuesSummaryReaderX() const; RifSummaryReaderInterface* valuesSummaryReaderY() const; const std::vector& timeStepsX() 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; virtual void defineEditorAttribute(const caf::PdmFieldHandle* field, QString uiConfigName, caf::PdmUiEditorAttribute* attribute) override; static void appendOptionItemsForSummaryAddresses(QList* options, RimSummaryCase* summaryCase, RimSummaryFilter* summaryFilter); private: // Y values caf::PdmPtrField m_yValuesSummaryCase; caf::PdmChildField m_yValuesCurveVariable; caf::PdmField m_yValuesSelectedVariableDisplayField; caf::PdmChildField m_yValuesSummaryFilter; caf::PdmField m_yValuesUiFilterResultSelection; caf::PdmField m_yPushButtonSelectSummaryAddress; // X values caf::PdmPtrField m_xValuesSummaryCase; caf::PdmChildField m_xValuesCurveVariable; caf::PdmField m_xValuesSelectedVariableDisplayField; caf::PdmChildField m_xValuesSummaryFilter; caf::PdmField m_xValuesUiFilterResultSelection; caf::PdmField m_xPushButtonSelectSummaryAddress; caf::PdmChildField m_curveNameConfig; caf::PdmField> m_plotAxis; };