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

智慧服務,成就美好體驗 項目咨詢

主頁 > 服務與支持 > 開發(fā)平臺 > 客戶端SDK參考 > Android Native SDK > 會議 會議管理

入門使用

會議管理

更新時間:2019-11-20

創(chuàng)建預約會議

描述

用戶創(chuàng)建預約會議。

前提條件

  • 鑒權登錄成功。
  • 會議環(huán)境參數(shù)已設置。

業(yè)務流程

圖1 預約會議流程 
  1. UI調用TsdkConferenceManager對象的bookConference()方法預約會議,參數(shù)類型為TsdkBookConfInfo類。

     

    說明: 

    在創(chuàng)建TsdkBookConfInfo對象后,需要從該對象調用方法來設置必填參數(shù)和可選參數(shù)。

    • 在預約會議時,會議方數(shù)(size)、會議類型(confType)、媒體類型(confMediaType)和與會者信息(attendeeList&attendeeNum)必選,其他參數(shù)可選。
    • 按具體需求填寫會議方數(shù),當實際與會者數(shù)目多于設置的方數(shù)時,服務會自動擴大會議方數(shù),當填寫方數(shù)小于3時,服務器默認會議方數(shù)為3。
    • 預約會議,會議類型應選TsdkConfType.TSDK_E_CONF_RESERVED。
    • 服務器默認時間為UTC時間,在預約時需將預約時間轉換為UTC時間。
    代碼示例:
    //Java code
    public int bookConference(BookConferenceInfo bookConferenceInfo)
    {
        Log.i(TAG, "bookConference.");
    
        if (bookConferenceInfo == null)
        {
            Log.e(TAG, "booKConferenceInfo obj is null");
            return -1;
        }
    
        TsdkBookConfInfo bookConfInfo = new TsdkBookConfInfo();
    
        if(bookConferenceInfo.isInstantConference())
        {
            bookConfInfo.setConfType(TsdkConfType.TSDK_E_CONF_INSTANT);
            bookConfInfo.setIsAutoProlong(1);
        }
        else 
        {
            bookConfInfo.setConfType(TsdkConfType.TSDK_E_CONF_RESERVED);
        }
    
        bookConfInfo.setSubject(bookConferenceInfo.getSubject());
        bookConfInfo.setConfMediaType(bookConferenceInfo.getMediaType());
        bookConfInfo.setStartTime(bookConferenceInfo.getStartTime());
        bookConfInfo.setDuration(bookConferenceInfo.getDuration());
        bookConfInfo.setSize(bookConferenceInfo.getSize());
        bookConfInfo.setIsAutoRecord(bookConferenceInfo.getIs_auto()? 1:0);
        bookConfInfo.setRecordMode(bookConferenceInfo.getRecordType());
    
        List<TsdkAttendeeBaseInfo> attendeeList = ConfConvertUtil.memberListToAttendeeList(bookConferenceInfo.getMemberList());
        bookConfInfo.setAttendeeList(attendeeList);
        bookConfInfo.setAttendeeNum(attendeeList.size());
    
        //The other parameters are optional, using the default value
        bookConfInfo.setLanguage(TsdkConfLanguage.TSDK_E_CONF_LANGUAGE_EN_US);
    
        int result = TsdkManager.getInstance().getConferenceManager().bookConference(bookConfInfo);
        if (result != 0)
        {
            Log.e(TAG, "bookReservedConf result ->" + result);
            return  result;
        }
    
        return 0;
    }
    
     

     

  2. SDK在收到服務器返回的會議預約結果響應后,通過TsdkNotify對象中的onEvtBookConfResult()方法向UI上報預約會議結果,對應的結果參數(shù)為預約會議結果和會議信息。

     

    說明: 

    如果會議成功預約,其他用戶可以通過查詢會議列表或其他第三方方式獲取該會議的信息。

    代碼示例:
    //Java code
    public void handleBookConfResult(TsdkCommonResult result, TsdkConfBaseInfo confBaseInfo){
        Log.i(TAG, "onBookReservedConfResult");
        if ((result == null) || (confBaseInfo == null))
        {
            Log.e(TAG, "book conference is failed, unknown error.");
            mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.BOOK_CONF_FAILED, -1);
            return;
        }
        if (result.getResult() != TupConfParam.CONF_RESULT.TUP_SUCCESS)
        {
            Log.e(TAG, "book conference is failed, return ->" + result.getResult());
            mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.BOOK_CONF_FAILED, result.getResult());
            return;
        }
        Log.i(TAG, "book conference is success.");
        mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.BOOK_CONF_SUCCESS, result.getResult());
    }
    
     

     

注意事項

無。

創(chuàng)建即時會議

描述

用戶創(chuàng)建立即開始的會議,會議創(chuàng)建成功后,會議創(chuàng)建者自動入會,其他與會者將收到入會邀請。

前提條件

  • 鑒權登錄成功。
  • 會議環(huán)境參數(shù)已設置。

業(yè)務流程

圖2 創(chuàng)建立即會議流程 
  1. UI調用TsdkConferenceManager對象中的bookConference()方法創(chuàng)建立即會議。參數(shù)類型為TsdkBookConfInfo類。

     

    說明: 

    在創(chuàng)建TsdkBookConfInfo對象后,需要從該對象調用方法來設置必填參數(shù)和可選參數(shù)。

    • 在預約會議時,會議方數(shù)(size)、會議類型(confType)、媒體類型(confMediaType)和與會者信息(attendeeList&attendeeNum)必選,其他參數(shù)可選。
    • 按具體需求填寫會議方數(shù),當實際與會者數(shù)目多于設置的方數(shù)時,服務會自動擴大會議方數(shù),當填寫方數(shù)小于3時,服務器默認會議方數(shù)為3。
    • 預約會議,會議類型應選TsdkConfType.TSDK_E_CONF_INSTANT。
    • 服務器默認時間為UTC時間,在預約時需將預約時間轉換為UTC時間。
    代碼示例:
    //Java code
    public int bookConference(BookConferenceInfo bookConferenceInfo)
    {
        Log.i(TAG, "bookConference.");
    
        if (bookConferenceInfo == null)
        {
            Log.e(TAG, "booKConferenceInfo obj is null");
            return -1;
        }
    
        TsdkBookConfInfo bookConfInfo = new TsdkBookConfInfo();
    
        if(bookConferenceInfo.isInstantConference())
        {
            bookConfInfo.setConfType(TsdkConfType.TSDK_E_CONF_INSTANT);
            bookConfInfo.setIsAutoProlong(1);
        }
        else 
        {
            bookConfInfo.setConfType(TsdkConfType.TSDK_E_CONF_RESERVED);
        }
    
        bookConfInfo.setSubject(bookConferenceInfo.getSubject());
        bookConfInfo.setConfMediaType(bookConferenceInfo.getMediaType());
        bookConfInfo.setStartTime(bookConferenceInfo.getStartTime());
        bookConfInfo.setDuration(bookConferenceInfo.getDuration());
        bookConfInfo.setSize(bookConferenceInfo.getSize());
        bookConfInfo.setIsAutoRecord(bookConferenceInfo.getIs_auto()? 1:0);
        bookConfInfo.setRecordMode(bookConferenceInfo.getRecordType());
    
        List<TsdkAttendeeBaseInfo> attendeeList = ConfConvertUtil.memberListToAttendeeList(bookConferenceInfo.getMemberList());
        bookConfInfo.setAttendeeList(attendeeList);
        bookConfInfo.setAttendeeNum(attendeeList.size());
    
        //The other parameters are optional, using the default value
        bookConfInfo.setLanguage(TsdkConfLanguage.TSDK_E_CONF_LANGUAGE_EN_US);
    
        int result = TsdkManager.getInstance().getConferenceManager().bookConference(bookConfInfo);
        if (result != 0)
        {
            Log.e(TAG, "bookReservedConf result ->" + result);
            return  result;
        }
    
        return 0;
    }
    
     

     

  2. SDK在收到服務器返回的立即會議創(chuàng)建成功后,通過TsdkNotify對象中的onEvtBookConfResult()方法向UI上報會議創(chuàng)建結果通知。

     

    代碼示例:
    //Java code
    public void handleBookConfResult(TsdkCommonResult result, TsdkConfBaseInfo confBaseInfo){
        Log.i(TAG, "onBookReservedConfResult");
        if ((result == null) || (confBaseInfo == null))
        {
            Log.e(TAG, "book conference is failed, unknown error.");
            mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.BOOK_CONF_FAILED, -1);
            return;
        }
        if (result.getResult() != TupConfParam.CONF_RESULT.TUP_SUCCESS)
        {
            Log.e(TAG, "book conference is failed, return ->" + result.getResult());
            mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.BOOK_CONF_FAILED, result.getResult());
            return;
        }
        Log.i(TAG, "book conference is success.");
        mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.BOOK_CONF_SUCCESS, result.getResult());
    }
    
     

     

  3. SDK在收到服務器返回的加入會議響應后,通過TsdkNotify對象中的onEvtJoinConfResult()方法向UI上報會議加入結果事件。并返回會議對象TsdkConference,后續(xù)會控時使用。此時UI可跳轉至會議界面。

     

    說明: 
    1. 在加入會議時,會請求會議權限,若請求失敗,則通過TsdkNotify對象中的onEvtRequestConfRightFailed()方法向UI上報會議權限請求失敗通知,UI提示申請會控權限失敗,若請求成功,則不上報。
    2. 若應用程序是以多流的方式(SVC)成功加入會議,則此結果通知中會攜帶SVC信息,包含 isSvcConf (是否多流會議)、svcLabelCount(可使用的多流Label數(shù)) 和 svcLabel (多流Label 表),應用程序應保存多流“Label”信息,用于后繼流程中“綁定SVC視頻窗口”、"選看SVC與會者"和“設置SVC窗口和與會者關系”等操作。
    代碼示例:
    //Java code
    public void handleJoinConfResult(TsdkConference tsdkConference, TsdkCommonResult commonResult, TsdkJoinConfIndInfo tsdkJoinConfIndInfo
        Log.i(TAG, "handleJoinConfResult");
        if ((tsdkConference == null) || (commonResult == null)) {
            return;
        }
        int result = commonResult.getResult();
        if (result == 0)
        {
            this.currentConference = tsdkConference;
            this.memberList = null;
            this.self = null;
            TsdkCall tsdkCall = tsdkConference.getCall();
            if (null != tsdkCall) {
                Session newSession = CallMgr.getInstance().getCallSessionByCallID(tsdkCall.getCallInfo().getCallId());
                if (null == newSession) {
                    newSession = new Session(tsdkCall);
                    CallMgr.getInstance().putCallSessionToMap(newSession);
                }
                if (tsdkCall.getCallInfo().getIsVideoCall() == 1) {
                    VideoMgr.getInstance().initVideoWindow(tsdkCall.getCallInfo().getCallId());
                }
            }
            mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.JOIN_CONF_SUCCESS, tsdkConference.getHandle() + "");
        }
        else
        {
            mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.JOIN_CONF_FAILED, result);
        }
    }
    
     

     

  4. SDK收到會議狀態(tài)刷新通知,通過TsdkNotify對象中的onEvtInfoAndStatusUpdate()方法向UI上報會議信息及會議狀態(tài)刷新事件,UI刷新會議狀態(tài)和成員列表。

     

    說明: 

    詳細流程參見會議信息及會議狀態(tài)更新描述。

     

  1. 若會議包含數(shù)據會議能力,SDK通過TsdkNotify對象中的onEvtGetDataconfParamResult()方法向UI上報獲取數(shù)據會議參數(shù)結果。

     

    代碼示例:
    //Java code
    public void  handleGetDataConfParamsResult(TsdkConference tsdkConference, TsdkCommonResult commonResult){
        Log.i(TAG, "handleJoinConfResult");
        if ((tsdkConference == null) || (commonResult == null)) {
            return;
        }
        int result = commonResult.getResult();
        mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.GET_DATA_CONF_PARAM_RESULT, result);
    }
    
     

     

  2. 此時UI可選擇自動加入或用戶選擇加入數(shù)據會議,調用TsdkConference對象中的joinDataConference()方法加入數(shù)據會議。

     

    代碼示例:
    //Java code
    public int joinDataConf()
    {
        if (null == currentConference)
        {
            Log.e(TAG,  "join data conf failed, currentConference is null ");
            return -1;
        }
    
        int result =  currentConference.joinDataConference();
    
        return result;
    }
    
     

     

  3. SDK在收服務器加入數(shù)據會議響應后,通過TsdkNotify對象中的onEvtJoinDataConfResult()方法向UI上報數(shù)據會議加入結果事件。若成功,則UI刷新界面,提示加入數(shù)據會議成功,若失敗,則提示加入數(shù)據會議失敗。

     

    說明: 

    在加入數(shù)據會議后,通過TsdkNotify對象中的onEvtInfoAndStatusUpdate()方法向UI上報會議信息及狀態(tài)更新事件,UI刷新會議狀態(tài)和成員列表。

    代碼示例:
    //Java code
    public void  handleJoinDataConfResult(TsdkConference tsdkConference, TsdkCommonResult commonResult){
        Log.i(TAG, "handleJoinDataConfResult");
        if ((tsdkConference == null) || (commonResult == null)) {
            return;
        }
        int result = commonResult.getResult();
        mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.JOIN_DATA_CONF_RESULT, result);
    }
    
     

     

注意事項

無。

查詢會議列表

描述

用戶查詢自己“創(chuàng)建”的和“待參加”的預約會議信息。

前提條件

  • 鑒權登錄成功。
  • 會議環(huán)境參數(shù)已設置。

業(yè)務流程

圖3 查詢會議列表流程 
  1. UI調用TsdkConferenceManager對象的queryConferenceList()查詢會議列表,參數(shù)為獲取會議列表信息,參數(shù)類型為TsdkQueryConfListReq類。

     

    說明: 

    在創(chuàng)建TsdkQueryConfListReq對象后,需要從該對象調用方法來設置參數(shù)。

    • 會議權限(confRight),使用setConfRight()方法設置,參考枚舉類ConfctrlConfRight,用于指定要查詢的會議權限類型,包含查詢創(chuàng)建的會議、待參加的會議或創(chuàng)建和待參加的會議,可選填。
    • 指定返回的頁面索引(pageIndex),使用setPageIndex()方法設置,參數(shù)類型為int,取值從1開始,建議與應用程序與會議列表的頁簽對應,必須要有明確值。
    • 指定每頁返回的記錄數(shù)(pageSize),使用setPageSize()方法設置,參數(shù)類型為int,建議與應用程序會議列表個數(shù)相同,必須要有明確值。
    • 是否包含已結束的會議(isIncludeEnd),使用setIsIncludeEnd()方法設置,參數(shù)類型為int。
    • 返回來的時間為UTC時間,UI進行頁面呈現(xiàn)之前需進行時間處理。
    代碼示例:
    //Java code
    public int queryMyConfList(ConfConstant.ConfRight myRight)
    {
        Log.i(TAG, "query my conf list.");
        TsdkConfRight tupConfRight;
        switch (myRight)
        {
            case MY_CREATE:
                tupConfRight = TsdkConfRight.TSDK_E_CONF_RIGHT_CREATE;
                break;
            case MY_JOIN:
                tupConfRight = TsdkConfRight.TSDK_E_CONF_RIGHT_JOIN;
                break;
            case MY_CREATE_AND_JOIN:
                tupConfRight = TsdkConfRight.TSDK_E_CONF_RIGHT_CREATE_JOIN;
                break;
            default:
                tupConfRight = TsdkConfRight.TSDK_E_CONF_RIGHT_CREATE_JOIN;
                break;
        }
        TsdkQueryConfListReq queryReq = new TsdkQueryConfListReq();
        queryReq.setPageSize(ConfConstant.PAGE_SIZE);
        queryReq.setPageIndex(1);    
        queryReq.setIsIncludeEnd(0); 
        queryReq.setConfRight(tupConfRight);
        int result = TsdkManager.getInstance().getConferenceManager().queryConferenceList(queryReq);
        if (result != 0)
        {
            Log.e(TAG, "getConfList result ->" + result);
            return  result;
        }
        return 0;
    }
    
     

     

  2. SDK在收到服務器返回的查詢會議列表響應后,通過TsdkNotify對象中的onEvtQueryConfListResult()方法向UI上報查詢會議列表結果,參數(shù)包括會議列表信息和操作結果。

     

    說明: 
    • 查詢會議列表只返回會議的概要信息,如需查詢會議詳情(包括與會者信息),需要查詢會議詳情。
    • 會議的主席密碼需要查詢會議詳情獲取。
    代碼示例:
    //Java code
    public void handleQueryConfListResult(TsdkCommonResult result, TsdkConfListInfo confList){
        Log.i(TAG, "onGetConfListResult");
        if (result == null)
        {
            Log.e(TAG, "get conference list is failed, unknown error.");
            mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.QUERY_CONF_LIST_FAILED, -1);
            return;
        }
        else if (result.getResult() != 0)
        {
            Log.e(TAG, "get conference list is failed, return ->" + result.getReasonDescription());
            mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.QUERY_CONF_LIST_FAILED, result.getResult());
            return;
        }
        List<ConfBaseInfo> confBaseInfoList = new ArrayList<>();
        List<TsdkConfBaseInfo> tsdkConfBaseInfos = confList.getConfInfoList();
        if (null != tsdkConfBaseInfos) {
            for (TsdkConfBaseInfo confInfo : tsdkConfBaseInfos) {
                ConfBaseInfo confBaseInfo = new ConfBaseInfo();
                confBaseInfo.setSize(confInfo.getSize());
                confBaseInfo.setConfID(confInfo.getConfId());
                confBaseInfo.setSubject(confInfo.getSubject());
                confBaseInfo.setAccessNumber(confInfo.getAccessNumber());
                confBaseInfo.setChairmanPwd(confInfo.getChairmanPwd());
                confBaseInfo.setGuestPwd(confInfo.getGuestPwd());
                confBaseInfo.setSchedulerNumber(confInfo.getScheduserAccount());
                confBaseInfo.setSchedulerName(confInfo.getScheduserName());
                confBaseInfo.setStartTime(confInfo.getStartTime());
                confBaseInfo.setEndTime(confInfo.getEndTime());
                confBaseInfo.setMediaType(ConfConvertUtil.convertConfMediaType(confInfo.getConfMediaType()));
                confBaseInfo.setConfState(ConfConvertUtil.convertConfctrlConfState(confInfo.getConfState()));
                confBaseInfoList.add(confBaseInfo);
            }
        }
        mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.QUERY_CONF_LIST_SUCCESS, confBaseInfoList);
    }
    
     

     

注意事項

無。

查詢會議詳情

描述

用戶查詢指定會議的詳細信息。

前提條件

  • 鑒權登錄成功。
  • 會議環(huán)境參數(shù)已設置。

業(yè)務流程

圖4 查詢會議詳情流程 
  1. UI調用TsdkConferenceManager對象的queryConferenceDetail()方法查詢會議詳情,參數(shù)為獲取會議詳細信息,參數(shù)類型為TsdkQueryConfDetailReq類。

     

    說明: 

    在創(chuàng)建TsdkQueryConfDetailReq對象后,需要從該對象調用方法來設置參數(shù)。

    • 請求與會者列表頁索引,通過setPageIndex()方法設置,取值從1開始,建議與應用程序與會者列表的頁簽對應。
    • 需要查詢的會議ID,通過查詢列表或其他方式獲取。
    • 與會者列表每頁的與會者個數(shù),通過setPageSize()方法設置,建議與應用程序與會者列表個數(shù)相同。
    代碼示例:
    //Java code
    public int queryConfDetail(String confID)
    {
        Log.i(TAG,  "query conf detail");
        TsdkQueryConfDetailReq queryReq = new TsdkQueryConfDetailReq();
        queryReq.setConfId(confID);
        int result = TsdkManager.getInstance().getConferenceManager().queryConferenceDetail(queryReq);
        if (result != 0)
        {
            Log.e(TAG, "getConfInfo result ->" + result);
            return  result;
        }
        return result;
    }
    
     

     

  2. SDK在收到服務器返回的查詢會議詳情響應后,通過TsdkNotify對象中的onEvtQueryConfDetailResult()方法向UI上報查詢結果,參數(shù)包括會議詳情信息和操作結果。

     

    代碼示例:
    //Java code
    public void handleQueryConfDetailResult(TsdkCommonResult result, TsdkConfDetailInfo tsdkConfDetailInfo){
        Log.i(TAG, "onGetConfInfoResult");
        if ((result == null) || (tsdkConfDetailInfo == null))
        {
            Log.e(TAG, "get conference detail is failed, unknown error.");
            mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.QUERY_CONF_DETAIL_FAILED, -1);
            return;
        }
        if (result.getResult() != TupConfParam.CONF_RESULT.TUP_SUCCESS)
        {
            Log.e(TAG, "get conference detail is failed, return ->" + result.getResult());
            mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.QUERY_CONF_DETAIL_FAILED, result.getResult());
            return;
        }
        ConfDetailInfo confDetailInfo = new ConfDetailInfo();
        confDetailInfo.setSize(tsdkConfDetailInfo.getConfInfo().getSize());
        confDetailInfo.setConfID(tsdkConfDetailInfo.getConfInfo().getConfId());
        confDetailInfo.setSubject(tsdkConfDetailInfo.getConfInfo().getSubject());
        confDetailInfo.setAccessNumber(tsdkConfDetailInfo.getConfInfo().getAccessNumber());
        confDetailInfo.setChairmanPwd(tsdkConfDetailInfo.getConfInfo().getChairmanPwd());
        confDetailInfo.setGuestPwd(tsdkConfDetailInfo.getConfInfo().getGuestPwd());
        confDetailInfo.setSchedulerNumber(tsdkConfDetailInfo.getConfInfo().getScheduserAccount());
        confDetailInfo.setSchedulerName(tsdkConfDetailInfo.getConfInfo().getScheduserName());
        confDetailInfo.setStartTime(tsdkConfDetailInfo.getConfInfo().getStartTime());
        confDetailInfo.setEndTime(tsdkConfDetailInfo.getConfInfo().getEndTime());
        confDetailInfo.setMediaType(ConfConvertUtil.convertConfMediaType(tsdkConfDetailInfo.getConfInfo().getConfMediaType()));
        confDetailInfo.setConfState(ConfConvertUtil.convertConfctrlConfState(tsdkConfDetailInfo.getConfInfo().getConfState()));
        List<Member> memberList = ConfConvertUtil.convertAttendeeInfoList(tsdkConfDetailInfo.getAttendeeList());
        confDetailInfo.setMemberList(memberList);
        mConfNotification.onConfEventNotify(ConfConstant.CONF_EVENT.QUERY_CONF_DETAIL_SUCCESS, confDetailInfo);
    }
    
     

     

注意事項

無。