summaryrefslogtreecommitdiffstats
path: root/src/plugins/sensors/ios/iosproximitysensor.mm
diff options
context:
space:
mode:
Diffstat (limited to 'src/plugins/sensors/ios/iosproximitysensor.mm')
-rw-r--r--src/plugins/sensors/ios/iosproximitysensor.mm14
1 files changed, 12 insertions, 2 deletions
diff --git a/src/plugins/sensors/ios/iosproximitysensor.mm b/src/plugins/sensors/ios/iosproximitysensor.mm
index 6a2465bf..eae85608 100644
--- a/src/plugins/sensors/ios/iosproximitysensor.mm
+++ b/src/plugins/sensors/ios/iosproximitysensor.mm
@@ -45,6 +45,8 @@ char const * const IOSProximitySensor::id("ios.proximitysensor");
QT_BEGIN_NAMESPACE
+int IOSProximitySensor::s_startCount = 0;
+
@interface ProximitySensorCallback : NSObject
{
IOSProximitySensor *m_iosProximitySensor;
@@ -110,8 +112,12 @@ IOSProximitySensor::~IOSProximitySensor()
void IOSProximitySensor::start()
{
+ if (m_proximitySensorCallback)
+ return;
+
m_proximitySensorCallback = [[ProximitySensorCallback alloc] initWithQIOSProximitySensor:this];
- [UIDevice currentDevice].proximityMonitoringEnabled = YES;
+ if (++s_startCount == 1)
+ [UIDevice currentDevice].proximityMonitoringEnabled = YES;
}
void IOSProximitySensor::proximityChanged(bool close)
@@ -123,9 +129,13 @@ void IOSProximitySensor::proximityChanged(bool close)
void IOSProximitySensor::stop()
{
- [UIDevice currentDevice].proximityMonitoringEnabled = NO;
+ if (!m_proximitySensorCallback)
+ return;
+
[m_proximitySensorCallback release];
m_proximitySensorCallback = 0;
+ if (--s_startCount == 0)
+ [UIDevice currentDevice].proximityMonitoringEnabled = NO;
}
QT_END_NAMESPACE