2 ******************************************************************************
4 * @file thermalcalibrationtransitions.h
5 * @author The OpenPilot Team, http://www.openpilot.org Copyright (C) 2014.
7 * @brief State transitions used to implement thermal calibration
8 * @see The GNU Public License (GPL) Version 3
12 *****************************************************************************/
14 * This program is free software; you can redistribute it and/or modify
15 * it under the terms of the GNU General Public License as published by
16 * the Free Software Foundation; either version 3 of the License, or
17 * (at your option) any later version.
19 * This program is distributed in the hope that it will be useful, but
20 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
21 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
24 * You should have received a copy of the GNU General Public License along
25 * with this program; if not, write to the Free Software Foundation, Inc.,
26 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
29 #ifndef DATAACQUISITIONTRANSITION_H
30 #define DATAACQUISITIONTRANSITION_H
32 #include "thermalcalibrationhelper.h"
34 #include <QSignalTransition>
35 #include <QEventTransition>
38 class DataAcquisitionTransition
: public QSignalTransition
{
42 DataAcquisitionTransition(ThermalCalibrationHelper
*helper
, QState
*currentState
, QState
*targetState
)
43 : QSignalTransition(helper
, SIGNAL(collectionCompleted())),
46 QObject::connect(currentState
, SIGNAL(entered()), this, SLOT(enterState()));
48 setTargetState(targetState
);
51 virtual void onTransition(QEvent
*e
)
54 m_helper
->endAcquisition();
60 m_helper
->setProgressMax(0);
61 m_helper
->setProgress(0);
63 m_helper
->addInstructions(tr("Please wait during samples acquisition. This can take several minutes..."), WizardModel::Prompt
);
64 m_helper
->addInstructions(tr("Acquisition will run until the rate of temperature change is less than %1°C/min.").arg(ThermalCalibrationHelper::TargetGradient
, 4, 'f', 2));
65 m_helper
->addInstructions(tr("For the calibration to be valid, the temperature span during acquisition must be greater than %1°C.").arg(ThermalCalibrationHelper::TargetTempDelta
, 4, 'f', 2));
66 m_helper
->addInstructions(tr("Estimating acquisition duration..."));
68 m_helper
->initAcquisition();
72 ThermalCalibrationHelper
*m_helper
;
76 #endif // DATAACQUISITIONTRANSITION_H