多应用+插件架构,代码干净,二开方便,首家独创一键云编译技术,文档视频完善,免费商用码云13.8K 广告
### **开始录制** int startRecord(AnyChatRecordOpt recordOpt,AnyChatRecordEvent recordEvent) #### 接口说明: 开始录制,录像可以录制单方视频流,也可以录制多方视频流。 #### 返回值: 录制操作返回的状态码(0代表录制成功 ) #### 接口参数简介 : | 名称 |类型 |说明 |是否必须 | | --- | --- | --- | --- | | recordOpt| AnyChatRecordOpt | 录制配置类 | 是| | recordEvent| AnyChatRecordEvent | 录制结果回调事件 | 是| ### **开始录制(主要用于录像状态检测)** int startRecord(AnyChatRecordOpt recordOpt,AnyChatRecordNotifyEvent notifyEvent,AnyChatRecordEvent recordEvent) #### 接口说明: 开始录制,主要用于服务器录制、服务器合成流录制时,检测录像状态是否正常。 #### 返回值: 录制操作返回的状态码(0代表录制成功 ) #### 接口参数简介 : | 名称 |类型 |说明 |是否必须 | | --- | --- | --- | --- | | recordOpt| AnyChatRecordOpt | 录制配置类 | 是| | notifyEvent| AnyChatRecordNotifyEvent| 录像状态回调(针对服务器录制、服务器合成流) | 是| | recordEvent| AnyChatRecordEvent | 录制结果回调事件 | 是| AnyChatRecordOpt录制配置类简介: | 名称 |类型 |说明 |是否必须 | | --- | --- | --- | --- | | userID | int | 用户id | 是 | | recordLayoutOpt | AnyChatRecordLayoutOpt | 录制画面布局配置类 | 是 | | width | int | 录制画面宽度 | 否 | | height | int | 录制画面高度 | 否 | | mode | int | 录制模式<br>BRAC_RECORD_LOCAL_MODE--本地录制(默认)<br>BRAC_RECORD_SERVER_MODE --服务器端录制 <br> BRAC_RECORD_STREAM_MODE --服务器端合成流录制 |否 | | content | int | 录制内容<br>BRAC_RECORD_DEFAULT_CONTENT--既录音又录像(默认) <br>BRAC_RECORD_AUDIO--只录音 <br>BRAC_RECORD_VIDEO--只录像 | 否 | | fileType | int | 录制文件类型<br>BRAC_RECORD_FILE_TYPE_MP4-- MP4(默认) <br> BRAC_RECORD_FILE_TYPE_WMV—WMV <br>BRAC_RECORD_FILE_TYPE_FLV-- FLV <br> BRAC_RECORD_FILE_TYPE_MP3-- MP3| 否| | fileName | String | 录制文件名 | 否 | | category | String | 设置录像文件保存目录(针对服务器录制有效) | 否 | | localFilePath | String | 本地录制文件存放目录 | 否 | | encryptionKey | String | 本地录制文件加密的密钥 <br>为空不加密,传了密钥普通加密 | 否 | | recordClipMode| int | 裁剪模式<br>BRAC_RECORD_CLIPMODE_UNKNOW--未知模式,不需要做裁剪时使用<br>BRAC_RECORD_CLIPMODE_AUTO--以最大比例进行裁剪,然后再整体拉伸,画面保持比例,但被裁剪画面较大 <br> BRAC_RECORD_CLIPMODE_OVERLAP--重叠模式,只取最大有效部分,对边缘进行裁剪 <br>BRAC_RECORD_CLIPMODE_SHRINK--缩小模式,缩小到合适的比例,不进行裁剪 <br>BRAC_RECORD_CLIPMODE_STRETCH--平铺模式,不进行裁剪,但可能导致画面不成比例 <br> | statusnotify | int | 录像状态回调通知时间设置,默认时间为10秒(针对服务器录制、服务器合成流录制有效) | 否 | | videobitrate | int| 录制视频码率 单位:bps| 否 | | audiobitrate | int| 录制音频码率 单位:bps| 否 | | fps| int| 录像帧率| 否 | | channels| int| 录制音频通道: 1 单通道, 2双通道| 否 | | isOpenMD5 | boolean|录像完成回调是否返回文件MD5值| 否 | | isStrict | boolean | 是否打开非严格模式,默认情况下,SDK录制在遇到没有音视频设备,或者打开设备失败的情况下,会自动终止录制任务,返回录制失败,错误码如723、724等,如需继续录制任务,则将此属性设置为false。| 否 | | isDealException | boolean | 是否由上层处理异常,默认情况下,SDK在检测到录像任务异常时,会自动终止该录制任务。但有些场合需要由上层应用来处理,比如APP切换到了后台,此时SDK会检测到录像传输中断(errorcode:728)或者视频编码异常(errorcode:730),如果需要APP自行决定何时结束录制任务,则将此属性设置为true。| 否 | AnyChatRecordLayoutOpt 录制画面布局配置类简介: | 返回值 | 名称 |说明 |备注 | | --- | --- | --- | --- | | recordlayout| int | 视频布局,视频流数量,即多少个视频画面| 是| | layoutstyle| int | 三路流和四路流的视频画面布局风格:0-并列风格(默认) ,1-画中画风格,2-三画面并列风格| 否 | streamlist | List | 录制对象AnyChatRecordStreamOpt的list集合。<br>AnyChatRecordStreamOpt对象包含三个属性:<br>1、userID(String)录制对象ID<br>2、streamIndex(int):录制对象的视频流号,移动端默认为0;<br>3、recordIndex(int):录制对象在录制视频上的位置 | 否 | AnyChatRecordNotifyEvent回调简介: | 返回值 | 名称 |说明 |备注 | | --- | --- | --- | --- | | void | onRecordStatusDone| result(AnyChatResult): 操作状态信息<br>JsonData(JSONObject):返回结果 | result.errCode: 0表示成功<br>其他表示错误代号.<br>result.msg: 错误描述| AnyChatRecordEvent回调简介: | 返回值 | 名称 |说明 |备注 | | --- | --- | --- | --- | | void | onRecordPrepare | result(AnyChatResult): 操作状态信息<br>JsonData(JSONObject):返回结果 | result.errCode: 0表示成功<br>其他表示错误代号.<br>result.msg: 错误描述.<br>JsonData.userId:用户id<br>JsonData.status:录像状态,值为 "prepare" <br>JsonData.statuscode:录像状态,1为prepare| | void | onRecordStart | result(AnyChatResult): 操作状态信息<br>JsonData(JSONObject):返回结果 | result.errCode: 0表示成功<br>其他表示错误代号.<br>result.msg: 错误描述.<br>JsonData.userId:用户id<br>JsonData.status:录像状态,值为 "start"<br>JsonData.statuscode:录像状态, 2为start| | void | onRecordDone | result(AnyChatResult): 操作状态信息<br>JsonData(JSONObject):返回结果 | result.errCode: 0表示成功<br>其他表示错误代号.<br>result.msg: 错误描述.<br>JsonData.filePath:录像文件地址<br>JsonData.elapse:录像文件时长<br>JsonData.startTime:录像开始时间<br>JsonData.endTime:录像结束时间<br>JsonData.filemd5:录像md5| 示例代码 public int startRecord() { AnyChatRecordOpt recordOpt = new AnyChatRecordOpt(); recordOpt.setMode(AnyChatRecordMode.BRAC_RECORD_LOCAL_MODE);// 设置为本地录制 if (null != flePath) { recordOpt.setLocalFilePath(flePath + "/record");// 设置本地存储路径 } recordOpt.setRecordClipMode(AnyChatRecordClipMode.BRAC_RECORD_CLIPMODE_AUTO);// 设置裁剪模式 recordOpt.setUserID(-1); recordOpt.setContent(AnyChatRecordContent.BRAC_RECORD_DEFAULT_CONTENT);// 设置既录音又录像 List<AnyChatRecordStreamOpt> streamlist = new ArrayList<AnyChatRecordStreamOpt>(); AnyChatRecordStreamOpt recordEntity = new AnyChatRecordStreamOpt(); recordEntity.setUserID(-1); //设置录制对象的视频流号 recordEntity.setStreamindex(0); //设置录制对象在录制画面上的位置 recordEntity.setRecordindex(0); streamlist.add(recordEntity); AnyChatRecordStreamOpt recordEntity_1 = new AnyChatRecordStreamOpt(); recordEntity_1.setUserID(dwTargetUserId); //设置录制对象的视频流号 recordEntity_1.setStreamindex(0); //设置录制对象在录制画面上的位置 recordEntity_1.setRecordindex(1); streamlist.add(recordEntity_1); //设置图片水印参数信息 recordOpt.setImagepath(picPath); String fileName = "" + System.currentTimeMillis(); recordOpt.setFileName(fileName); AnyChatRecordLayoutOpt anyChatRecordLayoutOpt = new AnyChatRecordLayoutOpt(); anyChatRecordLayoutOpt.setRecordlayout(2); anyChatRecordLayoutOpt.setStreamlist(streamList); recordOpt.setAnyChatRecordLayoutOPt(anyChatRecordLayoutOpt); return AnyChatSDK.getInstance().startRecord(recordOpt, this); }