黄h片网址在线观看,五月婷婷网址,一级一级一级毛片免费毛片,欧美一级视频免费观看

智慧服務(wù),成就美好體驗 項目咨詢

主頁 > 服務(wù)與支持 > 開發(fā)平臺 > 客戶端SDK參考 > iOS Native SDK > 音視頻呼叫 建立音頻通話

入門使用

建立音頻通話

更新時間:2019-11-20

描述

用戶點對點音頻通話。

主被叫客戶端均已注冊。

業(yè)務(wù)流程

圖1 建立音頻通話流程 
  1. 主叫UI調(diào)用tsdk_start_call()接口發(fā)起音頻呼叫,傳入?yún)?shù)包含被叫號碼和是否發(fā)起視頻呼叫,返回參數(shù)call_id標(biāo)識本次呼叫ID。
    說明: 

    呼叫ID作為一路通話的唯一標(biāo)識,UI應(yīng)保存并管理,以用于后繼的呼叫相關(guān)操作。

    代碼示例:
    TSDK_BOOL isVideo = ((TSDK_CALL_E_CALL_TYPE)callType==CALL_VIDEO)?TSDK_TRUE:TSDK_FALSE;    
    TSDK_UINT32 callid = 0;    
    TSDK_RESULT ret = tsdk_start_call(&callid,(TSDK_CHAR*)[number UTF8String], isVideo);
     
  2. 主叫SDK完成狀態(tài)自檢,準(zhǔn)備呼叫請求消息,向UI上報呼出事件發(fā)起呼叫結(jié)果事件TSDK_E_CALL_EVT_CALL_START_RESULT。
  3. 主叫SDK發(fā)出呼叫請求消息,向UI上報呼出事件TSDK_E_CALL_EVT_CALL_OUTGOING;被叫SDK收到呼叫請求消息,向UI上報來電事件TSDK_E_CALL_EVT_CALL_INCOMING。通知事件攜帶參數(shù)callid標(biāo)識本次呼叫,對應(yīng)的事件數(shù)據(jù)結(jié)構(gòu)中TSDK_S_CALL_INFO包含遠(yuǎn)端號碼、呼叫類型和呼叫狀態(tài)等呼叫信息。
    代碼示例:
    case TSDK_E_CALL_EVT_CALL_INCOMING:        
    {                                             
        TSDK_S_CALL_INFO *callInfo = (TSDK_S_CALL_INFO *)notify.data;            
        CallInfo *tsdkCallInfo = [CallInfo transfromFromCallInfoStract:callInfo];                        
        [self resetUCVideoOrientAndIndexWithCallId:0];                        
        NSString *callId = [NSString stringWithFormat:@"%d", callInfo->call_id];            
        [_tsdkCallInfoDic setObject:tsdkCallInfo forKey:callId];            
        NSDictionary *resultInfo = @{                                         
            TSDK_CALL_INFO_KEY : tsdkCallInfo                                         
        };            
        [self respondsCallDelegateWithType:CALL_INCOMMING result:resultInfo];
    }
     
  4. 主叫SDK在收到被叫振鈴?fù)ㄖ獣r,上報TSDK_E_CALL_EVT_CALL_RINGBACK事件,UI應(yīng)播放本地回鈴音。
    代碼示例:
    case TSDK_E_CALL_EVT_CALL_RINGBACK:        
    {            
        NSDictionary *resultInfo = @{                                         
            TSDK_CALL_RINGBACK_KEY : [NSNumber numberWithBool:true]                                         
        };            
        [self respondsCallDelegateWithType:CALL_RINGBACK result:resultInfo];            
        break;        
    }
     
  5. 被叫調(diào)用tsdk_accept_call()接聽呼叫。
    說明: 

    被叫若拒絕呼叫參見結(jié)束通話(或呼叫)章節(jié)描述。

    代碼示例:
    - (BOOL) answerComingCallType:(TUP_CALL_TYPE)callType callId:(unsigned int)callId
    {    
        TSDK_RESULT ret = tsdk_accept_call((TSDK_UINT32)callId, callType == CALL_AUDIO ? TSDK_FALSE : TSDK_TRUE);   
        DDLogInfo(@"Call_Log:answer call type is %d,result is %d, callid: %d",callType,ret,callId);    
        return ret == TSDK_SUCCESS ? YES : NO;
    }
     
  6. 主被叫SDK向UI上報通話建立事件TSDK_E_CALL_EVT_CALL_RTP_CREATED。
    說明: 

    RTP通道已建立,可以進(jìn)行一些二次撥號等操作。

  7. 主被叫SDK向UI上報通話建立事件TSDK_E_CALL_EVT_CALL_CONNECTED,UI刷新界面進(jìn)入通話界面,主被叫雙方通話。
    代碼示例:
    case TSDK_E_CALL_EVT_CALL_CONNECTED:        
    {            
        DDLogInfo(@"Call_Log: recv call notify :CALL_E_EVT_CALL_CONNECTED");            
        TSDK_S_CALL_INFO *callInfo = (TSDK_S_CALL_INFO *)notify.data;           
        CallInfo *tsdkCallInfo = [CallInfo transfromFromCallInfoStract:callInfo];            
        NSString *callId = [NSString stringWithFormat:@"%d", tsdkCallInfo.stateInfo.callId];            
        [_tsdkCallInfoDic setObject:tsdkCallInfo forKey:callId];            
        NSDictionary *resultInfo = @{                                        
            TSDK_CALL_INFO_KEY : tsdkCallInfo                                         
        };            
        [self respondsCallDelegateWithType:CALL_CONNECT result:resultInfo];
    }