这篇文章,就Android平台上如何集成萤石SDK进行讲解。
前言:
萤石是海康威视集团旗下的一家做视频云的公司。我们接入萤石设备,实现实时预览、远程回放、抓图、切换画质等功能。
关于具体如何接入,包括添加依赖,声明权限等,大家可以参考萤石云开放平台Android SDK使用说明。
我们这篇文章就不对这个进行具体讲解了,下面我们直接上代码,
/**
* Created by Administrator on 2017/8/3.
* 封装的萤石播放库
*/
public class PlayerEZVIZ {
private SurfaceView surfaceView;
private Handler handler;
public EZPlayer ezPlayer_Live, ezPlayer_Playback;
public PlayerEZVIZ(SurfaceView surfaceView, Handler handler) {
this.surfaceView = surfaceView;
this.handler = handler;
}
/**
* 实时预览
* @param deviceSerial 设备序列号
* @param channelNo 通道号
*/
public void live(String deviceSerial, int channelNo) {
if (ezPlayer_Live == null) {
ezPlayer_Live = EZOpenSDK.getInstance().createPlayer(deviceSerial, channelNo); //根据设备序列号和通道号创建播放器(用于实时预览,如果需远程回放,最好再新建一个播放器)
}
ezPlayer_Live.setHandler(handler); //设置消息回调
ezPlayer_Live.setSurfaceHold(surfaceView.getHolder()); //设置显示视图
ezPlayer_Live.startRealPlay(); //开始实时预览
}
/**
* 远程回放
* @param deviceSerial
* @param channelNo
* @param beginYear
* @param beginMonth
* @param beginDay
* @param beginHour
* @param beginMinute
* @param beginSecond
* @param endYear
* @param endMonth
* @param endDay
* @param endHour
* @param endMinute
* @param endSecond
*/
public void playback(String deviceSerial, int channelNo,
int beginYear, int beginMonth, int beginDay, int beginHour, int beginMinute, int beginSecond,
int endYear, int endMonth, int endDay, int endHour, int endMinute, int endSecond) {
if (ezPlayer_Playback == null) {
ezPlayer_Playback = EZOpenSDK.getInstance().createPlayer(deviceSerial, channelNo);
}
Calendar beginCalendar = Calendar.getInstance();
Calendar endCalendar = Calendar.getInstance();
beginCalendar.set(beginYear, beginMonth - 1, beginDay, beginHour, beginMinute, beginSecond);
endCalendar.set(endYear, endMonth - 1, endDay, endHour, endMinute, endSecond);
ezPlayer_Playback.setHandler(handler);
ezPlayer_Playback.setSurfaceHold(surfaceView.getHolder());
ezPlayer_Playback.startPlayback(beginCalendar, endCalendar); //根据开始、结束时间开始远程回放
}
/**
* 获取录像段文件
* @param deviceSerial
* @param channelNo
* @param beginYear
* @param beginMonth
* @param beginDay
* @param beginHour
* @param beginMinute
* @param beginSecond
* @param endYear
* @param endMonth
* @param endDay
* @param endHour
* @param endMinute
* @param endSecond
* @return
*/
public List<EZDeviceRecordFile> getRecordFile(String deviceSerial, int channelNo,
int beginYear, int beginMonth, int beginDay, int beginHour, int beginMinute, int beginSecond,
int endYear, int endMonth, int endDay, int endHour, int endMinute, int endSecond) {
List<EZDeviceRecordFile> recordList = null;
Calendar beginCalendar = Calendar.getInstance();
Calendar endCalendar = Calendar.getInstance();
beginCalendar.set(beginYear, beginMonth - 1, beginDay, beginHour, beginMinute, beginSecond);
endCalendar.set(endYear, endMonth - 1, endDay, endHour, endMinute, endSecond);
try {
recordList = EZOpenSDK.getInstance().searchRecordFileFromDevice(deviceSerial, channelNo, beginCalendar, endCalendar);
} catch (BaseException e) {
e.printStackTrace();
}
return recordList;
}
/**
* 停止实时预览
*/
public void stopLive() {
if (ezPlayer_Live != null) {
ezPlayer_Live.stopRealPlay();
}
}
/**
* 停止远程回放
*/
public void stopPlayback() {
if (ezPlayer_Playback != null) {
ezPlayer_Playback.stopPlayback();
}
}
}
这个类是已经封装好的可以直接拿去用的。这里做以下说明:
在PlayerEZVIZ 中,我们没有介绍如何进行抓图,以及如何切换画质,其实很简单,
抓图:
直接调用EZPlayer的capturePicture方法就可以了。
切换画质:
直接调用EZOpenSDK的setVideoLevel(String deviceSerial, int cameraNo, int videoLevel)就可以了。
videoLevel: 0-流畅;1-均衡;2-高品质。