diff options
author | Arseniy-Movshev <dodoradio@outlook.com> | 2023-03-06 20:59:36 +0000 |
---|---|---|
committer | Arseniy-Movshev <dodoradio@outlook.com> | 2023-03-07 21:44:42 +0000 |
commit | 222f776d9f9d1f362038d26f835c96918a7af5fe (patch) | |
tree | e1c5b01753d52603bc9d8e5cb91c1cf3287a8ba9 /sensorPlugins/stepCounter.cpp | |
parent | 31a0592f40ccbe0ed31abcd8bf39c2c00dab699a (diff) |
Refactor sensors into separate files
- this should make things a lot easier to maintain. instead of having everything in the same file, each sensor provides a constructor that sets it up correctly etc.
- this should also get the step counter running when the service starts, which is necessary, since the sensor won't count on most devices unless the service is running.
- this also temporarily removes the gps module from the service. it's not implemented right now anyway.
Diffstat (limited to 'sensorPlugins/stepCounter.cpp')
-rw-r--r-- | sensorPlugins/stepCounter.cpp | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/sensorPlugins/stepCounter.cpp b/sensorPlugins/stepCounter.cpp new file mode 100644 index 0000000..6afc408 --- /dev/null +++ b/sensorPlugins/stepCounter.cpp @@ -0,0 +1,43 @@ +#include <QDateTime> +#include <QTimer> +#include <QtSensors/QStepCounterSensor> +#include <QDebug> +#include <QString> + +#include "../logger.h" + +#include "stepCounter.h" + +StepCounterPlugin::StepCounterPlugin(QObject *parent, int initInterval) : + QObject(parent){ + interval = initInterval; + + stepcounterSensor = new QStepCounterSensor(this); + stepcounterSensor->start(); + + qDebug() << "step counter sensor is enabled. interval is (ms) " << interval; + recordIntervalTimer = new QTimer(this); + connect(recordIntervalTimer,SIGNAL(timeout()),this,SLOT(triggerRecording())); + recordIntervalTimer->setSingleShot(true); + recordIntervalTimer->start(interval); + lastRecordTime = QDateTime::currentDateTime(); +} + +void StepCounterPlugin::timeUpdate() { + uint elapsed = QDateTime::currentMSecsSinceEpoch() - lastRecordTime.toMSecsSinceEpoch(); + qDebug() << "time until next steps recording" << recordIntervalTimer->remainingTime() << " elapsed = " << elapsed << " lastRecordTime " << lastRecordTime.toMSecsSinceEpoch(); + if (elapsed > interval) { //if too much time has passed, reset the timer and record + triggerRecording(); + lastRecordTime = QDateTime::currentDateTime(); + } else { //otherwise, restart the timer and compensate for time spent in suspend + recordIntervalTimer->start(interval - elapsed); + } +} + +void StepCounterPlugin::triggerRecording() { + qDebug() << "stepcounter interval recording"; + int steps = stepcounterSensor->reading()->steps(); + qDebug() << QDateTime::currentDateTime().toString("hh:mm:ss") << " : " << steps << stepcounterSensor->isActive(); + //we probably ought to do some error checking here + writeReadingToFile(QString::number(QDateTime::currentSecsSinceEpoch()) + " : " + QString::number(steps) + "\n", "stepsOut.txt"); +} |