diff options
author | Liang Qi <liang.qi@qt.io> | 2016-09-21 08:34:05 +0200 |
---|---|---|
committer | Liang Qi <liang.qi@qt.io> | 2016-09-21 08:34:05 +0200 |
commit | 53a414e33ce45f28b89217678597416b681128d4 (patch) | |
tree | 51ab26cf4a14662e525c4a648d84dae81090f0c7 /src/plugins/sensors/ios/iosaccelerometer.mm | |
parent | 3523afa703792fabc8bac3febe5541766bc1ccd4 (diff) | |
parent | df3374bd4bb8af1494f6a35b1102f15cfe9633e0 (diff) | |
download | qtsensors-53a414e33ce45f28b89217678597416b681128d4.tar.gz |
Merge remote-tracking branch 'origin/5.8' into dev
Change-Id: Iaeb7c9f62b50d68e0cedb95c523aebcceb9128c0
Diffstat (limited to 'src/plugins/sensors/ios/iosaccelerometer.mm')
-rw-r--r-- | src/plugins/sensors/ios/iosaccelerometer.mm | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/src/plugins/sensors/ios/iosaccelerometer.mm b/src/plugins/sensors/ios/iosaccelerometer.mm index a497d7b..2d2e27a 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 *) |