录制
更新时间:2020-12-11
- 录制的相关接口是在com.baidu.ugc.record.RecordManager类里,包括录制、美颜、贴纸和滤镜
初始化接口
设置预览画面
void setGLSurfaceView(GLSurfaceView view)
初始化录像机
void init(RecordManager.ICamera cameraManager, int cameraFrameRate, int videoBitrate, boolean isCameraFront, java.lang.String outputDir, java.lang.String arDataPath)
数据加载
void loadData(RecordManager.OnDataLoadCallback listener)
注意:在实例化new RecordManager(this, appid)需要传人自己的appid(即用户申请的licenseID),否则无法通过鉴权;
可通过修改配置文件com.baidu.smartminivideo.capture.shoot.config.Config.java中的LICENSE_APPID进行appid的修改; 若未申请授权,请参考快速接入
生命周期方法
初始化 -> resume -> pause -> destroy
停止预览:一般在在Activit的onStop时调用
void pause()
开始预览:一般在Activity的onStart时调用
void resume()
对象销毁,销毁后需要重新创建对象
void destroy()
相机设置
获取到摄像头的状态
boolean isFrontCamera()
相机的当前摄像头是否正在处于预览中
boolean isPreviewing()
设置前后摄像头
protected void setCameraFace(boolean front)
相机尺寸,默认720P,如果摄像头不支持,那么会取相近比例的尺寸
void setCameraSize(int w, int h)
相机切换前后摄像头
void switchCamera()
录制与停止录制
录制
获取当前录制视频的完整路径
String getVideoAbsoluteFile()
是否为正在录制
boolean isRecording()
设定视频输出目录
boolean setVideoPath(java.lang.String videoFileDir)
开始录制
boolean startRecording()
停止录制
boolean stopRecording()
美颜设置
- 美颜设置接口,代码示例如下:
//调整美颜程度
void setBeauty(float v) //参数0.0f不美颜
//调整美白程度
void setBeautyWhite(float value)
//调整磨皮程度
void setBeautyBlure(float value)
//调整大眼程度
void setEnlargeEye(float value)
//调整瘦脸程度
void setCheekThin(float value)
- 注意:使用高级美颜时,需要申请对应权限,免费版本不支持此功能
滤镜设置
设置滤镜
void setFilter(Filter filter)
滤镜参数
void setFilterLevel(float v)
贴纸设置
设置贴纸道具
void setStickerEffect(Sticker sticker, java.lang.String tabName)
下载贴纸
- 【v3.0】版本后,贴纸采用后下载方式使用,开通license的同时可以在Console购买或选择贴纸信息;
- Console地址跳转:跳转Console
- 使用贴纸涉及两个接口,获取贴纸列表信息、贴纸文件下载使用。
一、获取贴纸列表信息,即用于产品贴纸展示,建议开发者提前获取贴纸列表,可缓存,减少用户等待。下方获取贴纸列表数据实例代码:
1:调用加载贴纸列表数据
相关类:com.baidu.smartminivideo.capture.sticker.helper.LoadSticker
public void loadStickerDatas() {
String appId = Config.LICENSE_APPID;
String sdkVersion = Config.sdkVersion;
DownStickerHelper loadStickerHelper = new DownStickerHelper(SmartminivideoApplication.getContext(),
appId, sdkVersion);
loadStickerHelper.loadStickerList(this);
}
2:在第一步调用之后,会回调两个方法,将贴纸数据字符串传输回来
成功回调:
@Override
public void onListSuccess(String stickerList) {}
失败回调:
@Override
public void onFail(String msg) {}
二、贴纸文件下载使用。即用户选择某个贴纸后,下载贴纸并且加载使用。注:部分贴纸还会涉及模型下载,见下方实例代码:
1:调用加载单个贴纸数据
相关类:com.baidu.smartminivideo.capture.sticker.helper.LoadSticker
public void loadOneSticker(String faceId) {
String appId = Config.LICENSE_APPID;
String sdkVersion = Config.sdkVersion;
DownStickerHelper loadStickerHelper = new DownStickerHelper(SmartminivideoApplication.getContext(),
appId, sdkVersion);
loadStickerHelper.loadOneStickerList(Long.parseLong(faceId), this);
}
2:在第一步调用之后,会回调两个方法,将单个贴纸数据字符串传输回来
成功回调:
@Override
public void onOneSuccess(String sticker) {}
失败回调:
@Override
public void onFail(String msg) {}
3:在第3步回调之后,若成功获取单个贴纸数据,则将继续下载贴纸文件,见下方实例代码:
具体可查看demo工程中相关类:
com.baidu.smartminivideo.capture.sticker.StickerAdapter
com.baidu.smartminivideo.capture.beautify.StickerDownloadManager
StickerDownloadManager.download(item, new StickerDownloadManager.OnStickerDownloadCallback<FuFaceItem>() {
@Override
public void onStarted(FuFaceItem tag) {
holder.startLoadingAnim();
}
@Override
public void onProgress(FuFaceItem tag, long finished, long total, int progress) {
}
@Override
public void onCompleted(FuFaceItem faceItem) {
if (mLastClickIndex != position) {
notifyDataSetChanged();
return;
}
mSelectedIndex = position;
notifyDataSetChanged();
if (mListener != null) {
mListener.onSelectSticker(item, faceItem.getFilePath());
}
}
@Override
public void onFailed(FuFaceItem faceItem, int what, int ext, String msg) {
Log.e("StickerAdapter", "onFailed:" + faceItem.name
+ ", what:" + what + ", ext:" + ext + ", msg:" + msg);
notifyDataSetChanged();
}
});
}