【移動應用開發技術】【音視頻】Android CallKit 開發指南_第1頁
【移動應用開發技術】【音視頻】Android CallKit 開發指南_第2頁
【移動應用開發技術】【音視頻】Android CallKit 開發指南_第3頁
【移動應用開發技術】【音視頻】Android CallKit 開發指南_第4頁
【移動應用開發技術】【音視頻】Android CallKit 開發指南_第5頁
已閱讀5頁,還剩4頁未讀 繼續免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

【移動應用開發技術】【音視頻】AndroidCallKit開發指南

簡介CallKit

是融云音視頻通話功能的UI界面SDK。包含了單人、多人音視頻通話的界面的各種場景和功能。您可以快速的集成

CallKit

來實現豐富的音視頻通話界面,并進行自己的UI定制開發。同時我們開源了

CallKit,您可以根據您的需要去使用。GitHub項目:CallKit開源代碼開通方式音視頻服務開通,請參考音視頻開通方式說明。使用說明由于底層引擎技術不同,2.6.0之后的音視頻SDK與2.6.0之前的SDK中的實時音視頻不能互通。音視頻SDK為商用收費功能,之前的SDK中的實時音視頻為免費測試功能,如果您還想使用之前的實時音視頻,可以使用2.5.2版本,2.6.0之后的音視頻服務使用說明如下:集成說明1、首先請參考官網文檔集成CallKitSDK。2、

src/main/java/io/rong/imkit

下面是Call界面的源碼,可以自行修改以滿足自己的需求。3、打開

src/main/AndroidManifest.xml,下面是Call相關的代碼。<uses-permission

android:name="android.permission.PROCESS_OUTGOING_CALLS"

/>

<uses-permission

android:name="android.permission.SYSTEM_ALERT_WINDOW"

/>

<uses-permission

android:name="android.permission.INTERACT_ACROSS_USERS_FULL"

/>Call用到的權限。<activity

android:name="io.rong.imkit.MultiVideoCallActivity"

android:launchMode="singleTop"

android:screenOrientation="portrait"

android:windowSoftInputMode="stateHidden|adjustResize">

<intent-filter>

<action

android:name="ent.action.voip.MULTIVIDEO"

/>

<category

android:name="ent.category.DEFAULT"

/>

</intent-filter>

</activity>

<activity

android:name="io.rong.imkit.SingleCallActivity"

android:launchMode="singleTop"

android:screenOrientation="portrait"

android:windowSoftInputMode="stateHidden|adjustResize">

<intent-filter>

<action

android:name="ent.action.voip.SINGLEVIDEO"

/>

<category

android:name="ent.category.DEFAULT"

/>

</intent-filter>

<intent-filter>

<action

android:name="ent.action.voip.SINGLEAUDIO"

/>

<category

android:name="ent.category.DEFAULT"

/>

</intent-filter>

</activity>

<activity

android:name="io.rong.imkit.MultiAudioCallActivity"

android:launchMode="singleTop"

android:screenOrientation="portrait"

android:windowSoftInputMode="stateHidden|adjustResize">

<intent-filter>

<action

android:name="ent.action.voip.MULTIAUDIO"

/>

<category

android:name="ent.category.DEFAULT"

/>

</intent-filter>

</activity>

<activity

android:name="io.rong.imkit.CallSelectMemberActivity"

/>Call功能中使用到的

activity

receiver

。4、用戶使用Call期間融云保持connected狀態。5、在群組中,啟動視頻通話或音頻通話時,需要設置群組成員信息,通過getMemberList方法返回群組成員的userId的集合。以確保選擇成員頁面能正確顯示所有群組成員。設置方法如下:RongCallKit.setGroupMemberProvider(new

RongCallKit.GroupMembersProvider()

{

@Override

public

ArrayList<String>

getMemberList(String

groupId,

final

RongCallKit.OnGroupMembersResult

result)

{

//返回群組成員userId的集合

}

});發起通話在私聊或討論組的會話界面,點擊輸入框右側的+號,就可以選擇“語音聊天”和“視頻聊天”了。或者你可以根據自己的代碼邏輯,在需要的地方調用下面接口發起呼叫。/**

*

發起單人通話。

*

*

@param

context

上下文

*

@param

targetId

會話

id

*

@param

mediaType

會話媒體類型

*/RongCallKit.startSingleCall(Context

context,

String

targetId,

CallMediaType

mediaType);

/**

*

發起多人通話

*

*

@param

context

上下文

*

@param

conversationType

會話類型

*

@param

targetId

會話

id

*

@param

mediaType

會話媒體類型

*

@param

userIds

參與者

id

列表

*/

RongCallKit.startMultiCall(Context

context,

Conversation.ConversationType

conversationType,

String

targetId,

CallMediaType

mediaType,

ArrayList<String>

userIds);CallKit默認音頻通話最大人數為20人,視頻通話最大人數為9人。收到呼入的通話如果App在前臺或者在后臺且并沒有被系統回收時,當收到呼叫,會自動彈出通話界面。如果App已經被回收,2.6.0以上的版本需要集成遠程推送。這樣即使被回收了也能收到Call的推送消息,點擊推送消息啟動App會自動彈出通話界面。詳細請參考遠程推送集成文檔。通話回調接口IRongCallListener是通話狀態的監聽類,CallKit的

RongCallProxy.java

已經實現了該監聽,并且會回調到BaseCallActivity中的各個方法,您可以繼承BaseCallActivity,根據需要復寫其中的對應方法,即可獲取對應的通話回調。public

class

MyCallActivity

extends

BaseCallActivity

{

@Override

public

void

onCallOutgoing(RongCallSession

callProfile,

SurfaceView

localVideo)

{

super.onCallOutgoing(callProfile,

localVideo);

/**

*

此處添加你的代碼邏輯。

**/

}

@Override

public

void

onCallDisconnected(RongCallSession

callProfile,

RongCallCommon.CallDisconnectedReason

reason)

{

super.onCallDisconnected(callProfile,

reason);

/**

*

此處添加你的代碼邏輯。

**/

}

@Override

public

void

onOutgoingCallRinging()

{

super.onOutgoingCallRinging();

/**

*

此處添加你的代碼邏輯。

**/

}

@Override

public

void

onIncomingCallRinging()

{

super.onIncomingCallRinging();

/**

*

此處添加你的代碼邏輯。

**/

}

@Override

public

void

onCallConnected(RongCallSession

callProfile,

SurfaceView

localVideo)

{

super.onCallConnected(callProfile,

localVideo);

/**

*

此處添加你的代碼邏輯。

**/

}

@Override

public

void

onError(RongCallCommon.CallErrorCode

errorCode)

{

super.onError(errorCode);

/**

*

此處添加你的代碼邏輯。

**/

}

}如果上述方法不適合,您還可以通過修改

RongCallProxy.java

的代碼,實現自己應用的監聽。示例如下:public

class

RongCallProxy

implements

IRongCallListener

{

private

IRongCallListener

mCallListener;

//

增加一個監聽。

/*設置自己應用的監聽*/

public

void

setAppCallListener(IRongCallListener

listener)

{

this.mAppCallListener

=

listener;

}

/*修改對應的通話狀態回調的方法,使其回調到您設置的應用自身的監聽*/

@Override

public

void

onCallOutgoing(RongCallSession

callSession,

SurfaceView

localVideo)

{

if

(mCallListener

!=

null)

{

mCallListener.onCallOutgoing(callSession,

localVideo);

}

/*增加的代碼,回調應用設置的監聽*/

if(mAppCallListener

!=

null)

{

mAppCallListener.onCallOutgoing(callSession,

localVideo);

}

}

...

//

根據您的需要,同樣的方式修改其它通話狀

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論