Files
GoldenCheetah/deprecated/PerfPlot.h
Mark Liversedge 804f30502e Reorg tidy src directory
.. move the fluff that has collected into the src directory
   to somewhere more appropriate.
2016-02-26 09:28:28 +00:00

90 lines
2.3 KiB
C++

/*
* Copyright (c) 2009 Eric Murray (ericm@lne.com)
*
* This program 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 2 of the License, or (at your option)
* any later version.
*
* This program 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 for
* more details.
*
* You should have received a copy of the GNU General Public License along
* with this program; if not, write to the Free Software Foundation, Inc., 51
* Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef _GC_PerfPlot_h
#define _GC_PerfPlot_h 1
#include "GoldenCheetah.h"
#include "Settings.h"
#include "StressCalculator.h"
#include "RideItem.h"
#include "RideFile.h"
#include "PerfPlot.h"
#include "StressCalculator.h"
#include "Colors.h"
#include <QtGui>
#include <qwt_plot.h>
#include <qwt_plot_marker.h>
#include <qwt_plot_curve.h>
#include <qwt_plot_grid.h>
#include <qwt_scale_draw.h>
#include <qwt_series_data.h>
#include <qwt_legend.h>
#include <qwt_plot_canvas.h>
#include <qwt_scale_widget.h>
class PPTimeScaleDraw;
class PerfPlot : public QwtPlot
{
Q_OBJECT
G_OBJECT
private:
QwtPlotGrid *grid;
QwtPlotCurve *STScurve, *LTScurve, *SBcurve, *DAYcurve;
int days;
QDateTime startDate;
StressCalculator *_sc;
PPTimeScaleDraw *xsd;
int xmin, xmax;
public slots:
void configUpdate();
public:
double getSTS(int i) { return STScurve->sample(i - xmin).y(); }
double getLTS(int i) { return LTScurve->sample(i - xmin).y(); }
double getSB(int i) { return SBcurve->sample(i - xmin).y(); }
double getDAY(int i) { return DAYcurve->sample(i - xmin).y(); }
int n(void) { return days; }
int max(void) { return xmax; }
int min(void) { return xmin; }
QDateTime getStartDate(void) { return startDate; }
QDateTime getEndDate(void) { return startDate.addDays(days); }
PerfPlot();
void setStressCalculator(StressCalculator *sc);
void plot();
void setAxisTitle(int axis, QString label);
void resize(int newmin, int newmax);
};
#endif // _GC_PerfPlot_h