Index: webrtc/modules/audio_device/ios/objc/RTCAudioSessionDelegateAdapter.mm |
diff --git a/webrtc/modules/audio_device/ios/objc/RTCAudioSessionDelegateAdapter.mm b/webrtc/modules/audio_device/ios/objc/RTCAudioSessionDelegateAdapter.mm |
new file mode 100644 |
index 0000000000000000000000000000000000000000..bd75fd6eb92ef605e5744b18cb4b0984c2dcb8c9 |
--- /dev/null |
+++ b/webrtc/modules/audio_device/ios/objc/RTCAudioSessionDelegateAdapter.mm |
@@ -0,0 +1,94 @@ |
+/* |
+ * Copyright 2016 The WebRTC Project Authors. All rights reserved. |
+ * |
+ * Use of this source code is governed by a BSD-style license |
+ * that can be found in the LICENSE file in the root of the source |
+ * tree. An additional intellectual property rights grant can be found |
+ * in the file PATENTS. All contributing project authors may |
+ * be found in the AUTHORS file in the root of the source tree. |
+ */ |
+ |
+#import "webrtc/modules/audio_device/ios/objc/RTCAudioSessionDelegateAdapter.h" |
+ |
+#include "webrtc/base/asyncinvoker.h" |
+#include "webrtc/base/bind.h" |
+#include "webrtc/base/thread.h" |
+#include "webrtc/modules/audio_device/ios/audio_device_ios.h" |
+ |
+#import "webrtc/base/objc/RTCLogging.h" |
+ |
+@implementation RTCAudioSessionDelegateAdapter { |
+ webrtc::AudioDeviceIOS *_device; |
+ rtc::Thread *_callbackThread; |
+ std::unique_ptr<rtc::AsyncInvoker> _asyncInvoker; |
+} |
+ |
+- (instancetype)initWithAudioDevice:(webrtc::AudioDeviceIOS *)device |
+ callbackThread:(rtc::Thread *)callbackThread { |
+ NSParameterAssert(device); |
+ NSParameterAssert(callbackThread); |
+ if (self = [super init]) { |
+ _device = device; |
+ _callbackThread = callbackThread; |
+ _asyncInvoker.reset(new rtc::AsyncInvoker()); |
+ } |
+ return self; |
+} |
+ |
+#pragma mark - RTCAudioSessionDelegate |
+ |
+- (void)audioSessionDidBeginInterruption:(RTCAudioSession *)session { |
+ _asyncInvoker->AsyncInvoke<void>( |
+ _callbackThread, |
+ rtc::Bind(&webrtc::AudioDeviceIOS::OnInterruptionBegin, _device)); |
+} |
+ |
+- (void)audioSessionDidEndInterruption:(RTCAudioSession *)session |
+ shouldResumeSession:(BOOL)shouldResumeSession { |
+ _asyncInvoker->AsyncInvoke<void>( |
+ _callbackThread, |
+ rtc::Bind(&webrtc::AudioDeviceIOS::OnInterruptionEnd, _device)); |
+} |
+ |
+- (void)audioSessionDidChangeRoute:(RTCAudioSession *)session |
+ reason:(AVAudioSessionRouteChangeReason)reason |
+ previousRoute:(AVAudioSessionRouteDescription *)previousRoute { |
+ switch (reason) { |
+ case AVAudioSessionRouteChangeReasonUnknown: |
+ case AVAudioSessionRouteChangeReasonNewDeviceAvailable: |
+ case AVAudioSessionRouteChangeReasonOldDeviceUnavailable: |
+ case AVAudioSessionRouteChangeReasonCategoryChange: |
+ // It turns out that we see a category change (at least in iOS 9.2) |
+ // when making a switch from a BT device to e.g. Speaker using the |
+ // iOS Control Center and that we therefore must check if the sample |
+ // rate has changed. And if so is the case, restart the audio unit. |
+ case AVAudioSessionRouteChangeReasonOverride: |
+ case AVAudioSessionRouteChangeReasonWakeFromSleep: |
+ case AVAudioSessionRouteChangeReasonNoSuitableRouteForCategory: |
+ _asyncInvoker->AsyncInvoke<void>( |
+ _callbackThread, |
+ rtc::Bind(&webrtc::AudioDeviceIOS::OnValidRouteChange, _device)); |
+ break; |
+ case AVAudioSessionRouteChangeReasonRouteConfigurationChange: |
+ // The set of input and output ports has not changed, but their |
+ // configuration has, e.g., a port’s selected data source has |
+ // changed. Ignore this type of route change since we are focusing |
+ // on detecting headset changes. |
+ RTCLog(@"Ignoring RouteConfigurationChange"); |
+ break; |
+ } |
+} |
+ |
+- (void)audioSessionMediaServicesWereLost:(RTCAudioSession *)session { |
+} |
+ |
+- (void)audioSessionMediaServicesWereReset:(RTCAudioSession *)session { |
+} |
+ |
+- (void)audioSessionShouldConfigure:(RTCAudioSession *)session { |
+} |
+ |
+- (void)audioSessionShouldUnconfigure:(RTCAudioSession *)session { |
+} |
+ |
+@end |