2016-12-10 15 views
5

私は新しいCallKit APIを私のVOIPアプリケーションと統合しています。didActivateはCallKitによって呼び戻されません

例アプリに示すように:私は、オーディオセッションを設定していますhttps://developer.apple.com/library/content/samplecode/Speakerbox/Introduction/Intro.html

私CXAnswerCallActionで
- (void) configureAudioSession 
{ 
    // Configure the audio session 
    AVAudioSession *sessionInstance = [AVAudioSession sharedInstance]; 

    // we are going to play and record so we pick that category 
    NSError *error = nil; 
    [sessionInstance setCategory:AVAudioSessionCategoryPlayAndRecord error:&error]; 
    if (error) { 
     NSLog(@"error setting audio category %@",error); 
    } 

    // set the mode to voice chat 
    [sessionInstance setMode:AVAudioSessionModeVoiceChat error:&error]; 
    if (error) { 
     NSLog(@"error setting audio mode %@",error); 
    } 

    NSLog(@"setupAudioSession"); 

    return; 
} 

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

     // get the active call 
     guard let call = self.softphone.getCallForCallId(self.currentCallId) else { 
      action.fail() 
      return 
     } 

     /* 
     Configure the audio session, but do not start call audio here, since it must be done once 
     the audio session has been activated by the system after having its priority elevated. 
     */ 
     self.softphone.configureAudioSession() 

     // Trigger the call to be answered via the underlying network service. 
     call.answer() 

     // Signal to the system that the action has been successfully performed. 
     action.fulfill() 
    } 

文書によると、didActivateを呼び出さなければなりませんコールキットによる返品:

func provider(_ provider: CXProvider, didActivate audioSession: AVAudioSession) { 
    print("Provider - Received \(#function)") 

    // Start call audio media, now that the audio session has been activated after having its priority boosted. 
} 

何らかの理由で、最初のVOIPコール後にコールバックされません。後続のコールはコールバックを受信するように見え、正常に動作します。この問題を解決する方法

答えて

1

私は、コール音声を最初に設定してから、 "reportNewIncomingCall"メソッドを呼び出すことでこの問題を解決しました。サンプルコードを以下に示します。

func reportIncomingCall(uuid: UUID, handle: String, hasVideo: Bool = false, completion: ((NSError?) -> Void)? = nil) { 
    let update = CXCallUpdate() 
    update.remoteHandle = CXHandle(type: .phoneNumber, value: handle) 
    update.hasVideo = hasVideo 


    DispatchQueue.global().sync { 
     _ = try? AVAudioSession.sharedInstance().setCategory(AVAudioSessionCategoryPlayAndRecord, with: AVAudioSessionCategoryOptions.mixWithOthers) 
     _ = try? AVAudioSession.sharedInstance().overrideOutputAudioPort(AVAudioSessionPortOverride.none) 
     if hasVideo == true { 
      _ = try? AVAudioSession.sharedInstance().setMode(AVAudioSessionModeVideoChat) 
     } else { 
      _ = try? AVAudioSession.sharedInstance().setMode(AVAudioSessionModeVoiceChat) 
     } 


     do { 
      _ = try AVAudioSession.sharedInstance().setActive(true) 
     } catch (let error){ 
      print("audio session error: \(error)") 
     } 
    } 

    provider.reportNewIncomingCall(with: uuid, update: update) { error in 

     if error == nil { 

     } 

     completion?(error as? NSError) 
    } 
} 
関連する問題