SkeyeVSS综合安防监控录像回放下载功能实现源码
发布时间:2022-11-19 15:32:40 486 相关标签: # 服务器# 数据# 服务器# 监控# 设备
SkeyeVSS综合安防视频云服务通过接入SkeyeRMS录像服务器实现对系统里的摄像机等设备录像,通过配置录像模板,对所配置的录像时间段产生的视频数据进行存储,方便下载管理。
1.判断当前设备是否有录像数据产生:如图:上面的图标表示设备已经配置了录像计划,点击图标加载对应设备的录像数据列表。

2.展示录像列表
(1)根据时间查询(开始与结束时间之间的录像数据)
let startTime = moment(this.listQuery.date).format('YYYYMMDDT000000');
let endTime = moment(this.listQuery.date).format('YYYYMMDDT235959');
(2)展示列表 如图:(包含设备名称、日期、时间、每段录像时长)

3.录像下
载列表 (将过长的录像进行拆分)
当一段录像数据的时长超过30分钟,数据就可能达到几百上千兆,将采用分段下载,这样可以减小单个录像数据体积,避免下载等待时间过长,将每段录像时长控制在30分钟以内,下载的等待时间稍短。
let startTime = moment.duration(row.time.split('-')[0]).asMilliseconds()
let endTime = moment.duration(row.time.split('-')[1]).asMilliseconds()
let total = moment.duration(endTime - startTime).asMilliseconds()
let interval = 30 * 60 * 1000
let paragraph = Math.floor(total / interval)
let moreThan = total % interval
let arr = []
for (let i = 0; i < paragraph; i++) {
arr.push({
name: row.name,
date: row.date,
indexCode: row.indexCode,
time: row.time,
duration: moment.utc(interval).format('HH:mm:ss'),
start: moment(Number(moment(row.date).format('x')) + startTime + i * interval).format('HH:mm:ss'),
end: moment(Number(moment(row.date).format('x')) + startTime + i * interval + interval).format('HH:mm:ss'),
startstamp: Number(moment(row.date).format('x')) + startTime + i * interval,
endstamp: Number(moment(row.date).format('x')) + startTime + i * interval + interval,
})
}
if (moreThan) {
arr.push({
name: row.name,
date: row.date,
indexCode: row.indexCode,
time: row.time,
duration: moment.utc(moreThan).format('HH:mm:ss'),
start: moment(Number(moment(row.date).format('x')) + startTime + paragraph * interval).format('HH:mm:ss'),
end: moment(Number(moment(row.date).format('x')) + startTime + paragraph * interval + moreThan).format('HH:mm:ss'),
startstamp: Number(moment(row.date).format('x')) + startTime + paragraph * interval,
endstamp: Number(moment(row.date).format('x')) + startTime + paragraph * interval + moreThan,
})
}

4.录像下载
通过传入下载对应参数 (名称、开始时间、结束时间)
let url = `${location.protocol}//${serverIp}:${serverPort}/DownloadRecord_${row.name}_${startTime}.ts?indexCode=${row.indexCode}&startTime=${startTime}&endTime=${endTime}`
downloadFile(url, name) {
//创建下载
const doma = document.createElement('a');
document.body.append(doma)
doma.href = url;
doma.download = name
doma.rel = 'noopener noreferrer'
doma.click();
document.body.removeChild(doma)
},
文章来源: https://blog.51cto.com/openskeye/5851681
特别声明:以上内容(图片及文字)均为互联网收集或者用户上传发布,本站仅提供信息存储服务!如有侵权或有涉及法律问题请联系我们。
举报