138 lines
4.0 KiB
JavaScript
138 lines
4.0 KiB
JavaScript
import { loginUser } from "../../../public/js/url.js";
|
||
import { currentEventData } from "./orgApi/getAlarmEventList.js";
|
||
import { mqttUrl } from "../../../public/js/url.js";
|
||
import { deviceHash } from "../api/moveDeviceWebsocket.js";
|
||
var currentVideoPage={};//保存当前页面打开的视频
|
||
var currentStation="";
|
||
function openMoveDeviceVideo(deviceArr){
|
||
var deviceidArr=[];
|
||
for(let i=0;i<deviceArr.length;i++){
|
||
var deviceid=deviceArr[i]["deviceid"];
|
||
if(deviceid in deviceHash){
|
||
var status=deviceHash[deviceid]["status"];
|
||
if(status=="online"){
|
||
deviceidArr.push(deviceid);
|
||
}
|
||
}
|
||
}
|
||
currentStation=currentEventData["station"];
|
||
createVideoOpenData(deviceidArr);
|
||
currentPageOpenVideo(deviceidArr);
|
||
}
|
||
|
||
function createVideoOpenData(deviceidArr){
|
||
var videoCallObj={
|
||
"rtmpflag":0,
|
||
"camera":1,
|
||
"rotation":0
|
||
}
|
||
var rtmObj=getRtmData("videocall",JSON.stringify(videoCallObj),deviceidArr);
|
||
//发送开启视频的指令
|
||
sendMqttData(rtmObj);
|
||
}
|
||
|
||
//发送mqqt接口数据
|
||
function sendMqttData(obj){
|
||
|
||
var mqttObj={
|
||
"topic":`${currentStation}/ter_cmd`,
|
||
"message":JSON.stringify(obj)
|
||
}
|
||
return axios({
|
||
method: 'post',
|
||
url:mqttUrl,
|
||
data: mqttObj
|
||
})
|
||
}
|
||
|
||
function getRtmData(title,data,receiver){
|
||
return {
|
||
"title":title,
|
||
"sender":loginUser,
|
||
"department":"",
|
||
"scope":"",
|
||
"receiver":receiver,
|
||
"video":"",
|
||
"rtm":(new Date().getTime()).toString(),
|
||
"data":data,
|
||
"userScope":"",
|
||
"userBragide":"",
|
||
"userDetachchment":"",
|
||
"userBorough":"",
|
||
"name":"web",
|
||
}
|
||
}
|
||
|
||
//当前页面打开视频
|
||
function currentPageOpenVideo(deviceArr){
|
||
setTimeout(()=>{
|
||
|
||
var urlArr=[];
|
||
|
||
for(let i=0;i<deviceArr.length;i++){
|
||
var deviceid=deviceArr[i];
|
||
if(deviceid in deviceHash){
|
||
let showname=deviceHash[deviceid]["showname"];
|
||
let station=deviceHash[deviceid]["station"];
|
||
let power=0;
|
||
let url=`./rtc/deviceAlarmVideo.html?id=${deviceid}&power=${power}&mdDeviceName=${encodeURI(encodeURI(showname))}&station=${encodeURI(encodeURI(station))}&username=${loginUser}`;
|
||
urlArr.push(url);
|
||
$(`.videoMonitor>div:nth-child(${i+1})`).attr("deviceid",deviceid)
|
||
}
|
||
}
|
||
urlArr.forEach((item,index)=>{
|
||
$(`.videoMonitor>div:nth-child(${index+1})`).html(`<iframe src='${item}'></iframe>`);
|
||
|
||
})
|
||
|
||
console.log(urlArr);
|
||
|
||
|
||
|
||
},1500)
|
||
}
|
||
|
||
//单独打开视频
|
||
function aloneOpenVideo(obj){
|
||
let deviceid=obj["deviceid"];
|
||
let showname=obj["showname"];
|
||
let station=obj["station"];
|
||
currentStation=station;
|
||
let power=0;
|
||
let url=`./rtc/moveDeviceVideoOne.html?id=${deviceid}&power=${power}&mdDeviceName=${encodeURI(encodeURI(showname))}&station=${encodeURI(encodeURI(station))}&username=${loginUser}`;
|
||
createVideoOpenData([obj["deviceid"]])
|
||
window.open(url,'',"width=1280,height=720,top=0,left=0,status='no',location='no',resizable='no',toolbar='no'");
|
||
}
|
||
|
||
//监听iframe过来的数据,改变页面
|
||
window.addEventListener('message', function(e) {
|
||
var data=e.data
|
||
var cmd=data["cmd"];
|
||
var deviceid=data["deviceid"];
|
||
if(cmd=="closePage"){
|
||
var mdiv= $(`.videoMonitor>div`);
|
||
for(var i=0;i<mdiv.length;i++){
|
||
var tmdev=mdiv[i];
|
||
if($(tmdev).attr("deviceid")==deviceid){
|
||
$(tmdev).html(`<div><img src="./pages/cmddispatch/image/play.png" alt=""></div>`)
|
||
}
|
||
}
|
||
}
|
||
})
|
||
|
||
|
||
function sendCloseVideo(deviceid){
|
||
var videoCallObj={
|
||
"rtmpflag":0,
|
||
"camera":1,
|
||
"rotation":0
|
||
}
|
||
var rtmObj=getRtmData("videoclose",JSON.stringify(videoCallObj),[deviceid]);
|
||
//发送开启视频的指令
|
||
sendMqttData(rtmObj);
|
||
}
|
||
|
||
export {
|
||
openMoveDeviceVideo,
|
||
aloneOpenVideo
|
||
} |