mirror of
https://github.com/OPM/ResInsight.git
synced 2025-01-07 14:43:10 -06:00
127 lines
5.1 KiB
C++
127 lines
5.1 KiB
C++
/////////////////////////////////////////////////////////////////////////////////
|
|
//
|
|
// 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 <http://www.gnu.org/licenses/gpl.html>
|
|
// for more details.
|
|
//
|
|
/////////////////////////////////////////////////////////////////////////////////
|
|
|
|
#pragma once
|
|
|
|
#include "RimWellPath.h"
|
|
|
|
#include "cafPdmField.h"
|
|
#include "cafPdmObject.h"
|
|
#include "cafPdmPtrField.h"
|
|
#include "cafPdmUiOrdering.h"
|
|
#include "cafTristate.h"
|
|
|
|
class RimCase;
|
|
class RimWellLogCurve;
|
|
class RimWellLogPlot;
|
|
class RimWellLogTrack;
|
|
class RimWellPath;
|
|
|
|
//==================================================================================================
|
|
///
|
|
//==================================================================================================
|
|
class RimWellLogCurveCommonDataSource : public caf::PdmObject
|
|
{
|
|
CAF_PDM_HEADER_INIT;
|
|
|
|
public:
|
|
class DoubleComparator
|
|
{
|
|
public:
|
|
DoubleComparator( double eps = 1.0e-6 );
|
|
bool operator()( const double& lhs, const double& rhs ) const;
|
|
|
|
private:
|
|
double m_eps;
|
|
};
|
|
|
|
RimWellLogCurveCommonDataSource();
|
|
|
|
void setCaseType( RiaDefines::CaseType caseType );
|
|
|
|
RimCase* caseToApply() const;
|
|
void setCaseToApply( RimCase* val );
|
|
int trajectoryTypeToApply() const;
|
|
void setTrajectoryTypeToApply( int val );
|
|
RimWellPath* wellPathToApply() const;
|
|
void setWellPathToApply( RimWellPath* val );
|
|
int branchIndexToApply() const;
|
|
void setBranchIndexToApply( int val );
|
|
caf::Tristate branchDetectionToApply() const;
|
|
void setBranchDetectionToApply( caf::Tristate::State val );
|
|
caf::Tristate wbsSmoothingToApply() const;
|
|
void setWbsSmoothingToApply( caf::Tristate::State val );
|
|
double wbsSmoothingThreshold() const;
|
|
void setWbsSmoothingThreshold( double smoothingThreshold );
|
|
|
|
QString simWellNameToApply() const;
|
|
void setSimWellNameToApply( const QString& val );
|
|
int timeStepToApply() const;
|
|
void setTimeStepToApply( int val );
|
|
|
|
void resetDefaultOptions();
|
|
void updateDefaultOptions( const std::vector<RimWellLogCurve*>& curves, const std::vector<RimWellLogTrack*>& tracks );
|
|
void updateDefaultOptions();
|
|
void updateCurvesAndTracks( const std::vector<RimWellLogCurve*>& curves, const std::vector<RimWellLogTrack*>& tracks );
|
|
void updateCurvesAndTracks();
|
|
void applyPrevCase();
|
|
void applyNextCase();
|
|
|
|
void applyPrevWell();
|
|
void applyNextWell();
|
|
|
|
void applyPrevTimeStep();
|
|
void applyNextTimeStep();
|
|
std::vector<caf::PdmFieldHandle*> fieldsToShowInToolbar();
|
|
|
|
static QString smoothingUiOrderinglabel();
|
|
|
|
protected:
|
|
void fieldChangedByUi( const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue ) override;
|
|
QList<caf::PdmOptionItemInfo> calculateValueOptions( const caf::PdmFieldHandle* fieldNeedingOptions,
|
|
bool* useOptionsOnly ) override;
|
|
void defineUiOrdering( QString uiConfigName, caf::PdmUiOrdering& uiOrdering ) override;
|
|
void defineEditorAttribute( const caf::PdmFieldHandle* field,
|
|
QString uiConfigName,
|
|
caf::PdmUiEditorAttribute* attribute ) override;
|
|
void modifyCurrentIndex( caf::PdmValueField* field, int indexOffset );
|
|
|
|
private:
|
|
RiaDefines::CaseType m_caseType;
|
|
|
|
caf::PdmPtrField<RimCase*> m_case;
|
|
caf::PdmField<int> m_trajectoryType;
|
|
caf::PdmPtrField<RimWellPath*> m_wellPath;
|
|
caf::PdmField<QString> m_simWellName;
|
|
caf::PdmField<int> m_branchIndex;
|
|
caf::PdmField<caf::Tristate> m_branchDetection;
|
|
caf::PdmField<int> m_timeStep;
|
|
caf::PdmField<caf::Tristate> m_wbsSmoothing;
|
|
caf::PdmField<double> m_wbsSmoothingThreshold;
|
|
|
|
std::set<RimCase*> m_uniqueCases;
|
|
std::set<int> m_uniqueTrajectoryTypes;
|
|
std::set<RimWellPath*> m_uniqueWellPaths;
|
|
std::set<QString> m_uniqueWellNames;
|
|
std::set<int> m_uniqueTimeSteps;
|
|
std::set<bool> m_uniqueBranchDetection;
|
|
std::set<int> m_uniqueBranchIndices;
|
|
std::set<bool> m_uniqueWbsSmoothing;
|
|
std::set<double, DoubleComparator> m_uniqueWbsSmoothingThreshold;
|
|
};
|