音影片即時通訊—影片呼叫業務流程使用

bbbrrr123發表於2014-11-07

 

  影片呼叫業務邏輯主要實現兩個終端(PC、手機、Pad等)之間的通話請求流程控制,包括請求(Request)、回覆(Reply)、開始(Start)以及結束(Finish)等過程,可以形象理解為打電話的流程:撥號、等待、通話、結束通話。

     以下以AnyChat影片呼叫業務邏輯為例說明:

 

1、業務邏輯流程圖

    請參考 %3D1

 

2、API介面及常量定義

客戶端相關API介面及事件回撥:

// 視訊通話訊息通知回撥函式定義

typedef void (CALLBACK * BRAC_VideoCallEvent_CallBack)(DWORD dwEventType, DWORD dwUserId, DWORD dwErrorCode, DWORD dwFlags, DWORD dwParam, LPCTSTR lpUserStr, LPVOID lpUserValue);

 

// 設定視訊通話訊息通知回撥函式

BRAC_API DWORD BRAC_SetVideoCallEventCallBack(BRAC_VideoCallEvent_CallBack lpFunction, LPVOID lpUserValue);

 

// 影片呼叫事件控制(請求、回覆、結束通話等)

BRAC_API DWORD BRAC_VideoCallControl(DWORD dwEventType, DWORD dwUserId, DWORD dwErrorCode, DWORD dwFlags, DWORD dwParam, LPCTSTR lpUserStr);

 

伺服器相關API介面及事件回撥:

// 視訊通話訊息通知回撥函式定義

typedef DWORD (CALLBACK * BRAS_OnVideoCallEvent_CallBack)(DWORD dwEventType, DWORD dwSrcUserId, DWORD dwTarUserId, DWORD dwErrorCode, DWORD dwFlags, DWORD dwParam, LPCTSTR lpUserStr, LPVOID lpUserValue);

 

// 設定視訊通話訊息通知回撥函式

BRAS_API DWORD BRAS_SetOnVideoCallEventCallBack(BRAS_OnVideoCallEvent_CallBack lpFunction, LPVOID lpUserValue=NULL);

 

// 影片呼叫事件控制(請求、回覆、結束通話等)

BRAS_API DWORD BRAS_VideoCallControl(DWORD dwEventType, DWORD dwUserId, DWORD dwErrorCode, DWORD dwFlags, DWORD dwParam, LPCTSTR lpUserStr);

 

常量定義

/ 影片呼叫事件型別定義(APIBRAS_VideoCallControl 傳入引數、OnVideoCallEvent回撥引數)

#define BRAS_VIDEOCALL_EVENT_REQUEST 1 ///< 呼叫請求

#define BRAS_VIDEOCALL_EVENT_REPLY 2 ///< 呼叫請求回覆

#define BRAS_VIDEOCALL_EVENT_START 3 ///< 影片呼叫會話開始事件

#define BRAS_VIDEOCALL_EVENT_FINISH 4 ///< 結束通話(結束)呼叫會話

 

3、相關說明

3.1、客戶端APIBRAC_VideoCallControl)和回撥函式(BRAC_VideoCallEvent_CallBack)中的dwUserId均為對方(被呼叫方)的使用者ID

 

3.2、被呼叫方拒絕通話時,傳送回覆(Reply)指令,dwErrorCode=100104

 

3.3、被呼叫方同意通話時,傳送回覆(Reply)指令,dwErrorCode=0,然後伺服器會向雙方傳送通話開始(Start)指令,dwParam=RoomId,房間號由核心伺服器自動分配;

 

3.4、結束通話時,任何一方(包括業務伺服器)均可以傳送結束(Finish)指令,然後伺服器會向雙方傳送通話結束(Finish)指令;

 

3.5、業務伺服器可干預呼叫流程:在BRAS_OnVideoCallEvent_CallBack收到呼叫請求指令後,返回0表示允許呼叫,否則為出錯程式碼,不允許呼叫;在會話過程中可以傳送結束(Finish)指令,強制結束通話指定使用者的通話;

 

3.6、API介面中的dwParam(整型)、lpUserStr(字串)均為使用者自定義用途;

 

3.7、一個使用者同時只能發起一路呼叫請求,也同時只能被一個使用者呼叫;

 

3.8、影片呼叫業務流程可以脫離業務伺服器,由核心伺服器獨立支撐,可以不需要在伺服器端進行二次開發。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/30004768/viewspace-1324188/,如需轉載,請註明出處,否則將追究法律責任。

相關文章