CurveCalibrator.h 2.14 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29
/*=====================================================================

QGroundControl Open Source Ground Control Station

(c) 2009, 2010 QGROUNDCONTROL PROJECT <http://www.qgroundcontrol.org>

This file is part of the QGROUNDCONTROL project

    QGROUNDCONTROL 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.

    QGROUNDCONTROL 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 QGROUNDCONTROL. If not, see <http://www.gnu.org/licenses/>.

======================================================================*/

/**
 * @file
 *   @brief Calibration widget for 5 point inerpolated curve
 *   @author Bryan Godbolt <godbolt@ualberta.ca>
 */

30 31 32 33 34 35 36
#ifndef CURVECALIBRATOR_H
#define CURVECALIBRATOR_H

#include <QWidget>
#include <QVector>
#include <qwt_plot.h>
#include <qwt_plot_curve.h>
37
//#include <qwt_array.h>
38 39 40 41
#include <QGridLayout>
#include <QHBoxLayout>
#include <QLabel>
#include <QPushButton>
42 43 44 45 46
#include <QPen>
#include <QColor>
#include <QString>
#include <QSignalMapper>
#include <QDebug>
47

48 49
#include "AbstractCalibrator.h"

50 51 52 53
/**
  @brief Calibration widget for 5 point inerpolated curve.
  For the helicopter autopilot at UAlberta this is used for the throttle and pitch curves.
  */
54
class CurveCalibrator : public AbstractCalibrator
55 56 57 58
{
Q_OBJECT
public:
    explicit CurveCalibrator(QString title = QString(), QWidget *parent = 0);
59
    ~CurveCalibrator();
60 61

    void set(const QVector<float> &data);
62 63 64

protected slots:
    void setSetpoint(int setpoint);
65

66
protected:    
67 68
    QVector<double> *setpoints;
    QVector<double> *positions;
69
    /** Plot to display calibration curve */
70
    QwtPlot *plot;
71
    /** Curve object of calibration curve */
72
    QwtPlotCurve *curve;
73 74

    QSignalMapper *signalMapper;
75 76 77
};

#endif // CURVECALIBRATOR_H