CallKit干扰WebRTC视频

时间:2017-06-25 01:53:41

标签: ios swift webrtc videochat callkit

当我使用CallKit接听WebRTC电话时,视频聊天大部分时间都在工作。偶尔因为CallKit而无法正确访问我本地iPhone上的相机。当我删除CallKit时,视频聊天始终有效。此外,如果我在应答CallKit呼叫然后开始视频聊天后设置了1.5秒的延迟,那么它似乎一直都能很好地工作。这是什么原因?

3 个答案:

答案 0 :(得分:1)

Callkit仅用于音频呼叫,因此callkit仅激活AudioSession 只有在导航到应用程序后才会激活视频。

尝试在手机锁屏幕上接听电话,然后您就会明白了。

测试Facebook或任何其他热门应用。

答案 1 :(得分:0)

尝试在providerDidReset(_ provider: CXProvider)中实现(重新)连接逻辑。您可能还希望在此方法中提供检查,以确保不重置成功的连接。

答案 2 :(得分:0)

我在我的应用程序中使用WebRTC + CallKit。 我开始通话,然后按Lock / Power按钮,那么CallKit通话将断开连接,并且My Voip通话音频路由更改为Receiver并保持不变。

为什么锁定iPhone终止通话。

这是我的代码。

    var callUUID: UUID?

extension AppDelegate {
    func initiateCallKitCall() {
        let config = CXProviderConfiguration(localizedName: "Huddl.ai")
        config.includesCallsInRecents = false;
        config.supportsVideo = true;
        config.maximumCallsPerCallGroup = 1
        provider = CXProvider(configuration: config)
        guard let provider = provider else { return }
        provider.setDelegate(self, queue: nil)
        callController = CXCallController()
        guard let callController = callController else { return }
        callUUID = UUID()
        let transaction = CXTransaction(action: CXStartCallAction(call: callUUID!, handle: CXHandle(type: .generic, value: "Huddl.ai")))
        callController.request(transaction, completion: { error in
            print("Error is : \(String(describing: error))")
        })

    }

    func endCallKitCall(userEnded: Bool) {
        self.userEnded = userEnded
        guard provider != nil else { return }
        guard let callController = callController else { return }
        if let uuid = callUUID {
            let endCallAction = CXEndCallAction(call: uuid)
            callController.request(
                CXTransaction(action: endCallAction),
                completion: { error in
                    if let error = error {
                        print("Error: \(error)")
                    } else {
                        print("Success")
                    }
                })
        }
    }

    func isCallGoing() -> Bool {
        let callController = CXCallController()
        if callController.callObserver.calls.count != 0 {
            return true
        }
        return false
    }
}

extension AppDelegate: CXProviderDelegate {

    func providerDidReset(_ provider: CXProvider) {
        print("-Provider-providerDidReset")
    }

    func provider(_ provider: CXProvider, perform action: CXAnswerCallAction) {
        print("-Provider-perform action: CXAnswerCallAction")
        action.fulfill()
    }

    func provider(_ provider: CXProvider, perform action: CXEndCallAction) {
        action.fulfill()
        print("-Provider: End Call")
    }

    func provider(_ provider: CXProvider, perform action: CXStartCallAction) {
        action.fulfill()

        DispatchQueue.main.asyncAfter(wallDeadline: DispatchWallTime.now() + 3) {
            provider.reportOutgoingCall(with: action.callUUID, startedConnectingAt: Date())
            DispatchQueue.main.asyncAfter(wallDeadline: DispatchWallTime.now() + 1.5) {
                provider.reportOutgoingCall(with: action.callUUID, connectedAt: Date())
            }
        }
    }

    func provider(_ provider: CXProvider, perform action: CXSetHeldCallAction) {
        action.fulfill()
    }

    func provider(_ provider: CXProvider, didActivate audioSession: AVAudioSession) {
        RTCAudioSession.sharedInstance().audioSessionDidActivate(audioSession)
        RTCAudioSession.sharedInstance().isAudioEnabled = true
    }

    func provider(_ provider: CXProvider, didDeactivate audioSession: AVAudioSession) {
        RTCAudioSession.sharedInstance().audioSessionDidDeactivate(audioSession)
        RTCAudioSession.sharedInstance().isAudioEnabled = false
    }
}