summaryrefslogtreecommitdiffstats
path: root/src/plugins/sensors/ios/iosaccelerometer.mm
diff options
context:
space:
mode:
authorLiang Qi <liang.qi@qt.io>2016-09-19 14:33:39 +0200
committerLiang Qi <liang.qi@qt.io>2016-09-19 14:33:44 +0200
commitdf3374bd4bb8af1494f6a35b1102f15cfe9633e0 (patch)
tree5c76f62e0e0be4bb7a79f3441717c6b8c4d302af /src/plugins/sensors/ios/iosaccelerometer.mm
parent0032fd615097baeff2414e352e095bc412000941 (diff)
parentecd018fe2ee4508e094f631d882ecc1360abec01 (diff)
Merge remote-tracking branch 'origin/5.7' into 5.8
Diffstat (limited to 'src/plugins/sensors/ios/iosaccelerometer.mm')
-rw-r--r--src/plugins/sensors/ios/iosaccelerometer.mm14
1 files changed, 12 insertions, 2 deletions
diff --git a/src/plugins/sensors/ios/iosaccelerometer.mm b/src/plugins/sensors/ios/iosaccelerometer.mm
index a497d7b4..2d2e27ae 100644
--- a/src/plugins/sensors/ios/iosaccelerometer.mm
+++ b/src/plugins/sensors/ios/iosaccelerometer.mm
@@ -46,6 +46,8 @@ char const * const IOSAccelerometer::id("ios.accelerometer");
QT_BEGIN_NAMESPACE
+int IOSAccelerometer::s_startCount = 0;
+
IOSAccelerometer::IOSAccelerometer(QSensor *sensor)
: QSensorBackend(sensor)
, m_motionManager([QIOSMotionManager sharedManager])
@@ -58,16 +60,24 @@ IOSAccelerometer::IOSAccelerometer(QSensor *sensor)
void IOSAccelerometer::start()
{
+ if (m_timer != 0)
+ return;
+
int hz = sensor()->dataRate();
m_timer = startTimer(1000 / (hz == 0 ? 60 : hz));
- [m_motionManager startAccelerometerUpdates];
+ if (++s_startCount == 1)
+ [m_motionManager startAccelerometerUpdates];
}
void IOSAccelerometer::stop()
{
- [m_motionManager stopAccelerometerUpdates];
+ if (m_timer == 0)
+ return;
+
killTimer(m_timer);
m_timer = 0;
+ if (--s_startCount == 0)
+ [m_motionManager stopAccelerometerUpdates];
}
void IOSAccelerometer::timerEvent(QTimerEvent *)