title: 多人视频会议

本篇文档介绍开发多人视频会议的主要环节,包括 创建视频会议管理其他参与者加入视频会议相关

创建视频会议

创建视频会议包括配置和预览本地媒体流、发起/加入视频会议。

配置和预览本地媒体流

本地媒体流( Local Stream )包括音频和视频,发起或加入会议前需要进行配置,成功加入一个会议后,该媒体流会发送给其他参与者。

例如,创建一个只有视频且分辨率为 320X240 的流,并展示到 WilddogVideoView 上:

  1. //获取视频播放控件
  2. WilddogVideoView localView = (WilddogVideoView) findViewById(R.id.local_video_view);
  3. // 如果没有获得摄像头权限或无摄像头,则无法展示。
  4. LocalStreamOptions.Builder builder = new LocalStreamOptions.Builder();
  5. LocalStreamOptions options = builder.height(240).width(320).build();
  6. localStream = video.createLocalStream(options,new CompleteListener() {
  7. @Override
  8. public void onCompleted(VideoException e) {
  9. }
  10. });

配置成功后,可以在加入视频通话前预览本地画面。

  1. //为视频流绑定播放控件
  2. localStream.attach(localView);

发起/加入视频会议

通过 Conference ID 发起/加入一个视频会议。如果该会议不存在,系统会以你作为第一个参与者发起该会议。

例如,加入 Conference ID 为 ‘123456’ 的视频会议:

  1. mConference=client.connectToConference("123456", options, new Conference.Listener() {//会议事件监听});

管理其他参与者

管理其他参与者包括处理其他参与者的连接事件和播放其他参与者的媒体流。

处理其他参与者的连接事件

通过监听其他参与者加入或离开的事件,来获得其状态通知。

例如,打印加入、离开的日志:

  1. Conference.Listener listener = new Conference.Listener() {
  2. @Override
  3. public void onParticipantConnected(Conference conference, Participant participant) {
  4. //监听参与者加入事件
  5. Log.d(TAG, "onParticipantConnected :" + participant.getParticipantId());
  6. }
  7. @Override
  8. public void onParticipantDisconnected(Conference conference, Participant participant) {
  9. //监听参与者离开事件
  10. Log.d(TAG, "onParticipantDisconnected :" + participant.getParticipantId());
  11. }
  12. };

播放其他参与者的媒体流

通过展示他参与者的视频流来观看其视频画面。

例如,当监听到参与者加入视频会议时展示参与者的媒体流:

  1. //在参与者加入时获得到加入的参与者,并设置监听
  2. participant.setListener(new Participant.Listener() {
  3. @Override
  4. public void onStreamAdded(RemoteStream remoteStream) {
  5. //其他客户端的媒体流可用,播放其他客户端的媒体流
  6. remoteStream.attach(remoteView);
  7. }
  8. @Override
  9. public void onStreamRemoved(RemoteStream remoteStream) {
  10. }
  11. @Override
  12. public void onError(VideoException e) {
  13. }
  14. });

加入视频会议相关


视频会议相关操作包括离开视频会议和直播视频会议。

离开视频会议

离开一个正在进行的视频会议并释放媒体资源。可以直接释放媒体资源或通过监听离开视频会议事件在成功离开会议后释放媒体资源。

例如,断开视频会议并释放不使用的资源:

  1. @Override
  2. protected void onDestroy() {
  3. super.onDestroy();
  4. //需要离开会议时调用此方法,并做资源释放和其他自定义操作
  5. localStream.detach();
  6. localStream.close();
  7. if (localView != null) {
  8. localView.release();
  9. localView = null;
  10. }
  11. if (mConference != null) {
  12. mConference.disconnect();
  13. }
  14. client.dispose();
  15. video.dispose();
  16. videoViewManager.dispose();
  17. }

视频会议直播

视频会议直播采用野狗独有的 MeetingCast 技术,能直播视频会议中指定客户端的视频和音频,并根据需要无缝切换直播的客户端。

注意:

MeetingCast 功能配置之前,需要开启 控制面板-实时视频通话-多人视频会议 下的 “视频会议直播” 开关。

开启直播

在视频会议开始后,选择一个参与者作为直播源,打开直播功能。

例如,选择参与者 ‘12345’ 作为直播源开启直播:

  1. //获取直播插件
  2. meetingCast = mConference.getMeetingCast(new MeetingCastStateListener() {
  3. @Override
  4. public void onMeetingCastStateChanged(Conference.MeetingCastStatus status, String participantId, Map<String, String> urlMap) {
  5. //直播状态改变时会触发此方法
  6. }
  7. });
  8. meetingCast.start("12345", new CompleteListener() {
  9. @Override
  10. public void onCompleted(VideoException exception) {
  11. //操作异常则会返回错误
  12. //操作成功会调用onMeetingCastStateChanged() 方法
  13. }
  14. });

切换直播者

直播进行时无缝切换直播源。

例如,切换直播源为 participant ID ‘99999’ 的参与者:

  1. meetingCast.switchParticipant("99999", new CompleteListener() {
  2. @Override
  3. public void onCompleted(VideoException exception) {
  4. //操作异常则会返回错误
  5. //操作成功会调用onMeetingCastStateChanged() 方法
  6. }
  7. });

停止直播

停止直播功能。

例如,直播开启后,停止直播:

  1. meetingCast.stop(new CompleteListener() {
  2. @Override
  3. public void onCompleted(VideoException exception) {
  4. //操作异常则会返回错误
  5. //操作成功会调用onMeetingCastStateChanged() 方法
  6. }
  7. });

直播状态

获取直播状态,通过直播状态监听获取直播地址。

  1. meetingCast = mConference.getMeetingCast(new MeetingCastStateListener() {
  2. @Override
  3. public void onMeetingCastStateChanged(Conference.MeetingCastStatus status, String participantId, Map<String, String> urlMap) {
  4. //status:直播状态
  5. //participantId:当前正在直播的参与者 ID
  6. //urlMap:直播地址
  7. }
  8. });