///////////////////////////////////////////////////////////////////////////////// // // 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. // ///////////////////////////////////////////////////////////////////////////////// #pragma once #include "RimSummaryDataSourceStepping.h" #include "cafPdmField.h" #include "cafPdmObject.h" #include "cafPdmProxyValueField.h" #include "cafPdmPtrField.h" #include #include #include class RimSummaryCase; class RimSummaryCurve; class RifSummaryReaderInterface; class RimSummaryCaseCollection; class RifEclipseSummaryAddress; class RiaSummaryAddressAnalyzer; class RimSummaryPlot; class RimPlot; //================================================================================================== /// //================================================================================================== class RimSummaryPlotSourceStepping : public caf::PdmObject { CAF_PDM_HEADER_INIT; public: RimSummaryPlotSourceStepping(); void setSourceSteppingType( RimSummaryDataSourceStepping::Axis sourceSteppingType ); void setSourceSteppingObject( caf::PdmObject* sourceObject ); void applyNextStep(); void applyPrevStep(); std::vector fieldsToShowInToolbar(); RifEclipseSummaryAddress stepAddress( RifEclipseSummaryAddress addr, int direction ); RimSummaryCase* stepCase( int direction ); RimSummaryCaseCollection* stepEnsemble( int direction ); void syncWithStepper( RimSummaryPlotSourceStepping* other ); void setStep( QString stepIdentifier ); RimSummaryDataSourceStepping::SourceSteppingDimension stepDimension() const; void setStepDimension( RimSummaryDataSourceStepping::SourceSteppingDimension dimension ); void updateStepIndex( int direction ); std::vector plotsMatchingStepSettings( std::vector plots ); private: void defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering ) override; QList calculateValueOptions( const caf::PdmFieldHandle* fieldNeedingOptions ) override; void fieldChangedByUi( const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue ) override; void defineEditorAttribute( const caf::PdmFieldHandle* field, QString uiConfigName, caf::PdmUiEditorAttribute* attribute ) override; private: caf::PdmValueField* fieldToModify(); std::set adressesForSourceStepping() const; std::set addressesForCurvesInPlot() const; std::set summaryCasesCurveCollection() const; std::set ensembleCollection() const; std::vector activeFieldsForDataSourceStepping(); std::vector toolbarFieldsForDataSourceStepping(); bool isXAxisStepping() const; bool isYAxisStepping() const; void modifyCurrentIndex( caf::PdmValueField* valueField, int indexOffset, bool notifyChange = true ); std::vector summaryCasesForSourceStepping(); RimSummaryDataSourceStepping* dataSourceSteppingObject() const; std::map optionsForQuantity( std::set addresses ); std::map optionsForQuantity( RiaSummaryAddressAnalyzer* analyzser ); void updateVectorNameInCurves( std::vector& curves, const QVariant& oldValue, const QVariant& newValue ); private: caf::PdmPointer m_objectForSourceStepping; caf::PdmField m_indexLabel; caf::PdmField> m_stepDimension; caf::PdmPtrField m_summaryCase; caf::PdmPtrField m_ensemble; caf::PdmField m_wellName; caf::PdmField m_groupName; caf::PdmField m_region; caf::PdmField m_vectorName; caf::PdmField m_placeholderForLabel; caf::PdmField m_cellBlock; caf::PdmField m_segment; caf::PdmField m_completion; caf::PdmField m_aquifer; caf::PdmField m_includeEnsembleCasesForCaseStepping; caf::PdmField m_autoUpdateAppearance; RimSummaryDataSourceStepping::Axis m_sourceSteppingType; std::vector m_cachedIdentifiers; };