Merge branch 'mkirk/fix-disable-earpiece' into release/2.31.0

pull/1/head
Matthew Chen 7 years ago
commit fc3780c243

@ -11,7 +11,16 @@ public protocol OWSProximityMonitoringManager: class {
@objc
public class OWSProximityMonitoringManagerImpl: NSObject, OWSProximityMonitoringManager {
var lifetimes: [Weak<AnyObject>] = []
let serialQueue = DispatchQueue(label: "ProximityMonitoringManagerImpl")
public override init() {
super.init()
// TODO: change to `runNowOrWhenAppWillBecomeReady` when
// reverse integrating
AppReadiness.runNowOrWhenAppIsReady {
self.setup()
}
}
// MARK:
@ -23,36 +32,61 @@ public class OWSProximityMonitoringManagerImpl: NSObject, OWSProximityMonitoring
@objc
public func add(lifetime: AnyObject) {
serialQueue.sync {
if !lifetimes.contains { $0.value === lifetime } {
lifetimes.append(Weak(value: lifetime))
}
reconcile()
objc_sync_enter(self)
if !lifetimes.contains { $0.value === lifetime } {
lifetimes.append(Weak(value: lifetime))
}
reconcile()
objc_sync_exit(self)
}
@objc
public func remove(lifetime: AnyObject) {
serialQueue.sync {
lifetimes = lifetimes.filter { $0.value !== lifetime }
reconcile()
objc_sync_enter(self)
lifetimes = lifetimes.filter { $0.value !== lifetime }
reconcile()
objc_sync_exit(self)
}
@objc
public func setup() {
NotificationCenter.default.addObserver(self, selector: #selector(proximitySensorStateDidChange(notification:)), name: .UIDeviceProximityStateDidChange, object: nil)
}
@objc
func proximitySensorStateDidChange(notification: Notification) {
Logger.debug("")
// This is crazy, but if we disable `device.isProximityMonitoringEnabled` while
// `device.proximityState` is true (while the device is held to the ear)
// then `device.proximityState` remains true, even after we bring the phone
// away from the ear and re-enable monitoring.
//
// To resolve this, we wait to disable proximity monitoring until `proximityState`
// is false.
if self.device.proximityState {
self.add(lifetime: self)
} else {
self.remove(lifetime: self)
}
}
func reconcile() {
if _isDebugAssertConfiguration() {
assertOnQueue(serialQueue)
}
lifetimes = lifetimes.filter { $0.value != nil }
if lifetimes.isEmpty {
Logger.debug("disabling proximity monitoring")
DispatchQueue.main.async {
Logger.debug("disabling proximity monitoring")
self.device.isProximityMonitoringEnabled = false
}
} else {
Logger.debug("enabling proximity monitoring for lifetimes: \(lifetimes)")
let lifetimes = self.lifetimes
DispatchQueue.main.async {
Logger.debug("willEnable proximity monitoring for lifetimes: \(lifetimes), proximityState: \(self.device.proximityState)")
self.device.isProximityMonitoringEnabled = true
Logger.debug("didEnable proximity monitoring for lifetimes: \(lifetimes), proximityState: \(self.device.proximityState)")
}
}
}

Loading…
Cancel
Save