///////////////////////////////////////////////////////////////////////////////// // // 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 #include #include class RimAsciiDataCurve; class RimSummaryCurve; class RimSummaryCurveFilter; class RimSummaryYAxisProperties; class RiuSummaryQwtPlot; class QwtPlotCurve; class RimSummaryPlotYAxisFormatter { public: RimSummaryPlotYAxisFormatter(RimSummaryYAxisProperties* axisProperties, const std::vector& summaryCurves, const std::vector& asciiCurves, const std::set& timeHistoryCurveQuantities); void applyYAxisPropertiesToPlot(RiuSummaryQwtPlot* qwtPlot); private: QString autoAxisTitle() const; private: RimSummaryYAxisProperties* m_axisProperties; const std::vector m_summaryCurves; const std::vector m_asciiDataCurves; const std::set m_timeHistoryCurveQuantities; }; class RimSummaryPlotYAxisRangeCalculator { public: RimSummaryPlotYAxisRangeCalculator( const std::vector& qwtCurves, const std::vector& yValuesForAllCurves); void computeYRange(double* min, double* max) const; private: bool curveValueRangeY(const QwtPlotCurve* qwtCurve, double* min, double* max) const; private: const std::vector m_singleCurves; const std::vector m_yValuesForAllCurves; };