///////////////////////////////////////////////////////////////////////////////// // // 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 "cafPdmChildField.h" #include "cafPdmField.h" #include "cafPdmObject.h" #include "cafPdmPointer.h" #include "cafPdmPtrField.h" #include "RiaDateTimeDefines.h" #include "RiaDefines.h" #include "RifEclipseSummaryAddressQMetaType.h" #include "RimStackablePlotCurve.h" #include "cafAppEnum.h" #include "cafTristate.h" class RifSummaryReaderInterface; class RimSummaryCase; class RimSummaryCurveAutoName; class RimSummaryAddress; class RiaSummaryCurveDefinition; class RimPlotAxisPropertiesInterface; //================================================================================================== /// /// //================================================================================================== class RimSummaryCurve : public RimStackablePlotCurve { CAF_PDM_HEADER_INIT; public: RimSummaryCurve(); ~RimSummaryCurve() override; // Y Axis functions RiaSummaryCurveDefinition curveDefinitionY() const; RimSummaryCase* summaryCaseY() const; RifEclipseSummaryAddress summaryAddressY() const; std::string unitNameY() const; virtual std::vector valuesY() const; void applyCurveDefinitionY( const RiaSummaryCurveDefinition& curveDefinition ); void setSummaryCaseY( RimSummaryCase* sumCase ); void setSummaryAddressYAndApplyInterpolation( const RifEclipseSummaryAddress& address ); void setSummaryAddressY( const RifEclipseSummaryAddress& address ); void setResampling( RiaDefines::DateTimePeriodEnum resampling ); RifEclipseSummaryAddress errorSummaryAddressY() const; std::vector errorValuesY() const; void setLeftOrRightAxisY( RiuPlotAxis plotAxis ); RiuPlotAxis axisY() const; virtual std::vector timeStepsY() const; double yValueAtTimeT( time_t time ) const; void setOverrideCurveDataY( const std::vector& xValues, const std::vector& yValues ); // X Axis functions RiaSummaryCurveDefinition curveDefinitionX() const; RimSummaryCase* summaryCaseX() const; RifEclipseSummaryAddress summaryAddressX() const; std::string unitNameX() const; virtual std::vector valuesX() const; void setSummaryCaseX( RimSummaryCase* sumCase ); void setSummaryAddressX( const RifEclipseSummaryAddress& address ); // Other bool isEnsembleCurve() const; void setIsEnsembleCurve( bool isEnsembleCurve ); void updatePlotAxis(); void applyCurveAutoNameSettings( const RimSummaryCurveAutoName& autoNameSettings ); QString curveExportDescription( const RifEclipseSummaryAddress& address ) const override; void setCurveAppearanceFromCaseType(); void setDefaultCurveAppearance(); void setAsTopZWithinCategory( bool enable ); void setZIndexFromCurveInfo(); RiaDefines::PhaseType phaseType() const override; protected: // RimPlotCurve overrides QString createCurveAutoName() override; void updateZoomInParentPlot() override; void onLoadDataAndUpdate( bool updateParentPlot ) override; void loadAndUpdateDataAndPlot(); void updateLegendsInPlot() override; void defineUiTreeOrdering( caf::PdmUiTreeOrdering& uiTreeOrdering, QString uiConfigName = "" ) override; void initAfterRead() override; double computeCurveZValue() override; virtual std::vector timeStepsX() const; virtual void updateTimeAnnotations(); // Overridden PDM methods void fieldChangedByUi( const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue ) override; QList calculateValueOptions( const caf::PdmFieldHandle* fieldNeedingOptions ) override; void defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering ) override; void defineEditorAttribute( const caf::PdmFieldHandle* field, QString uiConfigName, caf::PdmUiEditorAttribute* attribute ) override; private: RifSummaryReaderInterface* valuesSummaryReaderX() const; RifSummaryReaderInterface* valuesSummaryReaderY() const; void calculateCurveInterpolationFromAddress(); static void appendOptionItemsForSummaryAddresses( QList* options, RimSummaryCase* summaryCase ); private: // Y values caf::PdmPtrField m_yValuesSummaryCase; caf::PdmChildField m_yValuesSummaryAddress; caf::PdmField m_yValuesSummaryAddressUiField; caf::PdmField m_yPushButtonSelectSummaryAddress; caf::PdmField m_resampling; // X values caf::PdmPtrField m_xValuesSummaryCase; caf::PdmChildField m_xValuesSummaryAddress; caf::PdmField m_xValuesSummaryAddressUiField; caf::PdmField m_xPushButtonSelectSummaryAddress; caf::PdmField m_isEnsembleCurve; caf::PdmChildField m_curveNameConfig; caf::PdmField> m_plotAxis_OBSOLETE; caf::PdmPtrField m_plotAxisProperties; caf::PdmField m_isTopZWithinCategory; };