mirror of
				https://github.com/OPM/ResInsight.git
				synced 2025-02-25 18:55:39 -06:00 
			
		
		
		
	
		
			
				
	
	
		
			293 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			293 lines
		
	
	
		
			10 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| /////////////////////////////////////////////////////////////////////////////////
 | |
| //
 | |
| //  Copyright (C) 2015-     Statoil ASA
 | |
| //  Copyright (C) 2015-     Ceetron Solutions AS
 | |
| //
 | |
| //  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.
 | |
| //
 | |
| /////////////////////////////////////////////////////////////////////////////////
 | |
| 
 | |
| #include "RiuTofAccumulatedPhaseFractionsPlot.h"
 | |
| 
 | |
| #include "RimContextCommandBuilder.h"
 | |
| #include "RimTofAccumulatedPhaseFractionsPlot.h"
 | |
| 
 | |
| #include "RiuMainWindow.h"
 | |
| #include "RiuQwtCurvePointTracker.h"
 | |
| 
 | |
| #include "RiuGuiTheme.h"
 | |
| 
 | |
| #include "cafSelectionManager.h"
 | |
| 
 | |
| #include "cvfAssert.h"
 | |
| 
 | |
| #include "qwt_legend.h"
 | |
| #include "qwt_plot_curve.h"
 | |
| #include "qwt_plot_grid.h"
 | |
| #include "qwt_plot_layout.h"
 | |
| #include "qwt_text.h"
 | |
| 
 | |
| #include <QFocusEvent>
 | |
| #include <QHBoxLayout>
 | |
| #include <QMdiSubWindow>
 | |
| #include <QMenu>
 | |
| 
 | |
| #include <cmath>
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RiuTofAccumulatedPhaseFractionsPlot::RiuTofAccumulatedPhaseFractionsPlot( RimTofAccumulatedPhaseFractionsPlot* plotDefinition,
 | |
|                                                                           QWidget*                             parent )
 | |
|     : QwtPlot( parent )
 | |
|     , m_watCurve( nullptr )
 | |
|     , m_oilCurve( nullptr )
 | |
|     , m_gasCurve( nullptr )
 | |
| {
 | |
|     Q_ASSERT( plotDefinition );
 | |
|     m_plotDefinition = plotDefinition;
 | |
| 
 | |
|     QPalette newPalette( palette() );
 | |
|     newPalette.setColor( QPalette::Window, Qt::white );
 | |
|     setPalette( newPalette );
 | |
| 
 | |
|     setAutoFillBackground( true );
 | |
|     setDefaults();
 | |
|     QwtText title( "Cumulative Saturation by Time of Flight" );
 | |
|     QFont   titleFont = title.font();
 | |
|     titleFont.setPointSize( 10 );
 | |
|     title.setFont( titleFont );
 | |
|     title.setRenderFlags( title.renderFlags() | Qt::TextWordWrap );
 | |
|     setTitle( title );
 | |
| 
 | |
|     m_watCurve = new QwtPlotCurve;
 | |
|     setCurveColor( m_watCurve, RiuGuiTheme::getColorByVariableName( "curveColorWater2" ) );
 | |
|     m_watCurve->setZ( 0.9 );
 | |
|     m_watCurve->setTitle( "Water" );
 | |
|     m_watCurve->setRenderHint( QwtPlotItem::RenderAntialiased, true );
 | |
| 
 | |
|     m_oilCurve = new QwtPlotCurve;
 | |
|     setCurveColor( m_oilCurve, RiuGuiTheme::getColorByVariableName( "curveColorOil2" ) );
 | |
|     m_oilCurve->setZ( 0.8 );
 | |
|     m_oilCurve->setTitle( "Oil" );
 | |
|     m_oilCurve->setRenderHint( QwtPlotItem::RenderAntialiased, true );
 | |
| 
 | |
|     m_gasCurve = new QwtPlotCurve;
 | |
|     setCurveColor( m_gasCurve, RiuGuiTheme::getColorByVariableName( "curveColorGas2" ) );
 | |
|     m_gasCurve->setZ( 0.7 );
 | |
|     m_gasCurve->setTitle( "Gas" );
 | |
|     m_gasCurve->setRenderHint( QwtPlotItem::RenderAntialiased, true );
 | |
| 
 | |
|     m_watCurve->attach( this );
 | |
|     m_oilCurve->attach( this );
 | |
|     m_gasCurve->attach( this );
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RiuTofAccumulatedPhaseFractionsPlot::~RiuTofAccumulatedPhaseFractionsPlot()
 | |
| {
 | |
|     if ( m_watCurve )
 | |
|     {
 | |
|         m_watCurve->detach();
 | |
|         delete m_watCurve;
 | |
|         m_watCurve = nullptr;
 | |
|     }
 | |
| 
 | |
|     if ( m_oilCurve )
 | |
|     {
 | |
|         m_oilCurve->detach();
 | |
|         delete m_oilCurve;
 | |
|         m_oilCurve = nullptr;
 | |
|     }
 | |
| 
 | |
|     if ( m_gasCurve )
 | |
|     {
 | |
|         m_gasCurve->detach();
 | |
|         delete m_gasCurve;
 | |
|         m_gasCurve = nullptr;
 | |
|     }
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| QSize RiuTofAccumulatedPhaseFractionsPlot::sizeHint() const
 | |
| {
 | |
|     QSize plotSizeHint = QwtPlot::sizeHint();
 | |
| 
 | |
|     plotSizeHint.setWidth( std::max( plotSizeHint.width(), 400 ) );
 | |
|     plotSizeHint.setHeight( std::max( plotSizeHint.height(), 250 ) );
 | |
|     return plotSizeHint;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| int RiuTofAccumulatedPhaseFractionsPlot::heightForWidth( int w ) const
 | |
| {
 | |
|     return static_cast<int>( static_cast<double>( w ) / 1.1 );
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimTofAccumulatedPhaseFractionsPlot* RiuTofAccumulatedPhaseFractionsPlot::ownerPlotDefinition()
 | |
| {
 | |
|     return m_plotDefinition;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| RimViewWindow* RiuTofAccumulatedPhaseFractionsPlot::ownerViewWindow() const
 | |
| {
 | |
|     return m_plotDefinition;
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RiuTofAccumulatedPhaseFractionsPlot::setSamples( std::vector<double> xSamples,
 | |
|                                                       std::vector<double> watValues,
 | |
|                                                       std::vector<double> oilValues,
 | |
|                                                       std::vector<double> gasValues,
 | |
|                                                       int                 maxTofYears )
 | |
| {
 | |
|     m_xValues.clear();
 | |
|     m_watValues.clear();
 | |
|     m_oilValues.clear();
 | |
|     m_gasValues.clear();
 | |
| 
 | |
|     m_watValues.swap( watValues );
 | |
|     for ( size_t i = 0; i < xSamples.size(); ++i )
 | |
|     {
 | |
|         double tofYears = xSamples[i] / 365.2425;
 | |
|         if ( tofYears <= maxTofYears )
 | |
|         {
 | |
|             m_xValues.push_back( tofYears );
 | |
|             m_oilValues.push_back( oilValues[i] + m_watValues[i] );
 | |
|             m_gasValues.push_back( gasValues[i] + m_oilValues[i] );
 | |
|         }
 | |
|     }
 | |
|     m_watCurve->setSamples( m_xValues.data(), m_watValues.data(), static_cast<int>( m_xValues.size() ) );
 | |
|     m_oilCurve->setSamples( m_xValues.data(), m_oilValues.data(), static_cast<int>( m_xValues.size() ) );
 | |
|     m_gasCurve->setSamples( m_xValues.data(), m_gasValues.data(), static_cast<int>( m_xValues.size() ) );
 | |
| 
 | |
|     if ( !m_xValues.empty() )
 | |
|     {
 | |
|         double maxVal = 0;
 | |
|         for ( double val : m_xValues )
 | |
|         {
 | |
|             maxVal = std::max( val, maxVal );
 | |
|         }
 | |
|         setAxisScale( QwtAxis::XBottom, 0, maxVal );
 | |
|         updateAxes();
 | |
|     }
 | |
|     replot();
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RiuTofAccumulatedPhaseFractionsPlot::setDefaults()
 | |
| {
 | |
|     setCommonPlotBehaviour( this );
 | |
|     setAxisTitle( QwtAxis::XBottom, "Years" );
 | |
| 
 | |
|     setAxesCount( QwtAxis::XBottom, 1 );
 | |
|     setAxesCount( QwtAxis::YLeft, 1 );
 | |
|     setAxisScale( QwtAxis::YLeft, 0, 1, 0.2 );
 | |
| 
 | |
|     setAxisMaxMinor( QwtAxis::XBottom, 2 );
 | |
|     setAxisMaxMinor( QwtAxis::YLeft, 3 );
 | |
| 
 | |
|     QSizePolicy sizePolicy( QSizePolicy::Preferred, QSizePolicy::Preferred );
 | |
|     sizePolicy.setHeightForWidth( true );
 | |
|     setSizePolicy( sizePolicy );
 | |
|     updateGeometry();
 | |
| 
 | |
|     // The legend will be deleted in the destructor of the plot or when
 | |
|     // another legend is inserted.
 | |
|     QwtLegend* legend = new QwtLegend( this );
 | |
|     this->insertLegend( legend, BottomLegend );
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RiuTofAccumulatedPhaseFractionsPlot::setCommonPlotBehaviour( QwtPlot* plot )
 | |
| {
 | |
|     // Plot background and frame look
 | |
| 
 | |
|     QPalette newPalette( plot->palette() );
 | |
|     newPalette.setColor( QPalette::Window, Qt::white );
 | |
|     plot->setPalette( newPalette );
 | |
| 
 | |
|     plot->setAutoFillBackground( true );
 | |
|     plot->setCanvasBackground( Qt::white );
 | |
| 
 | |
|     QFrame* canvasFrame = dynamic_cast<QFrame*>( plot->canvas() );
 | |
|     if ( canvasFrame )
 | |
|     {
 | |
|         canvasFrame->setFrameShape( QFrame::NoFrame );
 | |
|     }
 | |
| 
 | |
|     // Grid
 | |
| 
 | |
|     QwtPlotGrid* grid = new QwtPlotGrid;
 | |
|     grid->attach( plot );
 | |
|     QPen gridPen( Qt::SolidLine );
 | |
|     gridPen.setColor( Qt::lightGray );
 | |
|     grid->setPen( gridPen );
 | |
| 
 | |
|     // Axis number font
 | |
|     QFont axisFont = plot->axisFont( QwtAxis::XBottom );
 | |
|     axisFont.setPointSize( 10 );
 | |
| 
 | |
|     plot->setAxisFont( QwtAxis::XBottom, axisFont );
 | |
|     plot->setAxisFont( QwtAxis::XTop, axisFont );
 | |
|     plot->setAxisFont( QwtAxis::YLeft, axisFont );
 | |
|     plot->setAxisFont( QwtAxis::YRight, axisFont );
 | |
| 
 | |
|     // Axis title font
 | |
|     QwtText axisTitle     = plot->axisTitle( QwtAxis::XBottom );
 | |
|     QFont   axisTitleFont = axisTitle.font();
 | |
|     axisTitleFont.setPointSize( 10 );
 | |
|     axisTitleFont.setBold( false );
 | |
|     axisTitle.setFont( axisTitleFont );
 | |
|     axisTitle.setRenderFlags( Qt::AlignRight );
 | |
| 
 | |
|     plot->setAxisTitle( QwtAxis::XBottom, axisTitle );
 | |
|     plot->setAxisTitle( QwtAxis::XTop, axisTitle );
 | |
|     plot->setAxisTitle( QwtAxis::YLeft, axisTitle );
 | |
|     plot->setAxisTitle( QwtAxis::YRight, axisTitle );
 | |
| 
 | |
|     // Enable mouse tracking and event filter
 | |
| 
 | |
|     plot->canvas()->setMouseTracking( true );
 | |
|     plot->canvas()->installEventFilter( plot );
 | |
|     plot->plotLayout()->setAlignCanvasToScales( true );
 | |
| 
 | |
|     new RiuQwtCurvePointTracker( plot, true );
 | |
| }
 | |
| 
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| ///
 | |
| //--------------------------------------------------------------------------------------------------
 | |
| void RiuTofAccumulatedPhaseFractionsPlot::setCurveColor( QwtPlotCurve* curve, QColor color )
 | |
| {
 | |
|     curve->setBrush( QBrush( color ) );
 | |
| }
 |