///////////////////////////////////////////////////////////////////////////////// // // 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. // ///////////////////////////////////////////////////////////////////////////////// #include "RimPlotCurve.h" #include "RiaColorTools.h" #include "RiaCurveDataTools.h" #include "RiaGuiApplication.h" #include "RiaPreferences.h" #include "RimEnsembleCurveSet.h" #include "RimEnsembleCurveSetCollection.h" #include "RimNameConfig.h" #include "RimProject.h" #include "RimSummaryCrossPlot.h" #include "RimSummaryCurve.h" #include "RimSummaryCurveCollection.h" #include "RimSummaryPlot.h" #include "RiuPlotCurve.h" #include "RiuPlotCurveSymbol.h" #include "RiuPlotMainWindowTools.h" #include "RiuPlotWidget.h" #include "cafAssert.h" #include "cafPdmUiComboBoxEditor.h" #include // NB! Special macro for pure virtual class CAF_PDM_XML_ABSTRACT_SOURCE_INIT( RimPlotCurve, "PlotCurve" ); //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimPlotCurve::RimPlotCurve() : appearanceChanged( this ) , visibilityChanged( this ) , dataChanged( this ) , nameChanged( this ) { CAF_PDM_InitObject( "Curve", ":/WellLogCurve16x16.png" ); CAF_PDM_InitField( &m_showCurve, "Show", true, "Show curve" ); m_showCurve.uiCapability()->setUiHidden( true ); CAF_PDM_InitFieldNoDefault( &m_curveName, "CurveName", "Curve Name" ); CAF_PDM_InitFieldNoDefault( &m_customCurveName, "CurveDescription", "Custom Name" ); m_customCurveName.uiCapability()->setUiHidden( true ); CAF_PDM_InitFieldNoDefault( &m_legendEntryText, "LegendDescription", "Legend Name" ); m_legendEntryText.uiCapability()->setUiHidden( true ); CAF_PDM_InitField( &m_isUsingAutoName, "AutoName", true, "Auto Name" ); CAF_PDM_InitField( &m_showLegend, "ShowLegend", true, "Contribute To Legend" ); CAF_PDM_InitField( &m_showErrorBars, "ShowErrorBars", true, "Show Error Bars" ); // Obsolete field: appearance configuration is moved to RimPlotCurveAppearance CAF_PDM_InitField( &m_curveColor_OBSOLETE, "Color", RiaColorTools::textColor3f(), "Color" ); m_curveColor_OBSOLETE.xmlCapability()->setIOWritable( false ); CAF_PDM_InitField( &m_fillColor_OBSOLETE, "FillColor", cvf::Color3f( -1.0, -1.0, -1.0 ), "Fill Color" ); m_fillColor_OBSOLETE.xmlCapability()->setIOWritable( false ); CAF_PDM_InitField( &m_curveThickness_OBSOLETE, "Thickness", 1, "Line Thickness" ); m_curveThickness_OBSOLETE.xmlCapability()->setIOWritable( false ); CAF_PDM_InitFieldNoDefault( &m_curveInterpolation_OBSOLETE, "CurveInterpolation", "Interpolation" ); m_curveInterpolation_OBSOLETE.xmlCapability()->setIOWritable( false ); CAF_PDM_InitFieldNoDefault( &m_lineStyle_OBSOLETE, "LineStyle", "Line Style" ); m_lineStyle_OBSOLETE.xmlCapability()->setIOWritable( false ); CAF_PDM_InitFieldNoDefault( &m_fillStyle_OBSOLETE, "FillStyle", "Area Fill Style" ); m_fillStyle_OBSOLETE.xmlCapability()->setIOWritable( false ); CAF_PDM_InitFieldNoDefault( &m_pointSymbol_OBSOLETE, "PointSymbol", "Symbol" ); m_pointSymbol_OBSOLETE.xmlCapability()->setIOWritable( false ); CAF_PDM_InitField( &m_symbolEdgeColor_OBSOLETE, "SymbolEdgeColor", RiaColorTools::textColor3f(), "Symbol Edge Color" ); m_symbolEdgeColor_OBSOLETE.xmlCapability()->setIOWritable( false ); CAF_PDM_InitField( &m_symbolSkipPixelDistance_OBSOLETE, "SymbolSkipPxDist", 0.0f, "Symbol Skip Distance", "", "Minimum pixel distance between symbols", "" ); m_symbolSkipPixelDistance_OBSOLETE.xmlCapability()->setIOWritable( false ); CAF_PDM_InitFieldNoDefault( &m_symbolLabel_OBSOLETE, "SymbolLabel", "Symbol Label" ); m_symbolLabel_OBSOLETE.xmlCapability()->setIOWritable( false ); CAF_PDM_InitField( &m_symbolSize_OBSOLETE, "SymbolSize", 6, "Symbol Size" ); m_symbolSize_OBSOLETE.xmlCapability()->setIOWritable( false ); CAF_PDM_InitFieldNoDefault( &m_symbolLabelPosition_OBSOLETE, "SymbolLabelPosition", "Symbol Label Position" ); m_symbolLabelPosition_OBSOLETE.xmlCapability()->setIOWritable( false ); CAF_PDM_InitFieldNoDefault( &m_curveAppearance, "PlotCurveAppearance", "PlotCurveAppearance" ); m_curveAppearance = new RimPlotCurveAppearance; m_curveAppearance.uiCapability()->setUiTreeHidden( true ); m_curveAppearance.uiCapability()->setUiTreeChildrenHidden( true ); m_curveAppearance->appearanceChanged.connect( this, &RimPlotCurve::onCurveAppearanceChanged ); m_curveAppearance->fillColorChanged.connect( this, &RimPlotCurve::onFillColorChanged ); m_plotCurve = nullptr; m_parentPlot = nullptr; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RimPlotCurve::~RimPlotCurve() { if ( m_plotCurve ) { m_plotCurve->detach(); delete m_plotCurve; m_plotCurve = nullptr; } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::fieldChangedByUi( const caf::PdmFieldHandle* changedField, const QVariant& oldValue, const QVariant& newValue ) { if ( changedField == &m_showCurve ) { this->updateCurveVisibility(); if ( m_showCurve() ) loadDataAndUpdate( false ); visibilityChanged.send( m_showCurve() ); } else if ( changedField == &m_curveName ) { m_customCurveName = m_curveName; updateCurveNameAndUpdatePlotLegendAndTitle(); } else if ( changedField == &m_isUsingAutoName ) { if ( !m_isUsingAutoName ) { m_customCurveName = createCurveAutoName(); } updateCurveNameAndUpdatePlotLegendAndTitle(); nameChanged.send( curveName() ); } else if ( changedField == &m_showLegend ) { updateLegendEntryVisibilityAndPlotLegend(); } else if ( changedField == &m_showErrorBars ) { updateCurveAppearance(); } RiuPlotMainWindowTools::refreshToolbars(); replotParentPlot(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- caf::PdmFieldHandle* RimPlotCurve::objectToggleField() { return &m_showCurve; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setCustomName( const QString& customName ) { m_isUsingAutoName = false; m_customCurveName = customName; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- QString RimPlotCurve::legendEntryText() const { if ( !m_legendEntryText().isEmpty() ) { return m_legendEntryText; } return m_customCurveName; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setLegendEntryText( const QString& legendEntryText ) { m_legendEntryText = legendEntryText; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setErrorBarsVisible( bool isVisible ) { m_showErrorBars = isVisible; updateCurveAppearance(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::initAfterRead() { if ( RimProject::current()->isProjectFileVersionEqualOrOlderThan( "2021.06.0" ) ) { updateCurveAppearanceForFilesOlderThan_2021_06(); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateCurvePresentation( bool updatePlotLegendAndTitle ) { this->updateCurveVisibility(); if ( updatePlotLegendAndTitle ) { this->updateCurveNameAndUpdatePlotLegendAndTitle(); this->updatePlotTitle(); } else { this->updateCurveNameNoLegendUpdate(); } updateCurveAppearance(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- caf::PdmFieldHandle* RimPlotCurve::userDescriptionField() { return &m_curveName; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setColor( const cvf::Color3f& color ) { m_curveAppearance->setColor( color ); m_curveAppearance->setFillColor( color ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- cvf::Color3f RimPlotCurve::color() const { return m_curveAppearance->color(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RimPlotCurve::isCurveVisible() const { return m_showCurve; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setCurveVisibility( bool visible ) { m_showCurve = visible; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateCurveName() { if ( m_isUsingAutoName ) { m_curveName = this->createCurveAutoName(); } else { m_curveName = m_customCurveName; } if ( !m_legendEntryText().isEmpty() ) { setTitle( m_legendEntryText ); } else { setTitle( m_curveName ); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateCurveNameAndUpdatePlotLegendAndTitle() { updateCurveName(); updateLegendEntryVisibilityAndPlotLegend(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateCurveNameNoLegendUpdate() { updateCurveName(); updateLegendEntryVisibilityNoPlotUpdate(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateOptionSensitivity() { m_curveName.uiCapability()->setUiReadOnly( m_isUsingAutoName ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updatePlotTitle() { RimNameConfigHolderInterface* nameConfigHolder = nullptr; this->firstAncestorOrThisOfType( nameConfigHolder ); if ( nameConfigHolder ) { nameConfigHolder->updateAutoName(); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::appearanceUiOrdering( caf::PdmUiOrdering& uiOrdering ) { QString configName = "AppearanceOrdering"; m_curveAppearance->uiOrdering( configName, uiOrdering ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::curveNameUiOrdering( caf::PdmUiOrdering& uiOrdering ) { uiOrdering.add( &m_isUsingAutoName ); uiOrdering.add( &m_curveName ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateCurveAppearanceForFilesOlderThan_2021_06() { // Forward values of obsolete fields to appearance object m_curveAppearance->setSymbolSize( m_symbolSize_OBSOLETE ); m_curveAppearance->setSymbolLabel( m_symbolLabel_OBSOLETE ); m_curveAppearance->setColor( m_curveColor_OBSOLETE ); m_curveAppearance->setLineThickness( m_curveThickness_OBSOLETE ); m_curveAppearance->setSymbolSkipDistance( m_symbolSkipPixelDistance_OBSOLETE ); m_curveAppearance->setSymbol( m_pointSymbol_OBSOLETE() ); m_curveAppearance->setLineStyle( m_lineStyle_OBSOLETE() ); m_curveAppearance->setFillStyle( m_fillStyle_OBSOLETE() ); m_curveAppearance->setFillColor( m_fillColor_OBSOLETE ); m_curveAppearance->setInterpolation( m_curveInterpolation_OBSOLETE() ); m_curveAppearance->setSymbolLabelPosition( m_symbolLabelPosition_OBSOLETE() ); m_curveAppearance->setSymbolEdgeColor( m_symbolEdgeColor_OBSOLETE ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RimPlotCurve::canCurveBeAttached() const { if ( !hasParentPlot() ) { return false; } if ( !m_showCurve() ) { return false; } bool isVisibleInPossibleParent = true; { RimSummaryCurveCollection* summaryCurveCollection = nullptr; this->firstAncestorOrThisOfType( summaryCurveCollection ); if ( summaryCurveCollection ) isVisibleInPossibleParent = summaryCurveCollection->isCurvesVisible(); RimEnsembleCurveSet* ensembleCurveSet = nullptr; firstAncestorOrThisOfType( ensembleCurveSet ); if ( ensembleCurveSet ) isVisibleInPossibleParent = ensembleCurveSet->isCurvesVisible(); } return isVisibleInPossibleParent; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::checkAndApplyDefaultFillColor() { // if ( m_curveAppearance->fillColor().isValid() ) // { // m_curveAppearance->fillColor() = m_curveAppearance->color(); // } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RimPlotCurve::isCrossPlotCurve() const { RimSummaryCrossPlot* crossPlot = nullptr; this->firstAncestorOrThisOfType( crossPlot ); if ( crossPlot ) return true; return false; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::loadDataAndUpdate( bool updateParentPlot ) { this->onLoadDataAndUpdate( updateParentPlot ); if ( updateParentPlot ) { dataChanged.send(); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setLineStyle( RiuQwtPlotCurveDefines::LineStyleEnum lineStyle ) { m_curveAppearance->setLineStyle( lineStyle ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setSymbol( RiuPlotCurveSymbol::PointSymbolEnum symbolStyle ) { m_curveAppearance->setSymbol( symbolStyle ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setInterpolation( RiuQwtPlotCurveDefines::CurveInterpolationEnum curveInterpolation ) { m_curveAppearance->setInterpolation( curveInterpolation ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- RiuPlotCurveSymbol::PointSymbolEnum RimPlotCurve::symbol() { return m_curveAppearance->symbol(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- int RimPlotCurve::symbolSize() const { return m_curveAppearance->symbolSize(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- cvf::Color3f RimPlotCurve::symbolEdgeColor() const { return m_curveAppearance->symbolEdgeColor(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setSymbolEdgeColor( const cvf::Color3f& edgeColor ) { m_curveAppearance->setSymbolEdgeColor( edgeColor ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setSymbolSkipDistance( float distance ) { m_curveAppearance->setSymbolSkipDistance( distance ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setSymbolLabel( const QString& label ) { m_curveAppearance->setSymbolLabel( label ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setSymbolLabelPosition( RiuPlotCurveSymbol::LabelPosition labelPosition ) { m_curveAppearance->setSymbolLabelPosition( labelPosition ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setSymbolSize( int sizeInPixels ) { m_curveAppearance->setSymbolSize( sizeInPixels ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setLineThickness( int thickness ) { m_curveAppearance->setLineThickness( thickness ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::resetAppearance() { setColor( RiaColorTools::textColor3f() ); setSymbolEdgeColor( RiaColorTools::textColor3f() ); setLineThickness( 2 ); setLineStyle( RiuQwtPlotCurveDefines::LineStyleEnum::STYLE_SOLID ); setSymbol( RiuPlotCurveSymbol::SYMBOL_NONE ); setSymbolSkipDistance( 10 ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- Qt::BrushStyle RimPlotCurve::fillStyle() const { return m_curveAppearance->fillStyle(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setFillStyle( Qt::BrushStyle brushStyle ) { m_curveAppearance->setFillStyle( brushStyle ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setFillColor( const cvf::Color3f& fillColor ) { m_curveAppearance->setFillColor( fillColor ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RimPlotCurve::showInLegend() const { return m_showLegend; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RimPlotCurve::errorBarsVisible() const { return m_showErrorBars; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setShowInLegend( bool show ) { m_showLegend = show; if ( m_plotCurve ) m_plotCurve->setVisibleInLegend( show ); updateLegendEntryVisibilityNoPlotUpdate(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateLegendEntryVisibilityAndPlotLegend() { updateLegendEntryVisibilityNoPlotUpdate(); updateLegendsInPlot(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::onCurveAppearanceChanged( const caf::SignalEmitter* emitter ) { checkAndApplyDefaultFillColor(); updateCurveAppearance(); appearanceChanged.send(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::onFillColorChanged( const caf::SignalEmitter* emitter ) { } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateLegendsInPlot() { nameChanged.send( curveName() ); if ( m_parentPlot != nullptr ) { m_parentPlot->updateLegend(); } } void RimPlotCurve::setTitle( const QString& title ) { if ( m_plotCurve ) m_plotCurve->setTitle( title ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::replotParentPlot() { if ( m_parentPlot ) m_parentPlot->replot(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RimPlotCurve::hasParentPlot() const { return ( m_parentPlot != nullptr ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setSamplesFromXYValues( const std::vector& xValues, const std::vector& yValues, bool useLogarithmicScale ) { if ( m_plotCurve ) { m_plotCurve->setSamplesFromXValuesAndYValues( xValues, yValues, useLogarithmicScale ); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setSamplesFromDatesAndYValues( const std::vector& dateTimes, const std::vector& yValues, bool useLogarithmicScale ) { if ( m_plotCurve ) { m_plotCurve->setSamplesFromDatesAndYValues( dateTimes, yValues, useLogarithmicScale ); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setSamplesFromTimeTAndYValues( const std::vector& dateTimes, const std::vector& yValues, bool useLogarithmicScale ) { if ( m_plotCurve ) { m_plotCurve->setSamplesFromTimeTAndYValues( dateTimes, yValues, useLogarithmicScale ); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setSamplesFromXYErrorValues( const std::vector& xValues, const std::vector& yValues, const std::vector& errorValues, bool useLogarithmicScale, RiaCurveDataTools::ErrorAxis errorAxis ) { if ( m_plotCurve ) { m_plotCurve->setSamplesFromXYErrorValues( xValues, yValues, errorValues, useLogarithmicScale, errorAxis ); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateAxisInPlot( RiuPlotAxis plotAxis ) { if ( m_plotCurve ) m_plotCurve->setYAxis( plotAxis ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateLegendEntryVisibilityNoPlotUpdate() { if ( !m_plotCurve ) return; RimEnsembleCurveSet* ensembleCurveSet = nullptr; this->firstAncestorOrThisOfType( ensembleCurveSet ); if ( ensembleCurveSet ) { return; } bool showLegendInPlot = m_showLegend(); RimSummaryPlot* summaryPlot = nullptr; this->firstAncestorOrThisOfType( summaryPlot ); if ( summaryPlot ) { bool anyCalculated = false; for ( const auto c : summaryPlot->summaryCurves() ) { if ( c->summaryAddressY().category() == RifEclipseSummaryAddress::SUMMARY_CALCULATED ) { // Never hide the legend for calculated curves, as the curve legend is used to // show some essential auto generated data anyCalculated = true; } } if ( !anyCalculated && summaryPlot->ensembleCurveSetCollection()->curveSets().empty() && summaryPlot->curveCount() == 1 ) { // Disable display of legend if the summary plot has only one single curve showLegendInPlot = false; } } m_plotCurve->setVisibleInLegend( showLegendInPlot ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RimPlotCurve::xValueRange( double* minimumValue, double* maximumValue ) const { CAF_ASSERT( minimumValue && maximumValue ); CAF_ASSERT( m_plotCurve ); if ( m_plotCurve->numSamples() < 1 ) { return false; } auto [min, max] = m_plotCurve->xDataRange(); *minimumValue = min; *maximumValue = max; return true; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RimPlotCurve::yValueRange( double* minimumValue, double* maximumValue ) const { CAF_ASSERT( minimumValue && maximumValue ); CAF_ASSERT( m_plotCurve ); if ( m_plotCurve->numSamples() < 1 ) { return false; } auto [min, max] = m_plotCurve->yDataRange(); *minimumValue = min; *maximumValue = max; return true; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setZOrder( double z ) { if ( m_plotCurve != nullptr ) { m_plotCurve->setZ( z ); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateCurveAppearance() { QColor curveColor = RiaColorTools::toQColor( m_curveAppearance->color() ); if ( !m_plotCurve ) return; RiuPlotCurveSymbol* symbol = nullptr; if ( m_curveAppearance->symbol() != RiuPlotCurveSymbol::SYMBOL_NONE ) { int legendFontSize = caf::FontTools::absolutePointSize( RiaPreferences::current()->defaultPlotFontSize(), caf::FontTools::RelativeSize::Small ); RimPlotWindow* plotWindow = nullptr; this->firstAncestorOrThisOfType( plotWindow ); if ( plotWindow ) { legendFontSize = plotWindow->legendFontSize(); } // Plot curve will take ownership of the symbol symbol = m_plotCurve->createSymbol( m_curveAppearance->symbol() ); if ( symbol ) { symbol->setLabelPosition( m_curveAppearance->symbolLabelPosition() ); symbol->setGlobalLabel( m_curveAppearance->symbolLabel() ); symbol->setSize( m_curveAppearance->symbolSize(), m_curveAppearance->symbolSize() ); symbol->setColor( curveColor ); symbol->setLabelFontSize( legendFontSize ); // If the symbol is a "filled" symbol, we can have a different edge color // Otherwise we'll have to use the curve color. if ( RiuPlotCurveSymbol::isFilledSymbol( m_curveAppearance->symbol() ) ) { QColor symbolEdgeColor = RiaColorTools::toQColor( m_curveAppearance->symbolEdgeColor() ); symbol->setPen( symbolEdgeColor ); } else { symbol->setPen( curveColor ); } } } m_plotCurve->updateErrorBarsAppearance( m_showErrorBars, curveColor ); QColor fillColor = RiaColorTools::toQColor( m_curveAppearance->fillColor() ); fillColor = RiaColorTools::blendQColors( fillColor, QColor( Qt::white ), 3, 1 ); QBrush fillBrush( fillColor, m_curveAppearance->fillStyle() ); m_plotCurve->setAppearance( m_curveAppearance->lineStyle(), m_curveAppearance->interpolation(), m_curveAppearance->lineThickness(), curveColor, fillBrush ); m_plotCurve->setSymbolSkipPixelDistance( m_curveAppearance->symbolSkipDistance() ); m_plotCurve->setSymbol( symbol ); // Make sure the legend lines are long enough to distinguish between line types. // Standard width in Qwt is 8 which is too short. // Use 10 and scale this by curve thickness + add space for displaying symbol. if ( m_curveAppearance->lineStyle() != RiuQwtPlotCurveDefines::LineStyleEnum::STYLE_NONE ) { QSize legendIconSize = m_plotCurve->legendIconSize(); int symbolWidth = 0; if ( symbol ) { symbolWidth = symbol->boundingRect().size().width() + 2; } int width = std::max( 10 * m_curveAppearance->lineThickness(), ( symbolWidth * 3 ) / 2 ); legendIconSize.setWidth( width ); m_plotCurve->setLegendIconSize( legendIconSize ); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::clearErrorBars() { if ( m_plotCurve ) m_plotCurve->clearErrorBars(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateUiIconFromPlotSymbol() { if ( m_curveAppearance->symbol() != RiuPlotCurveSymbol::SYMBOL_NONE && m_plotCurve ) { CAF_ASSERT( RiaGuiApplication::isRunning() ); QSizeF iconSize( 24, 24 ); QPixmap pixmap = m_plotCurve->legendIcon( iconSize ); setUiIcon( caf::IconProvider( pixmap ) ); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::updateCurveVisibility() { if ( canCurveBeAttached() ) { reattach(); } else { detach(); } } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- int RimPlotCurve::dataSize() const { if ( m_plotCurve ) return m_plotCurve->numSamples(); else return 0; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- std::pair RimPlotCurve::sample( int index ) const { CAF_ASSERT( m_plotCurve ); CAF_ASSERT( index >= 0 && index <= dataSize() ); return m_plotCurve->sample( index ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setParentPlotNoReplot( RiuPlotWidget* plotWidget ) { if ( !plotWidget ) return; m_parentPlot = plotWidget; if ( m_plotCurve ) { m_plotCurve->attachToPlot( plotWidget ); return; } m_plotCurve = m_parentPlot->createPlotCurve( this, "", RiaColorTools::toQColor( m_curveAppearance->color() ) ); m_plotCurve->attachToPlot( plotWidget ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::setParentPlotAndReplot( RiuPlotWidget* plotWidget ) { CAF_ASSERT( plotWidget ); setParentPlotNoReplot( plotWidget ); plotWidget->replot(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::attach( RiuPlotWidget* plotWidget ) { setParentPlotAndReplot( plotWidget ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::detach( bool deletePlotCurve ) { if ( m_plotCurve ) { if ( deletePlotCurve ) { delete m_plotCurve; m_plotCurve = nullptr; } else { m_plotCurve->detach(); } } replotParentPlot(); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::reattach() { if ( m_parentPlot && canCurveBeAttached() ) attach( m_parentPlot ); } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- bool RimPlotCurve::isSameCurve( const RiuPlotCurve* plotCurve ) const { return m_plotCurve == plotCurve; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- void RimPlotCurve::deletePlotCurve() { delete m_plotCurve; m_plotCurve = nullptr; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- QString RimPlotCurve::curveName() const { return m_curveName; } //-------------------------------------------------------------------------------------------------- /// //-------------------------------------------------------------------------------------------------- QString RimPlotCurve::curveExportDescription( const RifEclipseSummaryAddress& address ) const { return m_curveName; }