</div>
<div class="main-right">
<div class="contentRight" id="chart\_index" style="height:100%;display:none;">
<div class="chatData" id="dataCenterRightContent" style="height:calc(100% - 20px)">
<div class="block-header">
<div class="container">
<div>
<div class="left">
<div class="left\_\_bg"></div>
</div>
<div class="right">
<div class="right\_\_bg1"></div>
<div class="right\_\_bg2"></div>
<div class="right\_\_bg3"></div>
</div>
</div>
</div>
<img class="icon" src="../img/block-header-arrow.png" />
<div class="title" v-text="title">设备总览</div>
</div>
<div class="chatContent" id="index\_chart" style="height:130px"></div>
<div class="chatContent" id="index\_1" style="height:calc(100% - 170px); margin-top:10px; overflow-y: auto;">
</div>
</div>
</div>
<div class="contentRight" id="chart\_door" style="display:none;">
<div class="chatData">
<div class="block-header">
<div class="container">
<div>
<div class="left">
<div class="left\_\_bg"></div>
</div>
<div class="right">
<div class="right\_\_bg1"></div>
<div class="right\_\_bg2"></div>
<div class="right\_\_bg3"></div>
</div>
</div>
</div>
<img class="icon" src="../img/block-header-arrow.png" />
<div class="title" v-text="title">智能门禁系统</div>
</div>
<div class="chatContent" id="door\_1"></div>
</div>
<div class="chatData">
<div class="block-header">
<div class="container"><div><div class="left"><div class="left\_\_bg"></div></div><div class="right"><div class="right\_\_bg1"></div><div class="right\_\_bg2"></div><div class="right\_\_bg3"></div></div></div></div><img class="icon" src="../img/block-header-arrow.png" /><div class="title" v-text="title">
楼层设备总览
</div>
</div>
<div class="chatContent" id="door\_2">
<div class="doorLi\_Div">
<div class="doorLi\_DivTop">
<font class="doorLi\_DivTopName">3号梯</font>
<font class="doorLi\_DivTopState">在线</font>
</div>
<div class="doorLi\_DivBottom">
<img class="doorLi\_DivBottomImg" src="../img/pics/icons/doorPic.png" />
<div class="doorLi\_divBtn1">
<font style="float:left;">门禁开关:</font>
<div class="doorLi\_openClose">开</div>
</div>
<div class="doorLi\_divBtn2">
查看进出记录
</div>
</div>
</div>
</div>
</div>
</div>
<div class="contentRight" id="chart\_video" style="display:none;">
<div class="chatData">
<div class="block-header">
<div class="container">
<div>
<div class="left">
<div class="left\_\_bg"></div>
</div>
<div class="right">
<div class="right\_\_bg1"></div>
<div class="right\_\_bg2"></div>
<div class="right\_\_bg3"></div>
</div>
</div>
</div>
<img class="icon" src="../img/block-header-arrow.png" />
<div class="title" v-text="title">视频系统</div>
</div>
<div class="chatContent" id="video\_1"></div>
</div>
<div class="chatData">
<div class="block-header">
<div class="container"><div><div class="left"><div class="left\_\_bg"></div></div><div class="right"><div class="right\_\_bg1"></div><div class="right\_\_bg2"></div><div class="right\_\_bg3"></div></div></div></div><img class="icon" src="../img/block-header-arrow.png" /><div class="title" v-text="title">
楼层设备总览
</div>
</div>
<div class="chatContent" id="video\_2">
</div>
</div>
</div>
<div class="contentRight" id="chart\_TV" style="display:none;">
<div class="chatData">
<div class="block-header">
<div class="container"><div><div class="left"><div class="left\_\_bg"></div></div><div class="right"><div class="right\_\_bg1"></div><div class="right\_\_bg2"></div><div class="right\_\_bg3"></div></div></div></div><img class="icon" src="../img/block-header-arrow.png" /><div class="title" v-text="title">
信息发布系统
</div>
</div>
<div class="chatContent" id="TV\_1"></div>
</div>
<div class="chatData">
<div class="block-header">
<div class="container"><div><div class="left"><div class="left\_\_bg"></div></div><div class="right"><div class="right\_\_bg1"></div><div class="right\_\_bg2"></div><div class="right\_\_bg3"></div></div></div></div><img class="icon" src="../img/block-header-arrow.png" /><div class="title" v-text="title">
楼层设备总览
</div>
</div>
<div class="chatContent" id="TV\_2">
<div class="TVLi\_Div">
<div class="TVLi\_DivTop">
<font class="TVLi\_DivTopName">3号梯</font>
<font class="TVLi\_DivTopState">在线</font>
</div>
<div class="TVLi\_DivBottom">
<img class="TVLi\_DivBottomImg" src="../img/pics/icons/tvPic.png" />
<div class="TVLi\_divBtn1">
<font style="float:left;">设备开关:</font>
<div class="TVLi\_openClose">开</div>
</div>
<div class="TVLi\_divBtn3">
<table style="width:100%;">
<tr>
<td>
<img src="../img/pics/icons/voiceBtn2.png" style="width:25px;height:25px;" />
</td>
<td>
<img src="../img/pics/icons/restartBtn2.png" style="width:25px;height:25px;" />
</td>
</tr>
<tr><td>设置音量</td><td>设备重启</td></tr>
</table>
</div>
<div class="TVLi\_divBtn2">
查看发布内容
</div>
</div>
</div>
</div>
</div>
</div>
<div class="contentRight" id="chart\_lift" style="display:none;">
<div class="chatData">
<div class="block-header">
<div class="container"><div><div class="left"><div class="left\_\_bg"></div></div><div class="right"><div class="right\_\_bg1"></div><div class="right\_\_bg2"></div><div class="right\_\_bg3"></div></div></div></div><img class="icon" src="../img/block-header-arrow.png" /><div class="title" v-text="title">
智能电梯系统
</div>
</div>
<div class="chatContent" id="lift\_1"></div>
</div>
<div class="chatData">
<div class="block-header">
<div class="container"><div><div class="left"><div class="left\_\_bg"></div></div><div class="right"><div class="right\_\_bg1"></div><div class="right\_\_bg2"></div><div class="right\_\_bg3"></div></div></div></div><img class="icon" src="../img/block-header-arrow.png" /><div class="title" v-text="title">
电梯内实时监控
</div>
</div>
<div class="chatContent" id="lift\_2">
<!--<table style="width:360px;margin-left:40px;">
<tr>
<td>
<video id="lift\_video1" muted playsinline controls style="width:360px; height:240px;"></video>
<div class="indexVideoContent" style="width:360px;">
<font id="lift\_video1\_title" class="indexVideoTitle">电梯实时监控1</font>
</div>
</td>
</tr>
<tr>
<td>
<video id="lift\_video2" muted playsinline controls style="width:360px; height:240px;"></video>
<div class="indexVideoContent" style="width:360px;">
<font id="lift\_video2\_title" class="indexVideoTitle">电梯实时监控2</font>
</div>
</td>
</tr>
</table>-->
<div class="liftLi\_Div">
<div class="liftLi\_DivTop">
<font class="liftLi\_DivTopName" id="lift\_title\_1">1号梯</font>
<font class="liftLi\_DivTopState">在线</font>
</div>
<div class="liftLi\_DivBottom">
<img class="liftLi\_DivBottomImg" src="../img/pics/icons/liftPic.png" />
<img class="liftLi\_DivBottomImgState" src="../img/pics/icons/liftUp.png" />
<font class="liftLi\_DivBottomFloor">8<font class="liftLi\_DivBottomFloorUnit"> F</font></font>
<div class="liftLi\_divBtn1" id="lift\_showVideoBtn\_1" onclick="indexPage.showVideoWin(0)">
查看电梯监控
</div>
<div class="liftLi\_divBtn2">
查看使用记录
</div>
</div>
</div>
<div class="liftLi\_Div">
<div class="liftLi\_DivTop">
<font class="liftLi\_DivTopName" id="lift\_title\_2">2号梯</font>
<font class="liftLi\_DivTopState">在线</font>
</div>
<div class="liftLi\_DivBottom">
<img class="liftLi\_DivBottomImg" src="../img/pics/icons/liftPic.png" />
<img class="liftLi\_DivBottomImgState" src="../img/pics/icons/liftUp.png" />
<font class="liftLi\_DivBottomFloor">8<font class="liftLi\_DivBottomFloorUnit"> F</font></font>
<div class="liftLi\_divBtn1" onclick="indexPage.showVideoWin(1)">
查看电梯监控
</div>
<div class="liftLi\_divBtn2">
查看使用记录
</div>
</div>
</div>
</div>
</div>
</div>
<div class="contentRight" id="chart\_fire" style="display:none;">
<div class="chatData">
<div class="block-header">
<div class="container"><div><div class="left"><div class="left\_\_bg"></div></div><div class="right"><div class="right\_\_bg1"></div><div class="right\_\_bg2"></div><div class="right\_\_bg3"></div></div></div></div><img class="icon" src="../img/block-header-arrow.png" /><div class="title" v-text="title">
智慧消防系统
</div>
</div>
<div class="chatContent" id="fire\_1"></div>
</div>
<div class="chatData">
<div class="block-header">
<div class="container"><div><div class="left"><div class="left\_\_bg"></div></div><div class="right"><div class="right\_\_bg1"></div><div class="right\_\_bg2"></div><div class="right\_\_bg3"></div></div></div></div><img class="icon" src="../img/block-header-arrow.png" /><div class="title" v-text="title">
楼层设备总览
</div>
</div>
<div class="chatContent" id="fire\_2">
<div class="fireLi\_Div">
<div class="fireLi\_DivTop">
<font class="fireLi\_DivTopName">3号梯</font>
<font class="fireLi\_DivTopState">在线</font>
</div>
<div class="fireLi\_DivBottom">
<img class="fireLi\_DivBottomImg" src="../img/pics/icons/fireControlPic.png" />
<div class="fireLi\_divBtn2">
查看报警记录
</div>
<div class="fireLi\_divBtn1">
<font style="float:left;">位置:检验科门口</font>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="contentRight" id="chart\_environment" style="display:none;">
<div class="chatData">
<div class="block-header">
<div class="container"><div><div class="left"><div class="left\_\_bg"></div></div><div class="right"><div class="right\_\_bg1"></div><div class="right\_\_bg2"></div><div class="right\_\_bg3"></div></div></div></div><img class="icon" src="../img/block-header-arrow.png" /><div class="title" v-text="title">
环境监测系统
</div>
</div>
<div class="chatContent" id="environment\_1"></div>
</div>
<div class="chatData">
<div class="block-header">
<div class="container"><div><div class="left"><div class="left\_\_bg"></div></div><div class="right"><div class="right\_\_bg1"></div><div class="right\_\_bg2"></div><div class="right\_\_bg3"></div></div></div></div><img class="icon" src="../img/block-header-arrow.png" /><div class="title" v-text="title">
楼层设备总览
</div>
</div>
<div class="chatContent" id="environment\_2">
<div class="fireLi\_Div">
<div class="fireLi\_DivTop">
<font class="fireLi\_DivTopName" title=""></font>\\
<font class="fireLi\_DivTopState"></font>
</div>
<div class="fireLi\_DivContent">
<div class="fireLi\_DivMete">
<div class="fireLi\_DivMeteName">
温度:
</div>
<div class="fireLi\_DivMeteValue">
26.5℃
</div>
</div>
</div>
<div class="fireLi\_DivBottom">
<div class="fireLi\_divBtn1">
<font style="float:left;">位置:</font>
<font style="float:left;">啊是犯法的事</font>
</div>
<div class="fireLi\_divBtn2" onclick="indexPage.showEDevAlarmListByDev()">
查看报警记录
</div>
</div>
</div>
</div>
</div>
</div>
<div class="contentRight" id="chart\_radio" style="display:none;">
<div class="chatData">
<div class="block-header">
<div class="container"><div><div class="left"><div class="left\_\_bg"></div></div><div class="right"><div class="right\_\_bg1"></div><div class="right\_\_bg2"></div><div class="right\_\_bg3"></div></div></div></div><img class="icon" src="../img/block-header-arrow.png" /><div class="title" v-text="title">
智能广播系统
</div>
</div>
<div class="chatContent" id="radio\_1"></div>
</div>
<div class="chatData">
<div class="block-header">
<div class="container"><div><div class="left"><div class="left\_\_bg"></div></div><div class="right"><div class="right\_\_bg1"></div><div class="right\_\_bg2"></div><div class="right\_\_bg3"></div></div></div></div><img class="icon" src="../img/block-header-arrow.png" /><div class="title" v-text="title">
楼层设备总览
</div>
</div>
<div class="chatContent" id="radio\_2">
</div>
</div>
</div>
</div>
<div id="fourBtns" class="btns\_four">
<div id="indexBtn" class="btn\_li action">主楼</div>
<div id="sbfBtn" class="btn\_li">设备房</div>
<div id="xzldbBtn" class="btn\_li">写字楼电表</div>
<div id="xfmdylBtn" class="btn\_li">消防末端压力</div>
<!--<div id="ltxtBtn" class="btn\_li">冷通系统</div>-->
</div>
<div id="dataCeneterDiv" style="display:none;">
<div class="chatData" style="width:100%;margin-top:20px;background-color:rgba(3, 24, 56, 0);">
<div class="block-header">
<div class="container" style="width:94% !important">
<div>
<div class="left">
<div class="left\_\_bg"></div>
</div>
<div class="right">
<div class="right\_\_bg1"></div>
<div class="right\_\_bg2"></div>
<div class="right\_\_bg3"></div>
</div>
</div>
</div>
<img class="icon" src="../img/block-header-arrow.png" />
<div class="title" id="roomname" v-text="title">数据中心</div>
</div>
<div class="exitBtn" id="room\_exitBtn">
关闭
</div>
<div id="iframe\_dataCenterContent" class="chatContent" style="width:100%;">
<iframe style="width:100%;border:0px solid black;height:100%;" id="iframe\_bpd"></iframe>
</div>
</div>
</div>
<div id="peidianshi" style="display:none;">
<div class="chatData" style="width:1030px;margin-top:20px;background-color:rgba(3, 24, 56, 0.64);">
<div class="block-header">
<div class="container" style="width:100% !important;">
<div>
<div class="left">
<div class="left\_\_bg"></div>
</div>
<div class="right">
<div class="right\_\_bg1"></div>
<div class="right\_\_bg2"></div>
<div class="right\_\_bg3"></div>
</div>
</div>
</div>
<img class="icon" src="../img/block-header-arrow.png" />
<div class="title" v-text="title">变配电系统</div>
</div>
<div id="iframe\_bpdContent" class="chatContent" style="width:1030px;">
<iframe style="width:100%;border:0px solid black;height:600px;" id="iframe\_bpd"></iframe>
</div>
</div>
</div>
<div id="jpaishui" style="display:none;">
<div class="chatData" style="width:980px;margin-top:20px;background-color:rgba(3, 24, 56, 0.64);">
<div class="block-header">
<div class="container" style="width:980px !important;">
<div>
<div class="left">
<div class="left\_\_bg"></div>
</div>
<div class="right">
<div class="right\_\_bg1"></div>
<div class="right\_\_bg2"></div>
<div class="right\_\_bg3"></div>
</div>
</div>
</div>
<img class="icon" src="../img/block-header-arrow.png" />
<div class="title" v-text="title">给排水系统</div>
</div>
<div id="waterCotent" class="chatContent" style="width:980px;height:700px;overflow-x:hidden;overflow-y:auto;">
</div>
</div>
</div>
<div id="songfeng" style="display:none;">
<div class="chatData" style="width:970px;margin-top:20px;background-color:rgba(3, 24, 56, 0.64);">
<div class="block-header">
<div class="container" style="width:970px !important;">
<div>
<div class="left">
<div class="left\_\_bg"></div>
</div>
<div class="right">
<div class="right\_\_bg1"></div>
<div class="right\_\_bg2"></div>
<div class="right\_\_bg3"></div>
</div>
</div>
</div>
<img class="icon" src="../img/block-header-arrow.png" />
<div class="title" v-text="title">送排风系统</div>
</div>
<div class="chatContent" id="songfengContent" style="width:970px;padding:20px;max-height:640px;overflow-y:scroll;overflow-x:hidden;">
</div>
</div>
</div>
<div id="alarmsList" style="display:none;">
<div class="chatData" style="width:700px;margin-top:20px;background-color:rgba(3, 24, 56, 0.64);">
<div class="block-header">
<div class="container" style="width:700px !important;">
<div>
<div class="left">
<div class="left\_\_bg"></div>
</div>
<div class="right">
<div class="right\_\_bg1"></div>
<div class="right\_\_bg2"></div>
<div class="right\_\_bg3"></div>
</div>
</div>
</div>
<img class="icon" src="../img/block-header-arrow.png" />
<div class="title" v-text="title">设备报警列表</div>
</div>
<div class="chatContent" style="width:700px;">
<!--<table id="alarmTable"></table>-->
<div style="width:680px; margin-left:10px; height:600px;overflow-y:scroll" id="AlarmListResult">
</div>
</div>
</div>
</div>
<div id="doorEventList" style="display:none;">
<div class="chatData" style="width:700px;margin-top:20px;background-color:rgba(3, 24, 56, 0.64);">
<div class="block-header">
<div class="container" style="width:700px !important;">
<div>
<div class="left">
<div class="left\_\_bg"></div>
</div>
<div class="right">
<div class="right\_\_bg1"></div>
<div class="right\_\_bg2"></div>
<div class="right\_\_bg3"></div>
</div>
</div>
</div>
<img class="icon" src="../img/block-header-arrow.png" />
<div class="title" v-text="title">门禁记录查询</div>
</div>
<div class="chatContent" style="width:700px;">
<div id="doorSearchDiv">
<table style="color:white !important;margin-left:10px;">
<tr>
<td>查询条件:</td>
<td style="width:145px;"><input id="doorEventStartTime" placeholder="yyyy-MM-dd HH:mm:ss" style="float:left;width:140px;height:28px; font-size:14px; text-align:center;line-height:28px;color:white;background-color:rgba(0,0,0,0) !important;color:#32C5FF !important;border:1px solid #32C5FF;" /></td>
<td style="width:20px;">至</td>
<td style="width:145px;"><input id="doorEventEndTime" placeholder="yyyy-MM-dd HH:mm:ss" style="float:left;width:140px;height:28px; font-size:14px; text-align:center;line-height:28px;color:white;background-color:rgba(0,0,0,0) !important;color:#32C5FF !important;border:1px solid #32C5FF;" /></td>
<td style="width:100px;">
<input type="hidden" id="doorDevicecSn" value="" />
<!--<select style="float:left;width:80px;height:28px; font-size:14px; text-align:center;line-height:28px;color:white;background-color:rgba(0,0,0,0) !important;color:#32C5FF !important;border:1px solid #32C5FF;">
<option>授权</option>
</select>-->
</td>
<td style="width:100px;">
<div id="searchDoorEventBtn" style=" float:left;width:80px;height:28px; background-image: linear-gradient(to right, #024D9E , #09FDFF);border-radius:2px;font-size:14px; text-align:center;line-height:28px;color:white;cursor:pointer;">
查 询
</div>
</td>
<td style="width:100px;">
<div id="exitDoorEventBtn" class="divBtn" style="width:80px;height:28px;line-height:28px; ">
退出
</div>
</td>
</tr>
</table>
</div>
<div style="width:680px; margin-left:10px; height:500px;overflow-y:scroll" id="doorEventListResult">
</div>
</div>
</div>
</div>
<div id="devAllMeteList" style="display:none;">
<div class="chatData" style="width:700px;margin-top:20px;background-color:rgba(3, 24, 56, 0.64);">
<div class="block-header">
<div class="container" style="width:700px !important;">
<div>
<div class="left">
<div class="left\_\_bg"></div>
</div>
<div class="right">
<div class="right\_\_bg1"></div>
<div class="right\_\_bg2"></div>
<div class="right\_\_bg3"></div>
</div>
</div>
</div>
<img class="icon" src="../img/block-header-arrow.png" />
<div class="title" v-text="title" id="devTitle">设备量</div>
</div>
<div class="chatContent" style="width:700px;">
<div style="width:680px; margin-left:10px;margin-top:15px; height:500px;overflow-y:scroll" id="devMeteListResult">
</div>
</div>
</div>
</div>
<div id="devAlarmList" style="display:none;">
<div class="chatData" style="width:700px;margin-top:20px;background-color:rgba(3, 24, 56, 0.64);">
<div class="block-header">
<div class="container" style="width:700px !important;">
<div>
<div class="left">
<div class="left\_\_bg"></div>
</div>
<div class="right">
<div class="right\_\_bg1"></div>
<div class="right\_\_bg2"></div>
<div class="right\_\_bg3"></div>
</div>
</div>
</div>
<img class="icon" src="../img/block-header-arrow.png" />
<div class="title" v-text="title">报警记录查询</div>
</div>
<div class="chatContent" style="width:700px;">
<div id="doorSearchDiv">
<table style="color:white !important;margin-left:10px;">
<tr>
<td>查询条件:</td>
<td style="width:155px;"><input id="alarmStartTime" placeholder="yyyy-MM-dd HH:mm:ss" style="float:left;width:150px;height:28px; font-size:14px; text-align:center;line-height:28px;color:white;background-color:rgba(0,0,0,0) !important;color:#32C5FF !important;border:1px solid #32C5FF;" /></td>
<td style="width:20px;">至</td>
<td style="width:155px;"><input id="alarmEndTime" placeholder="yyyy-MM-dd HH:mm:ss" style="float:left;width:150px;height:28px; font-size:14px; text-align:center;line-height:28px;color:white;background-color:rgba(0,0,0,0) !important;color:#32C5FF !important;border:1px solid #32C5FF;" /></td>
<td style="width:80px;">
<select id="alarmDevSort" style="float:left;width:60px;height:28px; font-size:14px; text-align:center;line-height:28px;color:white;background-color:rgba(0,0,0,0) !important;color:#32C5FF !important;border:1px solid #32C5FF;">
<option value="1">升序</option>
<option value="2">降序</option>
</select>
<input type="hidden" id="selectEAlarmDevid" />
</td>
<td style="width:100px;">
<div id="searchDevAlarmBtn" style=" float:left;width:80px;height:28px; background-image: linear-gradient(to right, #024D9E , #09FDFF);border-radius:2px;font-size:14px; text-align:center;line-height:28px;color:white;cursor:pointer;">
查 询
</div>
</td>
<td style="width:100px;">
<div id="exitDevAlarmBtn" class="divBtn" style="width:80px;height:28px;line-height:28px; ">
退出
</div>
</td>
</tr>
</table>
</div>
<div style="width:680px; margin-left:10px;margin-top:15px; height:500px;overflow-y:scroll" id="devAlarmListResult">
</div>
</div>
</div>
</div>
3.2、业务逻辑部分重要代码与讲解如下
function ModelBussiness() {
this.currentAnimationState = 0;
this.functionState = "";//功能状态
this.currentSelectFloor =-1;
}
ModelBussiness.prototype.init = function (roomName) {
//悬停回调
WT3DObj.mouseOverCallBack = this.mouseOverCallBack;
//进入回调
WT3DObj.mouseOverInCallBack = this.mouseOverInCallBack;
//离开回调
WT3DObj.mouseOverLeaveCallBack = this.mouseOverLeaveCallBack;
//悬停触发时间长度
WT3DObj.mouseOverTimeLong = 1000;
this.hideHelpModels();
this.autoRunRotation = true;
// modelBussiness.UnrealBoom(1,1.2,0.83, 0.42)
}
//双击选中
ModelBussiness.prototype.dbClickSelect = function (_sobj, _face,objs,_floor) {
console.log(_sobj);
var _this = this;
if (_sobj.name.indexOf("_room_") >= 0) {
var roomName = _sobj.name.split("_")[4];
$("#roomname").html(roomName);
var roomid = _sobj.name.split("_")[3];
layer.open({
type: 1,
shade: 0.8,
skin: 'myLayer',
title: false,
area: [($(window).width() - 20) + "px", ($(window).height() - 20) + "px"],
content: $('#dataCeneterDiv'),
cancel: function () {
$("#iframe_dataCenterContent").html('');
if (window.parent.iframeOpenHeaderFun) {
window.parent.iframeOpenHeaderFun();
}
$("#chart_index").show();
},
success: function () {
if (window.parent.iframeCloseHeaderFun) {
window.parent.iframeCloseHeaderFun();
}
$("#chart_index").hide();
$("#iframe_dataCenterContent").html('')
}
});
}
}
ModelBussiness.prototype.addVitureDev = function (menuType) {
if (modelBussiness.tempNameList && modelBussiness.tempNameList.length > 0) {
$.each(modelBussiness.tempNameList, function (_i, _o) {
WT3DObj.destoryObj(_o);
});
modelBussiness.tempNameList = [];
}
this.functionState = menuType;
//layer.load();
switch (menuType) {
case "xfmdyl":
case "xzldb":
case "rooms":
case "door":
case "environment"://环境
case "aircontrol"://空调
case "radio"://广播
case "fire":
case "TV":
case "video": {
WT3DObj.commonFunc.changeCameraPosition({ x: 8026.832919779723, y: 11410.537277765132, z: 8678.638422438804 }, { x: 556.4874673700924, y: 4427.39332904184, z: -494.69977246193355 }, 200,
function () {
modelBussiness.vAllModel(function () {
modelBussiness.showAllVisuFloor();
layer.closeAll();
});
});
}
break;
case "lift"://电梯
{
modelBussiness.showLiftModel();
$.each(modelBussiness.tempNameList, function (\_i, \_o) {
WT3DObj.destoryObj(\_o);
});
modelBussiness.tempNameList = \[\];
}
break;
case "ltxt": {
modelBussiness.showAllBuild(function () {
WT3DObj.commonFunc.changeCameraPosition({x: 4187.131036680923, y: 5464.426260502498, z: 2030.4192806797732},
{ x: 1043.3158032062647, y: 2641.232605326482, z: -499.18168864866135 }, 1000,
function () {
layer.closeAll();
});
});
}
break;
case "index":
case "back"://
{
modelBussiness.showAllBuild(function () {
layer.closeAll();
});
}
break;
}
}
ModelBussiness.prototype.showAllVisuFloor = function () {
var _this = this;
this.showFloors(function () {
$.each(modelBussiness.tempNameList, function (\_i, \_o) {
WT3DObj.destoryObj(\_o);
});
// webapi.getPositionData(modelBussiness.functionState, -1, function (data)
{
var data = modelList\[modelBussiness.functionState\].data;
modelBussiness.tempNameList = \[\];
$.each(data, function (\_index, \_obj) {
if (\_obj.show == false) {
} else {
var floor = \_obj.floor;
var floorHeight = modelBussiness.getFloorHeigth(floor) + 10;
var name = "devLogo\_" + \_this.functionState + "\_" + \_obj.type+"\_" + \_obj.id + "\_" + \_obj.name;
modelBussiness.tempNameList.push(name);
var iconimg = \_obj.icon ? \_obj.icon : modelList\[\_this.functionState\].icon;
modelBussiness.commonFunc.addDevMark(name, { x: \_obj.x, y: floorHeight, z: \_obj.z }, iconimg, modelList\[\_this.functionState\].iconSize);
}
})
}
//);
});
}
ModelBussiness.prototype.showAllBuild = function (callBack) {
var _this = this;
_this.hideHelpModels();
_this.showAllModel(function () {
var xrange = { x: 1 }
new TWEEN.Tween(xrange).to({
x: 1.1
}, 1500).onUpdate(function () {
// modelBussiness.params.exposure = this.x;
}).onComplete(function () {
new TWEEN.Tween(xrange).to({
x: 1
}, 2000).onUpdate(function () {
// modelBussiness.params.exposure = this.x;
}).onComplete(function () {
if (callBack) {
callBack();
}
}).start();
}).start();
});
}
//掀开你的头盖骨
ModelBussiness.prototype.hideTopFloorsModel = function (floorNub) {
var floors=[
["F1_B3"],//-3
["F1_B2"],
["F1_B1"],
["F1_1", "F3_1"],//1
["F1_2", "F3_2"],//2
["F1_3", "F3_3"],//3
["F1_4", "F3_4"],//4
["F1_5", "F3_5"],//5
]
for (var i = 6; i <= 42;i++){
floors.push(["F2_" + i, "F3_" + i]);
}
floors.push(["F2_43"]);
floors.push(["F2_44"]);
$.each(WT3DObj.scene.children, function (\_index, \_obj) {
if (!\_obj.oldPositionY && \_obj.oldPositionY != 0) {
\_obj.oldPositionY = \_obj.position.y;
\_obj.visible = true;
}
});
if (floorNub == 0) {
var floorNames = \[\];
$.each(floors, function (\_findex, \_fobj) {
floorNames = floorNames.concat(\_fobj);
});
var models = WT3DObj.commonFunc.findObjectsByNames(floorNames);
$.each(models, function (\_findex, \_fobj) {
if (\_fobj.oldPositionY || \_fobj.oldPositionY == 0) {
\_fobj.position.y = \_fobj.oldPositionY;
\_fobj.visible = true;
}
});
} else {
var floorNames = \[\];
$.each(floors, function (\_findex, \_fobj) {
if (\_findex-2 > floorNub ) {
floorNames = floorNames.concat(\_fobj);
}
});
var bootomNames = \[\];
$.each(floors, function (\_findex, \_fobj) {
if (\_findex-2 <= floorNub) {
bootomNames = bootomNames.concat(\_fobj);
}
});
var bottommodels = WT3DObj.commonFunc.findObjectsByNames(bootomNames);
$.each(bottommodels, function (\_findex, \_fobj) {
if (\_fobj.oldPositionY || \_fobj.oldPositionY == 0) {
\_fobj.position.y = \_fobj.oldPositionY;
\_fobj.visible = true;
}
});
var movemodes = \[\];
var topmodels = WT3DObj.commonFunc.findObjectsByNames(floorNames);
$.each(topmodels, function (\_findex, \_fobj) {
if (!\_fobj.oldPositionY&& \_fobj.oldPositionY!= 0) {
\_fobj.oldPositionY = \_fobj.position.y;
}
if (\_fobj.position.y > \_fobj.oldPositionY) {
\_fobj.position.y = 10000 + \_fobj.oldPositionY;
\_fobj.visible = false;
} else {
movemodes.push(\_fobj);
}
});
if (movemodes) {
var yR = {y:0}
new TWEEN.Tween(yR).to({
y: 10000
}, 500).onUpdate(function () {
var \_thisx=this;
$.each(movemodes, function (\_findex, \_fobj) {
\_fobj.position.y = \_fobj.oldPositionY + \_thisx.y;
});
}).onComplete(function () {
$.each(movemodes, function (\_findex, \_fobj) {
\_fobj.position.y = 10000 + \_fobj.oldPositionY;
\_fobj.visible = false;
});
}).start();
}
}
}
ModelBussiness.prototype.showFloorDev = function (floorNub, type)
{
floorNub = parseInt(floorNub);
var models = WT3DObj.commonFunc.findObjectsByNames(modelBussiness.tempNameList);
this.hideTopFloorsModel(floorNub);
if (floorNub == 0) {
$.each(models, function (_index, _obj) {
_obj.visible = true;
});
WT3DObj.commonFunc.changeCameraPosition({ x: 4911.210369862361, y: 10841.747779303612, z: 7670.509455766194 }, { x: 127.36338796169231, y: 4716.795093859403, z: -379.3846010914671 }, 500,
function () {
});
} else {
//查找该楼层设备
var showmodels = \[\];
$.each(modelList\[type\].data, function (\_devindex, \_devobj) {
if (parseInt(\_devobj.floor) == floorNub) {
if (type == "rooms") {
showmodels.push("devLogo\_" + type + "\_room\_" + \_devobj.id + "\_" + \_devobj.name)
} else {
showmodels.push("devLogo\_" + type + "\_device\_" + \_devobj.id + "\_" + \_devobj.name)
}
}
});
$.each(models, function (\_index, \_obj) {
if (showmodels.indexOf(\_obj.name) < 0) {
\_obj.visible = false;
} else {
\_obj.visible = true;
}
});
WT3DObj.commonFunc.changeCameraPosition({ x: 2842.032108861517, y: 15466.564073695303 - (43 - floorNub) \* 200, z: 1543.7861561756818 }, { x: -402.0797318127744, y: 5157.3929866002245 - (43 - floorNub) \* 200, z: -1354.1029952588615 }, 500,
function () {
});
}
}
ModelBussiness.prototype.tempNameList = [];
ModelBussiness.prototype.tempNetNameList = [];
ModelBussiness.prototype.tempJJNameList = [];
ModelBussiness.prototype.lastSelectedObj = null;
ModelBussiness.prototype.ClickSelect = function (_obj, _face, objs) {
var _this = modelBussiness;
if (_this.functionState == "lift") {
WT3DObj.commonFunc.setSkinColorByObj(WT3DObj.commonFunc.findObject("elevator_dev_1"), 0x000000);
WT3DObj.commonFunc.setSkinColorByObj(WT3DObj.commonFunc.findObject("elevator_dev_2"), 0x000000);
if (objs && objs.length > 0) {
var selectliftobj = null;
$.each(objs, function (_index, _lobj) {
if (_lobj.object && _lobj.object.name && _lobj.object.name.indexOf("elevator_dev_") >= 0) {
selectliftobj = _lobj.object;
}
});
if (selectliftobj) {
WT3DObj.commonFunc.setSkinColorByObj(selectliftobj, 0xffff00);
$("#liftDetail").show();
$("#liftDetail").attr("data-state", 1);
indexPage.showLiftDetailByModel(selectliftobj.name);
} else {
$("#liftDetail").hide();
$("#liftDetail").attr("data-state", 0);
}
}
}
}
//悬停
ModelBussiness.prototype.mouseOverCallBack = function (_obj, face) {
}
ModelBussiness.prototype.mouseInCurrentObj = null;
ModelBussiness.prototype.lastMouseInCurrentObj = null;
//鼠标滑入事件
ModelBussiness.prototype.mouseOverInCallBack = function (_obj, face, objs) {
console.log(_obj.name);
var _this = modelBussiness;
var color = 0xbfffea;
modelBussiness.lastMouseInCurrentObj = _obj;
modelBussiness.mouseInCurrentObj = _obj;
if (_this.functionState == "lift") {
if (_obj.name.indexOf("devLogo_") >= 0&& _obj.name.indexOf("video") >= 0) {
modelBussiness.mouseInCurrentObj = \_sobj;
var screenPostion = WT3DObj.commonFunc.transToScreenCoord(\_obj.position);
$("#MarkMessageHelper").remove();
$("body").append("<div id='MarkMessageHelper' style='position:absolute;left:" + (screenPostion.x - 20) + "px;top:" + screenPostion.y + "px;height:2px;width:2px;z-index:1000;'></div>");
//devLogo\_TV\_1674\_3F
var devType = \_obj.name.split("\_")\[1\];
var devId = \_obj.name.split("\_")\[2\];
var devName = \_obj.name.split("\_")\[3\];
var showobj = showDevDetail(devType, devId, devName);
layer.tips(showobj.html, "#MarkMessageHelper", {
tips: \[1, 'rgba(3,24,60,0.62)'\],
area: \[showobj.width, showobj.height\],
time: 0
})
}
}
else {
if (_obj.name.indexOf("vf_") >= 0) {
var floor = parseInt(_obj.name.replace("vf_", ""));
if (floor == modelBussiness.currentSelectFloor) {
return;
}
if (modelBussiness.currentSelectFloor>0) {
return;
}
var _sobj = _obj;
if (_obj.name.indexOf("OBJCREN") > 0) {
_sobj = _obj.parent;
}
modelBussiness.mouseInCurrentObj = \_sobj;
\_sobj.visible = true;
WT3DObj.commonFunc.setSkinColorByObj(\_sobj, 0x00ffff);
WT3DObj.commonFunc.changeObjsOpacity(\[\_sobj\], 0, 0.2, 10, function () { });
$("#MarkMessageHelper").remove();
$("body").append("<div id='MarkMessageHelper' style='position:absolute;left:" + (window.event.pageX ) + "px;top:" + (window.event.pageY-10) + "px;height:2px;width:2px;z-index:1000;'></div>");
layer.tips("<font style='font-size:18px;'>楼层:" + floor+ "楼</font>", "#MarkMessageHelper", {
tips: \[1, '#003333'\],
time: 0
});
}
else if (\_obj.name.indexOf("devLogo\_") >= 0) {
modelBussiness.mouseInCurrentObj = \_sobj;
var screenPostion = WT3DObj.commonFunc.transToScreenCoord(\_obj.position);
$("#MarkMessageHelper").remove();
$("body").append("<div id='MarkMessageHelper' style='position:absolute;left:" + (screenPostion.x - 20) + "px;top:" + screenPostion.y + "px;height:2px;width:2px;z-index:1000;'></div>");
//var devType = \_obj.name.split("\_")\[1\];
//var devId = \_obj.name.split("\_")\[2\];
//var devName = \_obj.name.split("\_")\[3\];
var showobj = showDevDetail(\_obj.name);
layer.tips(showobj.html, "#MarkMessageHelper", {
tips: \[1, 'rgba(3,24,60,0.62)'\],
area: \[showobj.width, showobj.height\],
time: 0
})
}
}
}
//鼠标滑出事件
ModelBussiness.prototype.mouseOverLeaveCallBack = function (_obj, face, nowobj) {
var _this = modelBussiness;
var color = 0x000000;
if (_this.functionState == "lift") {
if (_obj.name.indexOf("devLogo_") >= 0
|| _obj.name.indexOf("rack_") >= 0
|| _obj.name.indexOf("dev_") >= 0) {
layer.closeAll();
}
} else {
if (_obj.name.indexOf("vf_") >= 0) {
layer.closeAll();
var _sobj = _obj;
if (_obj.name.indexOf("OBJCREN") > 0) {
_sobj = _obj.parent;
}
WT3DObj.commonFunc.setSkinColorByObj(_sobj, 0x000000);
WT3DObj.commonFunc.changeObjsOpacity([_sobj], 0.2, 0, 10, function () {
});
} else if (_obj.name.indexOf("devLogo_") >= 0 || _obj.name.indexOf("rack_") >= 0 || _obj.name.indexOf("dev_") >= 0) {
layer.closeAll();
}
}
}
//播放摄像头
ModelBussiness.prototype.playVideo = function (wsSrc) {
var html = "
layer.open({
title:"实时视频",
type: 1,
shade: 0,
content: html,
moveEnd: function (a) {
},
maxmin: false,
cancel: function () {
layer.closeAll();
}
});
var wsPlayer = new WSPlayer("videoPlayer", {
modules: [
{
client: RTSPClient,
transport: {
constructor: WebsocketTransport,
options: {
socket: wsSrc
}
}
}
]
});
wsPlayer.setSource(wsSrc, "rtsp");
}
ModelBussiness.prototype.hmodels = null;
ModelBussiness.prototype.getHelpModels = function () {
if (!modelBussiness.hmodels) {
var hnames = [];
for (var i = 1; i <= 13; i++) {
hnames.push("vf_" + i);
}
modelBussiness.hmodels = WT3DObj.commonFunc.findObjectsByNames(hnames);
$.each(modelBussiness.hmodels, function (_i, _o) { _o.material.depthTest = false; }
);
}
return modelBussiness.hmodels;
}
ModelBussiness.prototype.hideHelpModels = function () {
this.hideFloors();
var ms = modelBussiness.getHelpModels();
$.each(ms, function (\_i, \_o) {
\_o.visible = true;
});
WT3DObj.commonFunc.changeObjsOpacity(ms, 0.8, 0, 10, function () {
});
$.each(modelBussiness.tempNameList, function (\_i, \_o) {
WT3DObj.destoryObj(\_o);
});
modelBussiness.tempNameList = \[\];
$.each(modelBussiness.tempNetNameList, function (\_i, \_o) {
WT3DObj.destoryObj(\_o);
});
modelBussiness.tempNetNameList = \[\];
$.each(modelBussiness.tempJJNameList, function (\_i, \_o) {
WT3DObj.destoryObj(\_o);
});
modelBussiness.tempJJNameList = \[\];
}
ModelBussiness.prototype.nearCameraPostion = function (_obj, _face) {
//此处设置双击聚焦
{
var mainCamera = WT3DModel.camera;//主场景
var objpositionx = \_obj.position.x;
var objpositiony = \_obj.position.y;
var objpositionz = \_obj.position.z;
if (typeof (\_obj.parent) != 'undefined' && \_obj.parent != null && typeof (\_obj.parent.position) != 'undefined' && \_obj.parent.position != null) {
objpositionx += \_obj.parent.position.x;
objpositiony += \_obj.parent.position.y;
objpositionz += \_obj.parent.position.z;
}
if (typeof (\_obj.oldPosition) != 'undefined' && \_obj.oldPosition != null) {
objpositionx = \_obj.oldPosition.x;
objpositiony = \_obj.oldPosition.y;
objpositionz = \_obj.oldPosition.z;
}
new TWEEN.Tween(WT3DModel.controls.target).to({
x: objpositionx, y: objpositiony, z: objpositionz
}, 600).onComplete(function () {
var x\_distance = mainCamera.position.x - objpositionx;
var y\_distance = mainCamera.position.y - objpositiony;
var z\_distance = mainCamera.position.z - objpositionz;
var lv = 300 / Math.sqrt(x\_distance \* x\_distance + y\_distance \* y\_distance + z\_distance \* z\_distance);
var runtweenTime = 1000;
if (lv > 0.6) {
runtweenTime = 400;
} else if (lv > 0.3) {
runtweenTime = 1000;
} else if (lv > 0.1) {
runtweenTime = 1200;
} else if (lv > 0.05) {
runtweenTime = 1600;
} else if (lv > 0.01) {
runtweenTime = 2000;
} else {
runtweenTime = 2500;
}
if (x\_distance \* x\_distance + y\_distance \* y\_distance + z\_distance \* z\_distance > 300 \* 300 && lv < 0.9999) {
new TWEEN.Tween(mainCamera.position).to({
x: objpositionx + (mainCamera.position.x - objpositionx) \* lv, y: objpositiony + (mainCamera.position.y - objpositiony) \* lv, z: objpositionz + (mainCamera.position.z - objpositionz) \* lv
}, runtweenTime).start();
}
}).start();
}
}
/*
==============================电梯===============================================
*/
//显示电梯
ModelBussiness.prototype.showLiftModel = function () {
this.functionState = "lift";
this.vAllModel(function () {
WT3DObj.commonFunc.changeCameraPosition({ x: 2934.252457615192, y: 6578.88534028727, z: 7045.186930258046 },
{ x: -394.1032500428694, y: 845.5404737020468, z: -572.4129363162384 }, 1000,
function () {
modelBussiness.showLiftHelpModels();
});
})
}
ModelBussiness.prototype.closeLiftModel = function () {
this.functionState = "";
this.hideLiftHelpModels(function () {
WT3DObj.commonFunc.changeCameraPosition({ x: 2934.252457615192, y: 6578.88534028727, z: 7045.186930258046 },
{ x: -394.1032500428694, y: 845.5404737020468, z: -572.4129363162384 }, 1000,
function () {
window.modelBussiness.showAllBuild();;
modelBussiness.currentSelectFloor = -1;
});
});
}
ModelBussiness.prototype.showLiftHelpModels = function (callBack) {
var liftModelNames = ["elevator_shaft_1", "elevator_shaft_2", "elevator_dev_1", "elevator_dev_2"];
var liftModels = WT3DObj.commonFunc.findObjectsByNames(liftModelNames);
$.each(liftModels, function (_i, _o) {
_o.material.depthTest = false;
if (_o.material.materials) {
_o.material.materials.forEach(function (a) { a.depthTest = false; })
}
})
WT3DModel.commonFunc.changeObjsOpacity(liftModels, 0.05, 1, 800, function () {
if (callBack) {
callBack();
}
});
}
ModelBussiness.prototype.hideLiftHelpModels = function (callBack) {
var liftModelNames = ["elevator_shaft_1", "elevator_shaft_2", "elevator_dev_1", "elevator_dev_2"];
var liftModels = WT3DObj.commonFunc.findObjectsByNames(liftModelNames);
$.each(liftModels, function (_i, _o) {
_o.material.depthTest = true;
if (_o.material.materials) {
_o.material.materials.forEach(function (a) { a.depthTest = true; })
}
});
WT3DModel.commonFunc.changeObjsOpacity(liftModels, 1, 0.05, 800, function () {
if (callBack) {
callBack();
}
});
}
ModelBussiness.prototype.changeLiftHeight = function (name, floor) {
var height = this.getFloorHeigth(floor);
var lift = WT3DObj.commonFunc.findObject(name);
new TWEEN.Tween(lift.position).to({
y: height
}, 1500).start();
}
/*
==============================电梯END===============================================
*/
ModelBussiness.prototype.getFloorHeigth = function (floor) {
var height = -1000;
if (floor < 0) {
height = 300 \* floor+75;
} else if (floor <= 43) {
height = 200 \* (floor - 1)+75;
} else if (floor <= 44) {
height = 8705 + 75;
}
return height;
}
/*
==============================楼层模型处理===============================================
*/
//加载楼层
ModelBussiness.prototype.showFloors = function (callBack) {
var _this = this;
var floorModels = this.getFloorModels();
if (floorModels) {
$.each(floorModels, function (_index, _obj) {
if (_obj.oldPositionY || _obj.oldPositionY == 0) {
_obj.position.y = _obj.oldPositionY;
}
_obj.visible = true;
});
if (callBack) {
callBack();
}
} else {
httpGet("../js/models/floors.json", function (rs) {
WT3DObj.commonFunc.loadModelsByJsons(rs, { x: 0, y: 0, z: 0 }, { x: 0, y: 0, z: 0 }, true, function (models) {
console.log(models);
var floorModels = \_this.getFloorModels();
if (callBack) {
callBack();
}
});
});
}
}
ModelBussiness.prototype.hideFloors = function (callBack) {
var floorModels = this.getFloorModels();
if (floorModels) {
$.each(floorModels, function (_index, _obj) {
if (!_obj.oldPositionY) {
if (_obj.oldPositionY!=0) {
\_obj.oldPositionY = \_obj.position.y;
}
}
\_obj.position.y = 100000;
\_obj.visible = false;
});
}
if (callBack) {
callBack();
}
}
ModelBussiness.prototype.FloorModels = null;
ModelBussiness.prototype.getFloorModels = function () {
if (!this.FloorModels) {
var floorModels = [];
$.each(WT3DObj.scene.children, function (_index, _obj) {
if (_obj.name.indexOf("F1_") >= 0
|| _obj.name.indexOf("F2_") >= 0
|| _obj.name.indexOf("F3_") >= 0
) {
floorModels.push(_obj);
}
});
if (floorModels.length > 0) {
this.FloorModels = floorModels;
}
}
return this.FloorModels;
}
/*
==============================大楼模型处理===============================================
*/
//获取大楼模型
ModelBussiness.prototype.BigBuildModelsCache = null;
ModelBussiness.prototype.getAllBuildModels = function () {
if (this.BigBuildModelsCache) {
} else {
var f1models = [];
var buildmodels = [];
$.each(WT3DObj.scene.children, function (_index, _obj) {
if (_obj.name != "backFloor"
&& _obj.name.indexOf("roadFlow") < 0
&& _obj.name.indexOf("Light") < 0
&& _obj.type.indexOf("Light") < 0
&& _obj.name.indexOf("roadCase") < 0
&& _obj.name.indexOf("F1_") < 0
&& _obj.name.indexOf("F2_") < 0
&& _obj.name.indexOf("F3_") < 0
&& _obj.name.indexOf("skybox") < 0
&& _obj.name.indexOf("vf_") < 0
&& _obj.name.indexOf("hb_") < 0) {
buildmodels.push(_obj);
}
});
this.BigBuildModelsCache = buildmodels;
}
return this.BigBuildModelsCache;
}
//虚化隐藏大楼
ModelBussiness.prototype.vAllModel = function (callBack) {
modelBussiness.getAllBuildModels();
WT3DModel.commonFunc.changeObjsOpacity(modelBussiness.BigBuildModelsCache, 1, 0.02, 1500, function () {
$.each(modelBussiness.BigBuildModelsCache, function (_index, _obj) {
if (!_obj.oldPositionY) {
if (\_obj.oldPositionY != 0) {
\_obj.oldPositionY = \_obj.position.y;
}
}
\_obj.position.y = 100000;
\_obj.visible = false;
});
if (callBack) {
callBack();
}
});
}
//显示大楼
ModelBussiness.prototype.showAllModel = function (callBack) {
modelBussiness.getAllBuildModels();
$.each(modelBussiness.BigBuildModelsCache, function (_index, _obj) {
if (_obj.oldPositionY || _obj.oldPositionY==0) {
_obj.position.y= _obj.oldPositionY ;
}
_obj.visible = true;
});
WT3DModel.commonFunc.changeObjsOpacity(modelBussiness.BigBuildModelsCache, 0.05, 1, 800, function () {
if (callBack) {
callBack();
}
});
}
//通道特效处理
ModelBussiness.prototype.UnrealBoom = function (a, b, c, d) {
renderScene = new THREE.RenderPass(WT3DObj.scene, WT3DObj.camera);
effectFXAA = new THREE.ShaderPass(THREE.FXAAShader);
effectFXAA.uniforms['resolution'].value.set(1 / window.innerWidth, 1 / window.innerHeight);
var copyShader = new THREE.ShaderPass(THREE.CopyShader);
copyShader.renderToScreen = true;
modelBussiness.bloomPass = new THREE.UnrealBloomPass(new THREE.Vector2(window.innerWidth, window.innerHeight), (1.5), (0.4), (0.85));//1.0, 9, 0.5, 512);
modelBussiness.bloomPass.threshold = c ? c : 0.81;
modelBussiness.bloomPass.strength = b ? b : 1.5;
modelBussiness.bloomPass.radius = d ? d : 0.85;
modelBussiness.composer = new THREE.EffectComposer(WT3DObj.renderer);
modelBussiness.composer.setSize(window.innerWidth, window.innerHeight);
modelBussiness.composer.addPass(renderScene);
modelBussiness.composer.addPass(effectFXAA);
modelBussiness.composer.addPass(modelBussiness.bloomPass);
modelBussiness.composer.addPass(copyShader);
modelBussiness.params = {
projection: 'normal',
background: false,
exposure: (a ? a : 1.0),
bloomStrength: (b ? b : 1.5),
bloomThreshold: (c ? c : 0.85),
bloomRadius: (d ? d : 0.4)
};
WT3DObj.renderer.toneMapping = THREE.ReinhardToneMapping;
WT3DObj.renderer.gammaInput = true;
WT3DObj.renderer.gammaOutput = true;
WT3DObj.postProcessFuc = function () {
WT3DObj.renderer.toneMappingExposure = Math.pow(modelBussiness.params.exposure, 4.0);
modelBussiness.composer.render();
}
var xrange = { x: 1 }
new TWEEN.Tween(xrange).to({
x: 1.2
}, 1500).onUpdate(function () {
modelBussiness.params.exposure = this.x;
}).onComplete(function () {
new TWEEN.Tween(xrange).to({
x: 1
}, 2000).onUpdate(function () {
modelBussiness.params.exposure = this.x;
}).onComplete(function () {
}).start();
}).start();
}
/*
==============================通用方法===============================================
*/
ModelBussiness.prototype.commonFunc = {
showVideo: function (_obj) {
//获取位置
var screenPostion = WT3DObj.commonFunc.transToScreenCoord(_obj.position);
var cameraId = _obj.name.split("_")[3];
var title = config.Videos[cameraId];
$("#videoTitle").html(title + "(" + cameraId + ")");
$("#MarkMessageHelper").remove();
$("body").append("
$("#videoDetail").show();
$("#videoDetail").css("left", $("#MarkMessageHelper").css("left"));
$("#videoDetail").css("top", (parseFloat($("#MarkMessageHelper").css("top")) - 300) + "px");
},
showNetDetail: function (\_obj) {
//获取位置
var screenPostion = WT3DObj.commonFunc.transToScreenCoord(\_obj.position);
$("#MarkMessageHelper").remove();
$("body").append("<div id='MarkMessageHelper' style='position:absolute;left:" + (screenPostion.x) + "px;top:" + screenPostion.y + "px;height:2px;width:2px;z-index:1000;'></div>");
$("#netDetail").show();
$("#netDetail").css("left", $("#MarkMessageHelper").css("left"));
$("#netDetail").css("top", (parseFloat($("#MarkMessageHelper").css("top")) - 200) + "px");
indexPage.showNetDevDetail(\_obj.name);
},
showJJDetail: function (\_obj) {
//获取位置
var screenPostion = WT3DObj.commonFunc.transToScreenCoord(\_obj.position);
$("#MarkMessageHelper").remove();
$("body").append("<div id='MarkMessageHelper' style='position:absolute;left:" + (screenPostion.x) + "px;top:" + screenPostion.y + "px;height:2px;width:2px;z-index:1000;'></div>");
$("#netDetail").show();
$("#netDetail").css("left", $("#MarkMessageHelper").css("left"));
$("#netDetail").css("top", (parseFloat($("#MarkMessageHelper").css("top")) - 200) + "px");
indexPage.showNetDevDetail(\_obj.name);
},
showDHDevDetail: function (\_obj) {
//获取位置
var screenPostion = WT3DObj.commonFunc.transToScreenCoord(\_obj.position);
$("#MarkMessageHelper").remove();
$("body").append("<div id='MarkMessageHelper' style='position:absolute;left:" + (screenPostion.x) + "px;top:" + screenPostion.y + "px;height:2px;width:2px;z-index:1000;'></div>");
layer.closeAll();
if (\_obj.name.indexOf("dhF1\_Rack") >= 0) {
$("#rackDetail").show();
$("#rackDetail").css("left", $("#MarkMessageHelper").css("left"));
$("#rackDetail").css("top", (parseFloat($("#MarkMessageHelper").css("top")) - 170) + "px");
} else if (\_obj.name.indexOf("dhF1\_UPS") >= 0) {
$("#upsDetail").show();
$("#upsDetail").css("left", $("#MarkMessageHelper").css("left"));
$("#upsDetail").css("top", (parseFloat($("#MarkMessageHelper").css("top")) - 170) + "px");
} else if (\_obj.name.indexOf("dhF1\_camera\_") >= 0) {
$("#dhVideoDetail").show();
var cameraId = config.Videos.dhCameraId;
var title = config.Videos.dhCameraTitle;
$("#dhVideoDetail table td:first").html(title + '<i class="ace-icon fa fa-wifi" style="margin-left:5px;color:#1bff00;" />')
$("#dhVideoDetail").css("left", $("#MarkMessageHelper").css("left"));
$("#dhVideoDetail").css("top", (parseFloat($("#MarkMessageHelper").css("top")) - 170) + "px");
} else if (\_obj.name.indexOf("dhF1\_AirConfig") >= 0) {
$("#airConfig2Detail").show();
$("#airConfig2Detail").css("left", $("#MarkMessageHelper").css("left"));
$("#airConfig2Detail").css("top", (parseFloat($("#MarkMessageHelper").css("top")) - 170) + "px");
}
}
, showDoorInfo: function (\_obj) {
//获取位置
var screenPostion = WT3DObj.commonFunc.transToScreenCoord(\_obj.position);
$("#MarkMessageHelper").remove();
$("body").append("<div id='MarkMessageHelper' style='position:absolute;left:" + (screenPostion.x) + "px;top:" + screenPostion.y + "px;height:2px;width:2px;z-index:1000;'></div>");
$("#doorDetail").show();
$("#doorDetail").css("left", $("#MarkMessageHelper").css("left"));
$("#doorDetail").css("top", (parseFloat($("#MarkMessageHelper").css("top")) - 230) + "px");
indexPage.showDoorDetail(\_obj.name);
}
}
}
var modelBussiness = new ModelBussiness();
3.3、交互逻辑代码
var indexPage = null;
$(function () {
indexPage = new IndexPage();
indexPage.init();
window.parent.parent.indexPage = indexPage;
});
function IndexPage() {
this.currentMebu = "首页";
this.state = 0;//0正常状态 1 加载状态
this.runAutoRoute = false;//运行自动漫游
this.liftVideoCache = null;
};
function closeAutoRouteFunc() {
indexPage.runAutoRoute = false;
$(".btn_li").attr("class", "btn_li");
layer.closeAll();
}
IndexPage.prototype.init = function () {
$("#indexBtn").click(function () {
$(".btn_li").attr("class", "btn_li");
$("#indexBtn").attr("class", "btn_li action");
indexPage.selectControl('index')
});
$("#sbfBtn").click(function () {
$(".btn_li").attr("class", "btn_li");
$("#sbfBtn").attr("class", "btn_li action");
indexPage.selectControl('rooms')
});
$("#xzldbBtn").click(function () {
$(".btn_li").attr("class", "btn_li");
$("#xzldbBtn").attr("class", "btn_li action");
indexPage.selectControl('xzldb')
//if (window.parent && window.parent.parent && window.parent.parent.openAutoRoute) {
// window.parent.parent.openAutoRoute();
//}
// indexPage.songpaifeng();
});
$("#xfmdylBtn").click(function () {
$(".btn_li").attr("class", "btn_li");
$("#xfmdylBtn").attr("class", "btn_li action");
indexPage.selectControl('xfmdyl')
});
$("#room_exitBtn").click(function () {
$("#chart_index").show();
if (window.parent.iframeOpenHeaderFun) {
window.parent.iframeOpenHeaderFun();
}
layer.closeAll();
});
$("#ltxtBtn").click(function () {
$(".btn_li").attr("class", "btn_li");
$("#ltxtBtn").attr("class", "btn_li action");
indexPage.selectControl('ltxt')
});
$("#searchDoorEventBtn").click(function () {
indexPage.searchDoorEventEvent();
})
$("#exitDoorEventBtn").click(function () {
layer.closeAll();
});
$("#exitDevAlarmBtn").click(function () {
layer.closeAll();
});
$("#searchDevAlarmBtn").click(function () {
indexPage.showAlarmListByDev($("#selectEAlarmDevid").val(), $("#alarmStartTime").val(), $("#alarmEndTime").val());
});
}
IndexPage.prototype.selectControl = function (menuType) {
var _this = this;
if (indexPage.state == 1) {
layer.msg(indexPage.currentMebu+"系统加载中,请稍后操作");
return;
}
indexPage.state = 1;
setTimeout(function () {
indexPage.state = 0;
}, 1500);
indexPage.currentMebuType = menuType;
modelBussiness.addVitureDev(menuType);
$(".contentRight").hide();
$("#fourBtns").show();
this.commonFunc.removeAllVideo();
$("#floorsBtn").html("");
switch (menuType) {
case "index": {
indexPage.currentMebu = "首页";
indexPage.indexPage(menuType, "首页");
if (window.parent.iframeOpenFun) {
window.parent.iframeOpenFun();
}
} break;
case "rooms": {
if (window.parent.iframeCloseFun) {
window.parent.iframeCloseFun();
}
indexPage.currentMebu = "设备房";
var floorsbtn = ' <div class="floorNub action" id="floorBtn\_0" onclick="indexPage.selectFloor(0,\\'rooms\\')">全楼层</div>';
modelList.rooms.data = modelList.rooms.data.sort(function (a, b) { return parseInt(b.floor) - parseInt(a.floor) });
var floornub = -100;
$.each(modelList.rooms.data, function (\_index, \_obj) {
if (floornub != \_obj.floor) {
floorsbtn += ' <div class="floorNub" id="floorBtn\_' + \_obj.floor + '" onclick="indexPage.selectFloor(' + \_obj.floor + ',\\'rooms\\')">楼层' + \_obj.floor + '</div>';
floornub = \_obj.floor;
}
});
setTimeout(function () {
$("#floorsBtn").html(floorsbtn);
}, 3000);
\_this.showRooms();
} break;
case "xzldb": {
if (window.parent.iframeCloseFun) {
window.parent.iframeCloseFun();
}
indexPage.currentMebu = "写字楼电表";
var floorsbtn = ' <div class="floorNub action" id="floorBtn\_0" onclick="indexPage.selectFloor(0,\\'xzldb\\')">全楼层</div>';
modelList.xzldb.data = modelList.xzldb.data.sort(function (a, b) { return parseInt(b.floor) - parseInt(a.floor) });
var floornub = -100;
$.each(modelList.xzldb.data, function (\_index,\_obj) {
if (floornub != \_obj.floor) {
floorsbtn += ' <div class="floorNub" id="floorBtn\_' + \_obj.floor + '" onclick="indexPage.selectFloor(' + \_obj.floor + ',\\'xzldb\\')">楼层' + \_obj.floor + '</div>';
floornub = \_obj.floor;
}
});
setTimeout(function () {
$("#floorsBtn").html(floorsbtn);
}, 3000);
var roomnubs = modelList.xzldb.roomId.length;
var result = \[\];
$.each(modelList.xzldb.roomId, function (\_i, \_o) {
webapi.getDevAndVluesList(\_o, function (response) {
roomnubs--;
if (response && response.result && response.result.length >= 0) {
result = result.concat(response.result)
}
if (roomnubs == 0) {
\_this.showListDetail(result);
};
});
})
} break;
case "xfmdyl": {
if (window.parent.iframeCloseFun) {
window.parent.iframeCloseFun();
}
indexPage.currentMebu = "消防压力";
var floorsbtn = ' <div class="floorNub action" id="floorBtn\_0" onclick="indexPage.selectFloor(0,\\'xfmdyl\\')">全楼层</div>';
modelList.xfmdyl.data = modelList.xfmdyl.data.sort(function (a, b) { return parseInt(b.floor) - parseInt(a.floor) });
var floornub = -100;
$.each(modelList.xfmdyl.data, function (\_index, \_obj) {
if (floornub != \_obj.floor) {
floorsbtn += ' <div class="floorNub" id="floorBtn\_' + \_obj.floor + '" onclick="indexPage.selectFloor(' + \_obj.floor + ',\\'xfmdyl\\')">楼层' + \_obj.floor + '</div>';
floornub = \_obj.floor;
}
});
setTimeout(function () {
$("#floorsBtn").html(floorsbtn);
}, 3000);
webapi.getDevAndVluesList(modelList.xfmdyl.roomId, function (response) {
if (response && response.result && response.result.length >= 0) {
\_this.showListDetail(response.result);
// if (callBack) { callBack(response.result); }
} else {
layer.msg("获取设备失败");
}
});
} break;
case "ltxt": {
if (window.parent.iframeCloseFun) {
window.parent.iframeCloseFun();
}
indexPage.currentMebu = "冷通系统";
webapi.getDevAndVluesList(modelList.ltxt.roomId, function (response) {
if (response && response.result && response.result.length >= 0) {
\_this.showListDetail(response.result);
// if (callBack) { callBack(response.result); }
} else {
layer.msg("获取设备失败");
}
});
} break;
case "door": {
indexPage.currentMebu = "门禁";
indexPage.doorPage(menuType,"门禁");
$("#fourBtns").hide();
} break;
case "TV": {
indexPage.currentMebu = "信息发布";
indexPage.TVPage(menuType, "信息发布");
$("#fourBtns").hide();
} break;
case "environment": {
indexPage.currentMebu = "环境";
indexPage.environmentPage(menuType, "环境");
$("#fourBtns").hide();
} break;
case "aircontrol": {
indexPage.currentMebu = "空调";
indexPage.aircontrolPage(menuType, "空调");
$("#fourBtns").hide();
} break;
case "radio": {
indexPage.currentMebu = "广播";
indexPage.radioPage(menuType, "广播");
$("#fourBtns").hide();
} break;
case "video": {
indexPage.currentMebu = "视频";
indexPage.videooPage(menuType, "视频");
$("#fourBtns").hide();
} break;
case "fire": {
indexPage.currentMebu = "消防";
indexPage.firePage(menuType, "消防");
$("#fourBtns").hide();
} break;
case "lift": {
indexPage.currentMebu = "电梯";
indexPage.liftPage(menuType, "电梯");
$("#fourBtns").hide();
} break;
case "pds": {
console.log(window);
window.location.href = "pdsCenter.html";
} break;
case "dataCenter": {
window.location.href = "dataCenter.html";
} break;
}
}
IndexPage.prototype.selectFloor = function (floornub,type) {
$(".floorNub").attr("class", "floorNub")
$("#floorBtn_" + floornub).attr("class", "floorNub action");
modelBussiness.showFloorDev(floornub, type);
}
//通用方法
IndexPage.prototype.webRtcServers = {};
IndexPage.prototype.commonFunc ={
addVideo: function (divId, url, video) {
if (indexPage.webRtcServers["video_" + divId]) {
indexPage.webRtcServers["video_" + divId].disconnect();
}
indexPage.webRtcServers["video_" + divId] = null;
var urlConfig = { video: video, audio: null };
indexPage.webRtcServers["video_" + divId] = new WebRtcStreamer(divId, url);
indexPage.webRtcServers["video_" + divId].connect(urlConfig.video, urlConfig.audio, "rtptransport=tcp&timeout=60");
// window.onbeforeunload = function () { this.webRtcServer.disconnect() }
},
removeVideo: function (divId) {
if (indexPage.webRtcServers["video_" + divId]) {
indexPage.webRtcServers["video_" + divId].disconnect();
}
indexPage.webRtcServers["video_" + divId] = null;
}
,
removeAllVideo: function () {
for (var webrtc in indexPage.webRtcServers) {
if (indexPage.webRtcServers[webrtc]) {
indexPage.webRtcServers[webrtc].disconnect();
}
indexPage.webRtcServers[webrtc] = null;
}
}
,
createPIEChart: function (id, giftImageUrl, value) {
if ($("#" + id).length > 0) {
var myChart = echarts.init(document.getElementById(id));
var option = {
graphic: {
elements: \[{
type: 'image',
style: {
image: giftImageUrl,
width: 20,
height: 20
},
left: 'center',
top: 'center'
}\]
},
polar: {
radius: \['65%', '78%'\],
center: \['50%', '50%'\],
},
angleAxis: {
max: 100,
show: false,
},
radiusAxis: {
type: 'category',
show: true,
axisLabel: {
show: false,
},
axisLine: {
show: false,
},
axisTick: {
show: false,
},
},
series: \[{
name: '',
type: 'bar',
roundCap: true,
barWidth: 90,
showBackground: true,
backgroundStyle: {
color: 'rgba(66, 66, 66, .0)',
},
data: \[value\],
coordinateSystem: 'polar',
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 1, 0, 0, \[{
offset: 0,
color: '#16CEB9',
},
{
offset: 1,
color: '#6648FF',
},
\]),
},
},
},
{
name: '',
type: 'pie',
startAngle: 80,
radius: \['90%'\],
hoverAnimation: false,
center: \['50%', '50%'\],
itemStyle: {
color: 'rgba(66, 66, 66, .1)',
borderWidth: 1,
borderColor: '#5269EE',
},
data: \[100\],
},
\],
};
myChart.setOption(option);
}
}
,
createStaticByDevType: function (devType) { }
}
//=============设备房==========================
IndexPage.prototype.showRooms = function () {
$("#chart_index").show();
var _this = this;
var html = "";
var allNub = modelList.rooms.data.length;
var onlineNub = modelList.rooms.data.length;
$.each(modelList.rooms.data, function (_index, _obj) {
html += _this.showRoomDetail(_obj);
});
createCSystemRoomsStatic("index", allNub, onlineNub);
$("#index\_1").html(html);
var roomNub = modelList.rooms.data.length;
var Allonnub = 0;
var Alloffnub = 0;
$.each(modelList.rooms.data, function (\_rindex, \_robj) {
webapi.getDevAndVluesList(\_robj.id, function (response) {
roomNub--;
var roomContentDevHtml = "";
if (response && response.result && response.result.length >= 0) {
var ronnub = 0;
var roffnub = 0;
$.each(response.result, function (\_devindex, \_eobj) {
if (\_eobj) {
{
roomContentDevHtml += ' <div class="dev\_DivMete">\\
<div class="dev\_DivMeteName" title=' + \_eobj.objName + '>\\
' + \_eobj.objName + ':\\
</div>\\
<div class="dev\_DivMeteValue">' + (\_eobj.objState == "ONLINE" ? "在线" : "<font style='color:red;'>离线</font>") + '\\
</div>\\
</div>';
\_eobj.objState == "ONLINE" ? ronnub++ : roffnub++;
}
}
});
$("#room\_" + \_robj.id).html(roomContentDevHtml);
$("#room\_" + \_robj.id + "\_all").html(ronnub + roffnub);
$("#room\_" + \_robj.id + "\_on").html(ronnub);
$("#room\_" + \_robj.id + "\_off").html(roffnub);
Allonnub += ronnub;
Alloffnub+=roffnub;
if (roomNub == 0) {
createCSystemStatic("index", (Allonnub + Alloffnub), Allonnub);
}
} else {
console.log("error:获取设备失败,eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee");
}
});
});
}
IndexPage.prototype.showRoomDetail = function (_obj) {
var html = "";
if (_obj ) {
html = ' <div class="fireLi\_Div" style="height:auto;">\\
<div class="fireLi\_DivTop">\\
<font class="fireLi\_DivTopName" title="' + \_obj.name + '">' + \_obj.name + '</font>\\
<font class="fireLi\_DivTopState">总数:<font style="color:#ff9900;font-size:14px;" id="room\_' + \_obj.id + '\_all" >3</font>;在线:<font style="color:#ff9900;font-size:14px;" id="room\_' + \_obj.id + '\_on" >3</font>;离线:<font style="color:#ff9900;font-size:14px;" id="room\_' + \_obj.id + '\_off" >3</font></font>\\
</div>\\
<div class="fireLi\_DivContent" id="room\_' + \_obj.id + '"> </div>\\
</div>';
}
return html;
}
//=============其它设备==========================
IndexPage.prototype.showListDetail = function (result) {
$("#chart_index").show();
var _this = this;
var html = "";
var allNub = 0;
var onlineNub = 0;
$.each(result, function (_index, _obj) {
html += _this.showDetail(_obj);
allNub++;
if (_obj.objState == "ONLINE") {
onlineNub++;
}
});
createCSystemStatic("index", allNub, onlineNub);
$("#index\_1").html(html);
}
IndexPage.prototype.showDetail = function (_obj) {
var html = "";
html = ' <div class="fireLi\_Div' + (\_obj.objState == "ONLINE" ? "" : " offline") + '" style="height:auto;">\\
<div class="fireLi\_DivTop">\\
<font class="fireLi\_DivTopName" title="' + \_obj.objName + '">' + \_obj.objName + '</font>\\
<font class="fireLi\_DivTopState">' + (\_obj.objState == "ONLINE" ? "在线" : "<font style='color:red'>离线</font>") + '</font>\\
</div>\\
<div class="fireLi\_DivContent">';
if (\_obj && \_obj.values && \_obj.values.length > 0) {
$.each(\_obj.values, function (\_eindex, \_eobj) {
{
if (\_eobj.key) {
\_eobj.sValue2 = \_eobj.sValue;
if (\_eobj.sValue == "END") {
\_eobj.sValue2 = "无告警"
} else if (\_eobj.sValue == "BEGIN") {
\_eobj.sValue2 = "<font style='color:red;'>告警</font>"
}
html += ' <div class="dev\_DivMete">\\
<div class="dev\_DivMeteName" title=' + \_eobj.meteName + '>\\
' + \_eobj.meteName + ':\\
</div>\\
<div class="dev\_DivMeteValue" data-unit="' + \_eobj.unit + '" data-keyname="' + \_eobj.meteName + '" id="devParamValue\_' + \_eobj.meteId + '">' + \_eobj.sValue2+(\_eobj.unit ? \_eobj.unit : "") + '\\
</div>\\
</div>';
}
}
});
}
html += ' </div>\\
</div>';
return html;
}
//===================================
IndexPage.prototype.XZLDBPage = function (id, name) {
var _this = this;
$("#chart_" + id).show();
createCSystemStatic(id, name, config.XZLDB.deviceTypeId, false, function (result) {
_this.showXZLDBListDetail(result);
});
}
IndexPage.prototype.showXZLDBListDetail = function (result) {
var _this = this;
var html = "";
var meteids = [];
result = result.sort(function (a, b) { return b.onlineState - a.onlineState });
$.each(result, function (_index, _obj) {
var hobj = _this.showXZLDBDetail(_obj);
html += hobj.html;
meteids = meteids.concat(hobj.meteids);
});
$("#XZLDB_2").html(html);
setTimeout(function () {
_this.flashXZLDBDetailValue(meteids);
}, 200);
if (_this.flashXZLDBDetailValueInterval) {
clearInterval(_this.flashXZLDBDetailValueInterval);
}
_this.flashXZLDBDetailValueInterval = setInterval(function () {
if (_this.currentMebuType == "XZLDB" && meteids.length > 0) {
_this.flashXZLDBDetailValue(meteids);
} else {
clearInterval(_this.flashXZLDBDetailValueInterval);
}
}, 5000);
}
IndexPage.prototype.flashXZLDBDetailValueInterval = null;
IndexPage.prototype.flashXZLDBDetailValue = function (meteids) {
var _this = this;
webapi.bulkGetRealTimeData(meteids, function (data) {
if (data && data.length > 0) {
$.each(data, function (_dindex, _dobj) {
var keyname = $("#devParamValue_" + _dobj.pointId).attr("data-keyname");
if (keyname) {
if (keyname.indexOf("温度") >= 0) {
_dobj.value += "℃";
} else if (keyname.indexOf("湿度") >= 0) {
_dobj.value += "%";
}
}
console.log("#devParamValue_" + _dobj.pointId)
console.log(_dobj.value)
$("#devParamValue_" + _dobj.pointId).html(_dobj.value);
});
}
});
}
IndexPage.prototype.showXZLDBDetail = function (_obj) {
var html = '
var meteids = [];
if (_obj && _obj.extra && _obj.extra.length > 0) {
$.each(\_obj.extra, function (\_eindex, \_eobj) {
if (\_eobj.key.indexOf("控制") < 0) {
html += ' <div class="fireLi\_DivMete">\\
<div class="fireLi\_DivMeteName" >\\
' + \_eobj.key + ':\\
</div>\\
<div class="fireLi\_DivMeteValue" data-keyname="' + \_eobj.key + '" id="devParamValue\_' + \_eobj.value + '">\\
<img src="../plugs/layer/layui/css/modules/layer/default/loading-1.gif" style="width:16px;height:16px;" />\\
</div>\\
</div>';
meteids.push(\_eobj.value);
}
});
}
html += ' </div>\\
<div class="fireLi\_DivBottom">\\
<div class="fireLi\_divBtn1">\\
<font style="float:left;margin-left: 27px;">位置:</font>\\
<font style="float:left;">' + \_obj.shortAddress + '</font>\\
</div>\\
<div class="fireLi\_divBtn2" onclick="indexPage.showEDevAlarmListByDev(\\'' + \_obj.serialNumber + '\\')">\\
查看报警记录\\
</div>\\
</div>\\
</div>';
return {
html: html,
meteids: meteids
};
}
//==============主页===========================
IndexPage.prototype.indexPage = function (id, name) {
}
//自动漫游
IndexPage.prototype.showAutoRunRouteTimeIndex = null;
//机房
IndexPage.prototype.showDataCenter = function (filter) {
layer.open({
type: 1,
shade: 0.8,
skin: 'myLayer',
title: false,
area: ["1050px", "750px"],
content: $('#dataCeneterDiv'),
cancel: function () {
indexPage.runAutoRoute = false;
if (indexPage.showAutoRunRouteTimeIndex) {
clearTimeout(indexPage.showAutoRunRouteTimeIndex);
}
if (window.parent && window.parent.parent && window.parent.parent.closeAutoRoute) {
window.parent.parent.closeAutoRoute();
}
$(".btn_li").attr("class", "btn_li");
$("#iframe_dataCenterContent").html('')
},
success: function () {
$("#iframe\_dataCenterContent").html('<iframe src="dataCenter.html' + (filter?"?filter="+filter:"") + '" style="width:100%;border:0px solid black;height:600px;" id="iframe\_bpd"></iframe>')
}
});
}
//变电站
IndexPage.prototype.showBianDianZhan = function () {
layer.closeAll();
setTimeout(function () {
layer.open({
type: 1,
shade: 0.8,
skin: 'myLayer',
title: false,
area: ["1050px", "750px"],
content: $('#peidianshi'),
cancel: function () {
indexPage.runAutoRoute = false;
if (indexPage.showAutoRunRouteTimeIndex) {
clearTimeout(indexPage.showAutoRunRouteTimeIndex);
}
if (window.parent && window.parent.parent && window.parent.parent.closeAutoRoute) {
window.parent.parent.closeAutoRoute();
}
$(".btn_li").attr("class", "btn_li");
$("#iframe_bpdContent").html('')
},
success: function () {
$("#iframe\_bpdContent").html('<iframe src="pdsCenter.html" style="width:100%;border:0px solid black;height:600px;" id="iframe\_bpd"></iframe>')
}
});
}, 200)
}
//显示首页视频
IndexPage.prototype.showIndexVideo = function () {
var url = { video: location.search.slice(1) };
var options = webrtcConfig.options;
if (typeof URLSearchParams != 'undefined') {
var params = new URLSearchParams(location.search);
if (params.has("video") || params.has("audio")) {
url = { video: params.get("video"), audio: params.get("audio") };
}
if (params.has("options")) {
options = params.get("options");
}
}
window.onload = function () {
this.webRtcServer = new WebRtcStreamer("video", webrtcConfig.url);
document.getElementById("title").innerHTML = url.video;
webRtcServer.connect(url.video, url.audio, options);
fetch(webrtcConfig.url + "/api/version").then(r => r.text()).then((response) => {
document.getElementById("footer").innerHTML = "
WebRTC-Streamer " + JSON.parse(response).split(" ")[0] + "
";});
}
window.onbeforeunload = function () { this.webRtcServer.disconnect() }
}
//==============给排水===========================
IndexPage.prototype.showJiPaiShui = function () {
layer.closeAll();
$(".btn_li").attr("class", "btn_li");
$("#jipaishuiBtn").attr("class", "btn_li action");
setTimeout(function () {
layer.open({
type: 1,
shade: 0.8,
skin: 'myLayer',
title: false,
area: ["985px", "750px"],
content: $('#jpaishui'),
cancel: function () {
indexPage.runAutoRoute = false;
if (indexPage.showAutoRunRouteTimeIndex) {
clearTimeout(indexPage.showAutoRunRouteTimeIndex);
}
if (window.parent && window.parent.parent && window.parent.parent.closeAutoRoute) {
window.parent.parent.closeAutoRoute();
}
$(".btn_li").attr("class", "btn_li");
},
success: function () {
webapi.getDeviceList(config.water.deviceTypeId, function (result) {
console.log(result);
var _html = "";
var meteids = [];
if (result && result.length > 0) {
result = result.sort(function (a, b) { return a.type - b.type });
var typenub = 0;
$.each(result, function (_index, _obj) {
if (_obj.type != typenub) {
typenub = _obj.type;
_html += "
}
_html += '
' + (_obj.name.indexOf("泵") >= 0 && _obj.name.indexOf("井") < 0 ? '' : '') + '\
\
if (\_obj.extra && \_obj.extra.length>0) {
$.each(\_obj.extra, function (\_eindex, \_eobj) {
\_html += '<div style="height:33px;width:' + (\_obj.extra.length > 2 ? "50%" : "100%") + ';line-height:33px !important;">\\
<font style="float:left;color:white;margin-left:5px;font-size:12px;">' + \_eobj.key + ':<font id="meteValue\_' + \_eobj.value + '" data-keyname="' + \_eobj.key + '"></font></font>\\
</div>';
meteids.push(\_eobj.value);
})
}
// \_html += '<div style="height:33px;width:100%;line-height:33px !important;">\\
// <font style="float:left;color:white;margin-left:5px;font-size:12px;">高液位:<font id="meteValue\_' + \_obj.extra\[0\].value + '"></font></font>\\
//</div>\\
//<div style="height:33px;width:100%;line-height:33px !important;">\\
// <font style="float:left;color:white;margin-left:5px;font-size:12px;">底液位:<font id="meteValue\_' + \_obj.extra\[1\].value + '"></font></font>\\
//</div>';
\_html += '<div class="divBtn" style="margin-left:90px;" onclick="indexPage.showEDevAlarmListByDev(\\'' + \_obj.serialNumber + '\\')">\\
查看告警记录\\
</div>\\
</div>';
// meteids.push(\_obj.extra\[1\].value);
});
}
$("#waterCotent").html(\_html);
//获取量的值
webapi.bulkGetRealTimeData(meteids, function (data) {
if (data && data.length > 0) {
$.each(data, function (\_dindex, \_dobj) {
if ($("#meteValue\_" + \_dobj.pointId).attr("data-keyname").indexOf("手自动") >= 0) {
$("#meteValue\_" + \_dobj.pointId).html(\_dobj.value == "1" ? "自动" : "手动");
} else if ($("#meteValue\_" + \_dobj.pointId).attr("data-keyname").indexOf("运行状态") >= 0) {
$("#meteValue\_" + \_dobj.pointId).html(\_dobj.value == "1" ? "运行" : "停止");
if (\_dobj.value == "1") {
var dclass = $("div\[data-runid\*='\_" + \_dobj.pointId + "\_'\]").attr("class");
$("div\[data-runid\*='\_" + \_dobj.pointId + "\_'\]").attr("class", dclass + " RunSW");
}
} else if ($("#meteValue\_" + \_dobj.pointId).attr("data-keyname").indexOf("高液位") >= 0) {
$("#meteValue\_" + \_dobj.pointId).html(\_dobj.value == "0" ? "正常" : "<font style='color:red;'>报警</font>");
if (\_dobj.value!="0") {
$("div\[data-runid\*='\_" + \_dobj.pointId + "\_'\]").attr("class", "jipaishuiGW");
}
} else if ($("#meteValue\_" + \_dobj.pointId).attr("data-keyname").indexOf("低液位") >= 0) {
$("#meteValue\_" + \_dobj.pointId).html(\_dobj.value == "0" ? "正常" : "<font style='color:red;'>报警</font>");
if (\_dobj.value != "0") {
$("div\[data-runid\*='\_" + \_dobj.pointId + "\_'\]").attr("class", "jipaishuiDSW");
}
} else {
$("#meteValue\_" + \_dobj.pointId).html(\_dobj.value == "1" ? "<font style='color:red;'>报警</font>" : "正常");
}
$("#meteValueRun\_" + \_dobj.pointId).html(\_dobj.value == "1" ? "运行" : "停止");
})
}
})
}, true);
}
});
}, 200);
}
//==============送排风===========================
IndexPage.prototype.songpaifeng = function () {
layer.closeAll();
$(".btn_li").attr("class", "btn_li");
$("#songpaifengBtn").attr("class", "btn_li action");
setTimeout(function () {
layer.open({
type: 1,
shade: 0.8,
skin: 'myLayer',
title: false,
area: ["975px", "750px"],
content: $('#songfeng'),
cancel: function () {
indexPage.runAutoRoute = false;
if (indexPage.showAutoRunRouteTimeIndex) {
clearTimeout(indexPage.showAutoRunRouteTimeIndex);
}
if (window.parent && window.parent.parent && window.parent.parent.closeAutoRoute) {
window.parent.parent.closeAutoRoute();
}
$(".btn_li").attr("class", "btn_li");
},
success: function () {
webapi.getDeviceList(config.wind.deviceTypeId, function (result) {
console.log(result);
var _html = "";
var meteids = [];
if (result && result.length > 0) {
$.each(result, function (_index,_obj) {
_html += '
\
\
meteids.push(\_obj.extra\[0\].value);
meteids.push(\_obj.extra\[1\].value);
});
}
$("#songfengContent").html(\_html);
//获取量的值
webapi.bulkGetRealTimeData(meteids, function (data) {
if (data && data.length > 0) {
$.each(data, function (\_dindex, \_dobj) {
if ($("#meteValue\_" + \_dobj.pointId).attr("data-keyname").indexOf("手自动") >= 0) {
$("#meteValue\_" + \_dobj.pointId).html(\_dobj.value == "1" ? "自动" : "手动");
} else if ($("#meteValue\_" + \_dobj.pointId).attr("data-keyname").indexOf("运行状态") >= 0) {
$("#meteValue\_" + \_dobj.pointId).html(\_dobj.value == "1" ? "运行" : "停止");
if (\_dobj.value == "1") {
$("#meteValueRunState\_" + \_dobj.pointId).attr("class", "songPaiFengFS Run");
} else {
$("#meteValueRunState\_" + \_dobj.pointId).attr("class", "songPaiFengFS");
}
} else {
$("#meteValue\_" + \_dobj.pointId).html(\_dobj.value == "1" ? "<font style='color:red;'>报警</font>" : "正常");
}
$("#meteValueRun\_" + \_dobj.pointId).html(\_dobj.value == "1" ? "运行" : "停止");
})
}
})
}, true);
}
});
}, 200);
}
//================告警列表========================
IndexPage.prototype.showAlarmsList = function () {
var _this = this;
layer.open({
type: 1,
shade: 0.8,
skin: 'myLayer',
title: false,
area: ["700px", "650px"],
content: $('#alarmsList'),
cancel: function () {
indexPage.runAutoRoute = false;
if (indexPage.showAutoRunRouteTimeIndex) {
clearTimeout(indexPage.showAutoRunRouteTimeIndex);
}
if (window.parent && window.parent.parent && window.parent.parent.closeAutoRoute) {
window.parent.parent.closeAutoRoute();
}
$("#AlarmListResult").html("");
},
success: function () {
_this.flashAlarmList(layer.load());
}
});
}
IndexPage.prototype.flashAlarmList = function (layerloadindex) {
webapi.getAlarmDataList(function (records) {
if (layerloadindex) {
layer.close(layerloadindex);
}
if (records && records.length > 0) {
console.log(records);
var _html = '';
var nub = 0;
$.each(records, function (_index, _obj) {
if (_obj.device) {//存在设备信息
nub++;
_html += '
设备类型: | \' + getDeviceTypeById(_obj.device.deviceTypeId) + ' | \设备名称: | \' + _obj.device.name + ' | \报警时间: | \' + _obj.time + ' | \
报警原因: | \ \ 巡游报警位置 解除报警 | \
}
});
$("#alarmListNub").html(nub);
$("#AlarmListResult").html(\_html);
}
});
}
IndexPage.prototype.showAlarmPosition = function (deviceTypeid, id, name, serialNumber) {
layer.closeAll();
switch (""+deviceTypeid) {
case config.water.deviceTypeId:
indexPage.showJiPaiShui()
break;
case config.dataCenter.deviceTypeId:
indexPage.showDataCenter(serialNumber);
break;
case config.powerCenter.deviceTypeId:
indexPage.showBianDianZhan();
break;
case config.wind.deviceTypeId:
indexPage.songpaifeng()
break;
case config.energy.deviceTypeId:
break;
case config.lift.deviceTypeId:
indexPage.selectControl('lift')
break;
case config.environment.deviceTypeId:
indexPage.selectControl('environment');
break;
case config.aircontrol.deviceTypeId:
indexPage.selectControl('aircontrol')
break;
case config.fire.deviceTypeId:
indexPage.selectControl('fire')
break;
case config.video.deviceTypeId:
indexPage.selectControl('video');
break;
case config.radio.deviceTypeId:
indexPage.selectControl('radio')
break;
case config.door.deviceTypeId:
indexPage.selectControl('door')
break;
case config.TV.deviceTypeId:
indexPage.selectControl('TV')
break;
}
setTimeout(function () {
var tvmodel = WT3DObj.commonFunc.findObject("devLogo_" + indexPage.currentMebuType + "_" + id + "_" + name)
if (tvmodel) {
WT3DObj.commonFunc.changeCameraPosition({ x: tvmodel.position.x + 500, y: tvmodel.position.y + 500, z: tvmodel.position.z + 500 }, tvmodel.position,
500, function () {
WT3DObj.commonFunc.flashObjs(\[tvmodel\], "0x000000", "0x00ffff", 10, 200, 0);
});
}
}, 2000);
}
IndexPage.prototype.cancelAlarm = function (id) {
layer.confirm("是否确认解除该报警?", function () {
var layerloadindex=layer.load();
webapi.deviceAlarmRelieve(id, function (res) {
layer.close(layerloadindex);
if (res.status == 200) {
layer.msg("解除成功");
$("#alarmDetal_" + id).remove();
_this.flashAlarmList();
} else {
layer.msg("解除失败");
console.log(res);
}
})
}, function () {
})
}
//=============门禁=============================
IndexPage.prototype.doorPage = function (id, name) {
var _this = this;
$("#chart_" + id).show();
createCSystemStatic(id, name, config.door.deviceTypeId, false, function (result) {
_this.showDoorListDetail(result);
});
}
IndexPage.prototype.showDoorListDetail = function (result) {
var _this = this;
var html = "";
result = result.sort(function (a, b) { return b.onlineState - a.onlineState });
$.each(result, function (_index, _obj) {
html += _this.showDoorDetail(_obj);
});
$("#door_2").html(html);
_this.getDoorState();
}
IndexPage.prototype.showDoorDetail = function (_obj,td) {
var html = '
return html;
}
IndexPage.prototype.doorCloseOpenBtn = function (devControlBtnId) {
var className = $("#" + devControlBtnId).attr("class");
var devid = $("#" + devControlBtnId).attr("data-id");// devControlBtnId.split("_")[devControlBtnId.split("_").length-1];
var sSate = $("#" + devControlBtnId).attr("data-senserSate");
if (sSate == "2") {
layer.tips("状态未知", "#" + devControlBtnId);
return;
}
if (className.indexOf("closeBtn") < 0){
layer.confirm("是否确认关门",{title:"远程关门"}, function () {
webapi.remoteDoorCloseById(devid, function (res) {
if (res.status == 200) {
layer.closeAll();
layer.msg("远程关门成功");
$("#" + devControlBtnId).attr("class", "doorLi_openClose closeBtn");
} else {
console.log(res);
layer.msg("远程关门异常:" + res.msg);
}
})
}, function () { })
} else {
layer.confirm("开门时长:秒", { title: "远程开门" }, function () {
var loadindex= layer.load();
var timelong = parseInt($("#timeLong").val());
webapi.remoteDoorOpenById(devid, timelong, function (res) {
layer.close(loadindex);
if (res&&res.status &&res.status == 200) {
layer.closeAll();
layer.msg("远程开门成功");
$("#" + devControlBtnId).attr("class", "doorLi_openClose");
} else {
console.log(res);
layer.msg("远程开门失败:"+res.msg);
}
})
}, function () { })
}
}
IndexPage.prototype.getDoorState = function (fromCache) {
webapi.getAllDoorState(function (dataList) {
/*
alarm: "0"
connect: "1"
deviceId: "40288a857a514c53017a516404210970"
id: "40288a857a514c53017a5164042b09c9"
name: "192.168.10.219-1"
relay: "0"
sensor: "0"
*/
var doorStateobj = {}
if (dataList && dataList.length > 0) {
$.each(dataList, function (_index, _obj) {
doorStateobj\["door\_" + \_obj.id\] = \_obj;
});
}
var doorClist = webapi.DeviceListCache\["deviceType\_" + config.door.deviceTypeId\]
if (doorClist) {
$.each(doorClist, function (\_index, \_obj) {
if (doorStateobj\["door\_" + \_obj.serialNumber\]) {
var doorState = doorStateobj\["door\_" + \_obj.serialNumber\];
\_obj.name = doorState.name;
\_obj.onlineState = doorState.connect;//设备链接状态(0离线,1在线,2禁用)
\_obj.doorId = doorState.id;
\_obj.doorSensorState = doorState.sensor;//门磁状态(0未知,1无门磁,2关闭,3打开)
\_obj.alarm = doorState.alarm;//报警状态(无,报警,门开超时,门被意外打开,防拆,胁迫密码 开门,胁迫指纹开门,胁迫开门,门开超时,常开报警,电池电压过低,立即更 换电池,非法操作,后备电源,未知)
\_obj.relay = doorState.relay;//继电器状态(0关闭,1打开,2未知)
if (\_obj.relay + "" == "0") {
$("#doorCloseOpenBtn\_" + \_obj.serialNumber).attr("class", "doorLi\_openClose closeBtn")
$("#doorCloseOpenBtn\_3d\_" + \_obj.serialNumber).attr("class", "doorLi\_openClose closeBtn")
$("#doorCloseOpenBtn\_" + \_obj.serialNumber).html("关")
$("#doorCloseOpenBtn\_3d\_" + \_obj.serialNumber).html("关")
} else if (\_obj.relay + "" == "2") {//未知
$("#doorCloseOpenBtn\_" + \_obj.serialNumber).attr("class", "doorLi\_openClose nouse")
$("#doorCloseOpenBtn\_3d\_" + \_obj.serialNumber).attr("class", "doorLi\_openClose nouse");
$("#doorCloseOpenBtn\_" + \_obj.serialNumber).html("未知")
$("#doorCloseOpenBtn\_3d\_" + \_obj.serialNumber).html("未知")
}
else if (\_obj.relay + "" == "1") {//打开
$("#doorCloseOpenBtn\_" + \_obj.serialNumber).attr("class", "doorLi\_openClose")
$("#doorCloseOpenBtn\_3d\_" + \_obj.serialNumber).attr("class", "doorLi\_openClose");
$("#doorCloseOpenBtn\_" + \_obj.serialNumber).html("开")
$("#doorCloseOpenBtn\_3d\_" + \_obj.serialNumber).html("开")
}
$("#doorCloseOpenBtn\_" + \_obj.serialNumber).attr("data-senserSate", \_obj.relay);
$("#doorCloseOpenBtn\_3d\_" + \_obj.serialNumber).attr("data-senserSate", \_obj.relay);
$("#doorCloseOpenBtn\_" + \_obj.serialNumber).attr("data-id", \_obj.doorId)
$("#doorCloseOpenBtn\_3d\_" + \_obj.serialNumber).attr("data-id", \_obj.doorId)
$("#doorDetailDiv\_" + \_obj.serialNumber + " .doorLi\_DivTopName").attr("title",\_obj.name);
$("#doorDetailDiv\_" + \_obj.serialNumber + " .doorLi\_DivTopName").html(\_obj.name);
if (\_obj.onlineState + "" == "1") {
$("#doorDetailDiv\_" + \_obj.serialNumber + " .doorLi\_DivTopState").html("在线")
$("#doorDetailDiv\_3d\_" + \_obj.serialNumber).attr("class", "doorLi\_Div")
$("#doorDetailDiv\_" + \_obj.serialNumber).attr("class", "doorLi\_Div")
} else {
if (\_obj.onlineState + "" == "0") {
$("#doorDetailDiv\_" + \_obj.serialNumber + " .doorLi\_DivTopState").html("离线")
} else {
$("#doorDetailDiv\_" + \_obj.serialNumber + " .doorLi\_DivTopState").html("禁用")
}
$("#doorDetailDiv\_" + \_obj.serialNumber).attr("class", "doorLi\_Div offline")
$("#doorDetailDiv\_3d\_" + \_obj.serialNumber).attr("class", "doorLi\_Div offline")
}
$("#doorShowEventListBtn\_" + \_obj.serialNumber).attr("onclick", "indexPage.showDoorEvent('" + \_obj.ssid + "')")
$("#doorShowEventListBtn\_3d\_" + \_obj.serialNumber).attr("onclick", "indexPage.showDoorEvent('" + \_obj.ssid + "')")
}
});
}
console.log("门禁状态:");
console.log(dataList);
/\*
alarm: "0"报警状态(无,报警,门开超时,门被意外打开,防拆,胁迫密码 开门,胁迫指纹开门,胁迫开门,门开超时,常开报警,电池电压过低,立即更 换电池,非法操作,后备电源,未知)
connect: "1"设备链接状态(0离线,1在线,2禁用)
deviceId: "40288a857a514c53017a5163b37b06d5"
id: "40288a857a514c53017a5163b3d0072e"
name: "192.168.10.206-1"
relay: "0"继电器状态(关闭,打开,未知
sensor: "0" 门磁状态(未知,无门磁,关闭,打开)
*/
}, fromCache)
}
IndexPage.prototype.showDoorEvent = function (deviceSn) {
var _this = this;
layer.open({
type: 1,
shade: 0.8,
skin: 'myLayer',
title: false,
area: ["700px", "615px"],
content: $('#doorEventList'),
colseBtn:0,
cancel: function () {
_this.runAutoRoute = false;
if (indexPage.showAutoRunRouteTimeIndex) {
clearTimeout(indexPage.showAutoRunRouteTimeIndex);
}
if (window.parent && window.parent.parent && window.parent.parent.closeAutoRoute) {
window.parent.parent.closeAutoRoute();
}
},
success: function () {
var startTime = new Date().format("yyyy-MM-dd 00:00:00");
var endTime = new Date().format("yyyy-MM-dd hh:mm:ss");
$("#doorEventStartTime").val(startTime);
$("#doorEventEndTime").val(endTime);
$("#doorDevicecSn").val(deviceSn);
\_this.searchDoorEventEvent();
//webapi.transactionDevice(deviceSn, startTime, endTime, 1, 1000, function (data) {
// if (data && data.length > 0) {
// \_this.addDoorEventList(data);
// } else {
// }
//});
//layer.close(layerLoadindex);
}
});
}
IndexPage.prototype.searchDoorEventEvent = function () {
//var startTime = new Date().format("yyyy-MM-dd 00:00:00");
//var endTime = new Date().format("yyyy-MM-dd hh:mm:ss");
var layerLoadindex = layer.load();
var deviceSn = $("#doorDevicecSn").val();
var startTime = $("#doorEventStartTime").val();
var endTime = $("#doorEventEndTime").val();
//var timeleng = (new Date(endTime).getTime() - new Date(startTime).getTime()) / 1000 / 3600 / 24;
//if (timeleng < 0 || timeleng > 30) {
// layer.tips("查询间隔需在30天内", "#doorEventEndTime", {
// tips: [1, '#fc8b11'],
// time: 4000
// });
// layer.close(layerLoadindex)
// return;
//}
webapi.transactionDevice(deviceSn, startTime, endTime, 1, 1000, function (data) {
layer.close(layerLoadindex)
if (data && data.length > 0) {
_this.addDoorEventList(data);
} else {
$("#doorEventListResult").html("
}
});
}
/*
id 设备id
eventTime Date 记录设备触发时间
deptName 部门名称
areaName 区域名称
cardNo 卡号
pin 人员编号
name 人员名称
lastName 人员姓名,英文下才有用
devSn 设备序列号
verifyModeName 验证方式名称
eventName 事件描述
eventPointName 事件出发点名称
readerName 读头名称
devName 设备名称
logId 事件索引值,根据设备是否支持才有值
*/
IndexPage.prototype.addDoorEventList = function (data){
var _html = ' ';
var pins = [];
$.each(data, function (_index, _obj) {
if (_obj.eventName.indexOf("连接断开") < 0
&& _obj.eventName.indexOf("设备启动") < 0
&& _obj.eventName.indexOf("取消报警") < 0
) {
if (\_obj.pin && \_obj.pin!="") {
pins.push(\_obj.pin);
}
\_html += ' <div style="width:100%;float:left;margin-top:15px;">\\
<div style="float:left;width:85px;">\\
<img id="personPhoto\_' + \_obj.pin + "\_" + \_index + '" src="../img/pics/icons/doorP.png" style="width:65px;height:80px;margin-left:15px; border:1px solid #32C5FF" />\\
</div>\\
<div style="float:left;width:590px;">\\
<table class="doorEventTable">\\
<tr>\\
<td class="doorEvent\_paramName">事件</td>\\
<td class="doorEvent\_paramValue">' + \_obj.eventName + '</td>\\
<td class="doorEvent\_paramName">进入时间</td>\\
<td class="doorEvent\_paramValue">' + (new Date(\_obj.eventTime).format("yyyy-MM-dd hh:mm:ss")) + '</td>\\
</tr>\\
<tr>\\
<td class="doorEvent\_paramName">姓名</td>\\
<td class="doorEvent\_paramValue">' + \_obj.name + '</td>\\
<td class="doorEvent\_paramName">所属部门</td>\\
<td class="doorEvent\_paramValue">' + \_obj.deptName + '</td>\\
</tr>\\
</table>\\
</div>\\
</div>';
}
});
$("#doorEventListResult").html(_html);
webapi.getPerson(pins + "", function (data) {
if (data && data.length > 0) {
$.each(data, function (\_index, \_obj) {
if (\_obj.personPhoto && \_obj.personPhoto!="") {
$("img\[id^='personPhoto\_" + \_obj.pin + "\_'\]").attr("src", "data:image/jpg;base64," + \_obj.personPhoto);
$("img\[id^='personPhoto\_" + \_obj.pin + "\_'\]").css("cursor", "url('../img/pics/icons/fangdajingSmall.png'), auto");
$("img\[id^='personPhoto\_" + \_obj.pin + "\_'\]").click(function () {
layer.open({
type: 1,
shade: 0.8,
skin: 'myLayer',
title: false,
area: \["350px", "420px"\],
content: '<img src="data:image/jpg;base64,' + \_obj.personPhoto + '" style="width:325px;height:400px;margin-left:15px; border:1px solid #32C5FF" />',
colseBtn: 0,
cancel: function () {
},
success: function () {
}
});
});
}
});
}
});
}
//==============信息发布=============================
IndexPage.prototype.TVPage = function (id, name) {
var _this = this;
$("#chart_" + id).show();
createCSystemStatic(id, name, config.TV.deviceTypeId,false, function (result) {
_this.showTVListDetail(result);
});
}
IndexPage.prototype.showTVListDetail = function (result) {
var _this = this;
var html = "";
result = result.sort(function (a, b) { return b.onlineState - a.onlineState });
$.each(result, function (_index, _obj) {
html += _this.showTVDetail(_obj);
});
$("#TV_2").html(html);
}
IndexPage.prototype.showTVDetail = function (_obj, td) {
if (_obj.onlineState == 1) {
webapi.getTVScreenshot(_obj.serialNumber, function (res) {
if (res.status == 200 && res.data && res.data.img) {
$("#TVLi_DivBottomImg_" + (td ? td + "_" : "") + _obj.serialNumber).attr("src", res.data.img);
$("#TVLi_DivBottomImg_" + _obj.serialNumber).attr("src", res.data.img);
}
});
}
var html = '
\ \ | \ |
设置音量 | \设备重启 |
return html;
}
IndexPage.prototype.changeTVDetail = function (_obj,td) {
_obj.onlineState = 0;
var html = '
\ \ | \ |
设置音量 | \设备重启 |
$(".TVLi_Div[data-id^='" + _obj.serialNumber + td + "']").attr("class", "TVLi_Div offline");
$(".TVLi_Div[data-id^='" + _obj.serialNumber + td + "']").html(html);
var tvmodel = WT3DObj.commonFunc.findObject("devLogo_TV_" + _obj.id + "_" + _obj.name)
if (tvmodel) {
var textture = WT3DObj.createSkinPic(WT3DObj, null, null, {
imgurl: "../img/icons/tvLogo_offline.png",
});
tvmodel.material.map = textture;
}
}
IndexPage.prototype.TVCloseOpenBtn = function (devControlBtnId, state) {
if (state != "1") {
//layer.msg("设备离线,无法控制");
return;
}
var className = $("#" + devControlBtnId).attr("class");
var devid = devControlBtnId.split("_")[devControlBtnId.split("_").length - 1];
if (className.indexOf("closeBtn") >= 0) {
layer.confirm("是否确认关机", { title: "远程关机" }, function () {
var loadindex = layer.load();
var data = {
data: [devid]
}
webapi.TVDoAction(data, "shutdown", function (res) {
if (res.status == 200) {
layer.closeAll();
var tvlist = webapi.DeviceListCache\["deviceType\_" + config.TV.deviceTypeId\];
if (tvlist && tvlist.length > 0) {
$.each(tvlist, function (\_index, \_obj) {
if (\_obj.serialNumber == devid) {
indexPage.changeTVDetail(\_obj, "");
indexPage.changeTVDetail(\_obj,"3d");
}
});
}
layer.msg("远程关机成功");
// $("#" + devControlBtnId).attr("class", "doorLi\_openClose closeBtn");
} else {
console.log(res);
layer.msg("远程关机异常:" + res.msg);
}
layer.close(loadindex);
})
}, function () { })
}
}
IndexPage.prototype.setTVRestart = function (id, state) {
if (state != "1") {
// layer.msg("设备离线,无法控制");
return;
}
layer.confirm("是否确认重启", {
title: "重启设备"
}, function () {
layer.msg("重启命令已发送");
var loadindex = layer.load();
var data = {
data: [id]
}
webapi.TVDoAction(data, "reboot", function (res) {
console.log(res);
layer.close(loadindex);
if (res.status == 200) {
layer.closeAll();
layer.msg("重启命令成功!");
} else {
layer.msg("命令发送失败:" + res.msg);
}
})
}, function () { })
}
IndexPage.prototype.setTVVolume = function (id, state) {
if (state != "1") {
// layer.msg("设备离线,无法控制");
return;
}
layer.confirm('
title: "音量设置",
success: function () {
layui.use('slider', function () {
var $ = layui.$
, slider = layui.slider;
//默认滑块
slider.render({
elem: '#slideTest1',
change: function (value) {
$("#slideTest1Value").val(value);
console.log('当前数值:' + value);
}
});
});
}
}, function () {
var loadindex = layer.load();
var data = {
data: [id],
volume: parseInt($("#slideTest1Value").val())
}
webapi.TVDoAction(data, "setVolume", function (res) {
console.log(res);
layer.close(loadindex);
if (res.status == 200) {
layer.closeAll();
layer.msg("音量设置成功!");
} else {
layer.msg("命令发送失败:" + res.msg);
}
})
}, function () { })
}
IndexPage.prototype.showTVScreenshot = function (id, state) {
if (state != "1") {
// layer.msg("设备离线,无法控制");
return;
}
layer.load();
webapi.getTVScreenshot(id, function (res) {
layer.closeAll();
console.log(res);
if (res.status == 200 && res.data) {
var width = res.data.width;
var height = res.data.height;
if (width > 1000) {
width = 1000;
height = height * 1000 / res.data.width;
}
if (window.parent && window.parent.parent && window.parent.parent.openAutoRoute) {
window.parent.parent.openAutoRoute();
}
layer.open({
type: 1,
shade: 0.8,
skin: 'myLayer',
title: res.data.programName + "-信息展示",
area: [width + "px", (height + 50) + "px"],
content: "",
cancel: function () {
if (window.parent && window.parent.parent && window.parent.parent.closeAutoRoute) {
window.parent.parent.closeAutoRoute();
}
},
success: function () {
}
});
} else {
layer.msg("获取失败:" + res.msg);
}
})
}
//=============电梯==========================
IndexPage.prototype.liftPage = function (id, name) {
$("#chart_" + id).show();
createCSystemStatic(id, name, config.lift.deviceTypeId,true);
var data = indexPage.liftVideoCache;
if (data && data.length > 0) {
$("#lift\_title\_1").html(data\[0\].label);
$("#lift\_title\_2").html(data\[1\].label);
indexPage.commonFunc.addVideo("lift\_video1", config.videoBaseUrl, data\[0\].value);
$("#lift\_video1\_title").html(data\[0\].label);
indexPage.commonFunc.addVideo("lift\_video2", config.videoBaseUrl, data\[1\].value);
$("#lift\_video2\_title").html(data\[1\].label);
}
}
IndexPage.prototype.showVideoWin = function (index) {
var data = indexPage.liftVideoCache;
var videoobj = data[index];
if (window.parent && window.parent.parent && window.parent.parent.openAutoRoute) {
window.parent.parent.openAutoRoute();
}
html = '
layer.open({
type: 1,
shade: 0.8,
skin: 'myLayer',
title: videoobj.label + "-实时视频",
area: ["450px", "350px"],
content: html,
cancel: function () {
if (window.parent && window.parent.parent && window.parent.parent.closeAutoRoute) {
window.parent.parent.closeAutoRoute();
}
},
success: function () {
}
});
}
//=============消防==============================
IndexPage.prototype.firePage = function (id, name) {
$("#chart_" + id).show();
createCSystemStatic(id, name, config.fire.deviceTypeId);
}
//==============空调=============================
IndexPage.prototype.aircontrolPage = function (id, name) {
var _this = this;
$("#chart_" + id).show();
createCSystemStatic(id, name, config.aircontrol.deviceTypeId, false, function (result) {
_this.showAircontrolListDetail(result);
});
}
IndexPage.prototype.showAircontrolListDetail = function (result) {
var _this = this;
var html = "";
var meteids = [];
result = result.sort(function (a, b) { return b.onlineState - a.onlineState });
result = result.sort(function (a, b) { return b.type - a.type });
$.each(result, function (_index, _obj) {
html += _this.showAircontrolDetail(_obj);
$.each(_obj.extra, function (_eindex, _eobj) {
if (_eobj.key == "开关") {
meteids.push(_eobj.value);
}
if (_eobj.key == "模式") {
meteids.push(_eobj.value);
}
if (_eobj.key == "温度") {
meteids.push(_eobj.value);
}
});
});
$("#aircontrol_2").html(html);
_this.getOpenCloseState(meteids);
}
IndexPage.prototype.showAircontrolDetail = function (_obj, td) {
var data_openid = "";
var data_zlid = "";
var data_tempid = "";
var data_ms = "";
var data_temp = "";
$.each(_obj.extra, function (_eindex, _eobj) {
if (_eobj.key == "开关") {
data_openid = _eobj.value;
}
if (_eobj.key == "模式") {
data_ms = _eobj.value;
}
if (_eobj.key == "温度") {
data_temp = _eobj.value;
}
if (_eobj.key == "模式控制") {
data_zlid = _eobj.value;
}
if (_eobj.key == "温度控制") {
data_tempid = _eobj.value;
}
});
var html = '
return html;
}
IndexPage.prototype.getOpenCloseState= function (meteIDs) {
webapi.bulkGetRealTimeData(meteIDs, function (data) {
if (data && data.length > 0) {
$.each(data, function (_dindex, _dobj) {
$("div\[data-modelmeteid='" + \_dobj.pointId + "'\]").css("color", \_dobj.value + "" == "2" ? "#C3EEFF" : "#FF8484");
$("font\[data-modelmeteid='" + \_dobj.pointId + "'\]").html( \_dobj.value+""=="2"?"制冷":"制热");
$("font\[data-tempmeteid='" + \_dobj.pointId + "'\]").html( \_dobj.value + "℃");
$("div\[data-openid='" + \_dobj.pointId + "'\]").attr("data-state", \_dobj.value)
$(".airControlLi\_btn\_1\[data-openmeteid='" + \_dobj.pointId + "'\]").attr("data-state", \_dobj.value)
$(".airControlLi\_divBtn2\[data-openmeteid='" + \_dobj.pointId + "'\]").attr("data-state", \_dobj.value)
if (\_dobj.value + "" == "0") {
$("font\[data-modelopenid='" + \_dobj.pointId + "'\]").hide();
$("font\[data-tempopenid='" + \_dobj.pointId + "'\]").hide();
$("div\[data-openid='" + \_dobj.pointId + "'\]").html("关")
$("div\[data-openid='" + \_dobj.pointId + "'\]").attr("class", "airControlLi\_openClose closeBtn")
$(".airControlLi\_btn\_1\[data-openmeteid='" + \_dobj.pointId + "'\]").attr("class", "airControlLi\_btn\_1 nouse");
$(".airControlLi\_divBtn2\[data-openmeteid='" + \_dobj.pointId + "'\]").attr("class", "airControlLi\_divBtn2 nouse");
}else{
$("font\[data-modelopenid='" + \_dobj.pointId + "'\]").show();
$("font\[data-tempopenid='" + \_dobj.pointId + "'\]").show();
$("div\[data-openid='" + \_dobj.pointId + "'\]").html("开")
$("div\[data-openid='" + \_dobj.pointId + "'\]").attr("class", "airControlLi\_openClose")
$(".airControlLi\_btn\_1\[data-openmeteid='" + \_dobj.pointId + "'\]").attr("class", "airControlLi\_btn\_1");
$(".airControlLi\_divBtn2\[data-openmeteid='" + \_dobj.pointId + "'\]").attr("class", "airControlLi\_divBtn2");
}
});
}
})
}
IndexPage.prototype.setCoolTemp = function (serialNumber,td) {
if ($("#airControlBtn1_" +(td ? td + "_" : "") + serialNumber).attr("data-state")=="0") {
return;
}
layer.confirm("是否确认调节为制冷模式", { title: "调节为制冷模式" }, function () {
var loadindex=layer.load();
var meteid = "";
var airlist = webapi.DeviceListCache["deviceType_" + config.aircontrol.deviceTypeId];
if (airlist && airlist.length > 0) {
$.each(airlist, function (\_index,\_obj) {
if (\_obj.serialNumber == serialNumber) {
$.each(\_obj.extra, function (\_eindex, \_eobj) {
if (\_eobj.key == "模式控制") {
meteid = \_eobj.value;
}
})
}
});
}
webapi.bulkSetRealTimeData(meteid, 2, function (res) {
layer.close(loadindex);
if (res.status == 200) {
layer.closeAll();
layer.msg("调节为制冷模式成功");
} else {
console.log(res);
layer.msg("调节为制冷模式异常:" + res.msg);
}
})
}, function () { })
}
IndexPage.prototype.setHotTemp = function (serialNumber, td) {
if ($("#airControlBtn2_" +(td ? td + "_" : "") + serialNumber).attr("data-state") == "0") {
return;
}
layer.confirm("是否确认调节为制热模式", { title: "调节为制热模式" }, function () {
var loadindex = layer.load();
var meteid = "";
var airlist = webapi.DeviceListCache["deviceType_" + config.aircontrol.deviceTypeId];
if (airlist && airlist.length > 0) {
$.each(airlist, function (_index, _obj) {
if (_obj.serialNumber == serialNumber) {
$.each(_obj.extra, function (_eindex, _eobj) {
if (_eobj.key == "模式控制") {
meteid = _eobj.value;
}
})
}
});
}
webapi.bulkSetRealTimeData(meteid,1, function (res) {
layer.close(loadindex);
if (res.status == 200) {
layer.closeAll();
layer.msg("调节为制热模式成功");
} else {
console.log(res);
layer.msg("调节为制热模式异常:" + res.msg);
}
})
}, function () { })
}
IndexPage.prototype.airControlCloseOpenBtn = function (devControlBtnId) {
var className = $("#" + devControlBtnId).attr("class");
var serialNumber = devControlBtnId.split("_")[devControlBtnId.split("_").length - 1];
if (className.indexOf("closeBtn")< 0) {
layer.confirm("是否确认关闭", { title: "远程关闭" }, function () {
var loadindex = layer.load();
var meteid = "";
var airlist = webapi.DeviceListCache["deviceType_" + config.aircontrol.deviceTypeId];
if (airlist && airlist.length > 0) {
$.each(airlist, function (_index, _obj) {
if (_obj.serialNumber == serialNumber) {
$.each(_obj.extra, function (_eindex, _eobj) {
if (_eobj.key == "开关控制") {
meteid = _eobj.value;
}
})
}
});
}
webapi.bulkSetRealTimeData(meteid, 0, function (res) {
layer.close(loadindex);
if (res.status == 200) {
layer.closeAll();
layer.msg("远程关闭成功");
//修改按钮样式
$("#" + devControlBtnId).attr("class", "airControlLi_openClose closeBtn");
$("#" + devControlBtnId).html("关");
$("#airControlBtn1_" + serialNumber).attr("class", "airControlLi_btn_1 nouse");
$("#airControlBtn2_" + serialNumber).attr("class", "airControlLi_btn_1 nouse");
$("#airControlBtn3_" + serialNumber).attr("class", "airControlLi_divBtn2 nouse");
$("#airControlBtn1_" + serialNumber).attr("data-state", "0");
$("#airControlBtn2_" + serialNumber).attr("data-state", "0");
$("#airControlBtn3_" + serialNumber).attr("data-state", "0");
$("#airControlLi_DivBottomImg_" + serialNumber+" font").hide();
} else {
console.log(res);
layer.msg("远程关闭异常:" + res.msg);
}
})
}, function () { })
} else {
layer.confirm("远程开启", { title: "远程开启" }, function () {
var loadindex = layer.load();
var timelong = parseInt($("#timeLong").val());
var meteid = "";
var airlist = webapi.DeviceListCache["deviceType_" + config.aircontrol.deviceTypeId];
if (airlist && airlist.length > 0) {
$.each(airlist, function (_index, _obj) {
if (_obj.serialNumber == serialNumber) {
$.each(_obj.extra, function (_eindex, _eobj) {
if (_eobj.key == "开关控制") {
meteid = _eobj.value;
}
})
}
});
}
webapi.bulkSetRealTimeData(meteid, 1, function (res) {
layer.close(loadindex);
if (res.status == 200) {
layer.closeAll();
layer.msg("远程开启成功");
//修改按钮样式
$("#" + devControlBtnId).attr("class", "airControlLi\_openClose");
$("#" + devControlBtnId).html("开");
$("#airControlBtn1\_" + serialNumber).attr("class", "airControlLi\_btn\_1");
$("#airControlBtn2\_" + serialNumber).attr("class", "airControlLi\_btn\_1");
$("#airControlBtn3\_" + serialNumber).attr("class", "airControlLi\_divBtn2");
$("#airControlBtn1\_" + serialNumber).attr("data-state", "1");
$("#airControlBtn2\_" + serialNumber).attr("data-state", "1");
$("#airControlBtn3\_" + serialNumber).attr("data-state", "1");
$("#airControlLi\_DivBottomImg\_" + serialNumber + " font").show();
} else {
console.log(res);
layer.msg("远程开启失败:" + res.msg);
}
})
}, function () { })
}
}
IndexPage.prototype.setAirConfigTempTure = function (serialNumber, td) {
if ($("#airControlBtn3_" +(td ? td + "_" : "") + serialNumber).attr("data-state") == "0") {
return;
}
layer.confirm('
title: "温度设置",
success: function (){
layui.use('slider', function () {
var $ = layui.$
, slider = layui.slider;
//默认滑块
var ins1 = slider.render({
elem: '#slideTest1',
min: 16 //最小值
, max: 30, //最大值
change: function (value) {
$("#slideTest1Value").val(value);
// console.log('当前数值:' + value);
}
});
//获取值
var meteid = "";
var airlist = webapi.DeviceListCache\["deviceType\_" + config.aircontrol.deviceTypeId\];
if (airlist && airlist.length > 0) {
$.each(airlist, function (\_index, \_obj) {
if (\_obj.serialNumber == serialNumber) {
$.each(\_obj.extra, function (\_eindex, \_eobj) {
if (\_eobj.key == "温度") {
meteid = \_eobj.value;
}
})
}
});
}
webapi.bulkGetRealTimeData(\[meteid\], function (data) {
if (data && data.length > 0) {
$.each(data, function (\_dindex, \_dobj) {
ins1.setValue(parseInt(\_dobj.value)-16);
});
}
})
});
}
}, function () {
var loadindex = layer.load();
var meteid = "";
var airlist = webapi.DeviceListCache\["deviceType\_" + config.aircontrol.deviceTypeId\];
if (airlist && airlist.length > 0) {
$.each(airlist, function (\_index, \_obj) {
if (\_obj.serialNumber == serialNumber) {
$.each(\_obj.extra, function (\_eindex, \_eobj) {
if (\_eobj.key == "温度控制") {
meteid = \_eobj.value;
}
})
}
});
}
webapi.bulkSetRealTimeData(meteid, parseInt($("#slideTest1Value").val()), function (res) {
layer.close(loadindex);
console.log(res);
if (res.status == 200) {
layer.closeAll();
layer.msg("设置成功!");
} else {
layer.msg("命令发送失败:" + res.msg);
}
})
}, function () { })
}
//===============环境============================
IndexPage.prototype.environmentPage = function (id, name) {
var _this = this;
$("#chart_" + id).show();
createCSystemStatic(id, name, config.environment.deviceTypeId, false, function (result) {
_this.showEnvironmentListDetail(result);
});
}
IndexPage.prototype.showEnvironmentListDetail = function (result) {
var _this = this;
var html = "";
var meteids = [];
result = result.sort(function (a, b) { return b.onlineState - a.onlineState });
$.each(result, function (_index, _obj) {
var hobj = _this.showEnvironmentDetail(_obj);
html += hobj.html;
meteids = meteids.concat(hobj.meteids);
});
$("#environment_2").html(html);
setTimeout(function () {
_this.flashEnvironmentDetailValue(meteids);
}, 200);
if (_this.flashEnvironmentDetailValueInterval) {
clearInterval(_this.flashEnvironmentDetailValueInterval);
}
_this.flashEnvironmentDetailValueInterval = setInterval(function () {
if (_this.currentMebuType == "environment" && meteids.length>0) {
_this.flashEnvironmentDetailValue(meteids);
} else {
clearInterval(_this.flashEnvironmentDetailValueInterval);
}
},5000);
}
IndexPage.prototype.flashEnvironmentDetailValueInterval = null;
IndexPage.prototype.flashEnvironmentDetailValue = function (meteids) {
var _this=this;
webapi.bulkGetRealTimeData(meteids, function (data) {
if (data && data.length > 0) {
$.each(data, function (_dindex, _dobj) {
var keyname = $("#devParamValue_" + _dobj.pointId).attr("data-keyname");
if (keyname) {
if (keyname.indexOf("温度") >= 0) {
_dobj.value += "℃";
} else if (keyname.indexOf("湿度") >= 0) {
_dobj.value += "%";
}
}
console.log("#devParamValue_" + _dobj.pointId)
console.log(_dobj.value)
$("#devParamValue_" + _dobj.pointId).html(_dobj.value);
});
}
});
}
IndexPage.prototype.showEnvironmentDetail = function (_obj) {
var html = '
var meteids = [];
if (_obj && _obj.extra && _obj.extra.length > 0) {
$.each(\_obj.extra, function (\_eindex, \_eobj) {
if (\_eobj.key.indexOf("控制") < 0) {
html += ' <div class="fireLi\_DivMete">\\
<div class="fireLi\_DivMeteName">\\
' + \_eobj.key+ ':\\
</div>\\
<div class="fireLi\_DivMeteValue" data-keyname="' + \_eobj.key + '" id="devParamValue\_' + \_eobj.value + '">\\
<img src="../plugs/layer/layui/css/modules/layer/default/loading-1.gif" style="width:16px;height:16px;" />\\
</div>\\
</div>';
meteids.push(\_eobj.value);
}
});
}
html += '
return {
html:html,
meteids:meteids
};
}
IndexPage.prototype.showMetesValueDetail = function (objname) {
var devType = objname.split("\_")\[1\];
var devId = objname.split("\_")\[3\];
var devName = objname.split("\_")\[4\];
var devdatas = modelList\[devType\].data;
var devinfo = null;
$.each(devdatas, function (\_index, \_obj) {
if (\_obj.id == devId) {
devinfo = \_obj;
}
})
var html = ' <div class="fireLi\_Div3D" id="showMetes\_' + devId + '">\\
<div class="fireLi\_DivTop3D" >\\
<font class="fireLi\_DivTopName3D" title="' + devName + '">' + devName + '</font>\\
</div>\\
<div class="fireLi\_DivContent" id="showMeteContent3D\_' + devId + '" style="height: 90px;overflow-y: auto;"><img src="../plugs/layer/layui/css/modules/layer/default/loading-1.gif" style="width:16px;height:16px;margin-top:30px;margin-left:200px;" />';
html += '
setTimeout(function () {
webapi.getDevValue(devId, function (response) {
if (response && response.result ) {
_obj = response.result;
if (_obj && _obj.values && _obj.values.length > 0) {
var _mhtml = "";
$.each(_obj.values, function (_eindex, _eobj) {
{
if(_eobj.key){
\_eobj.sValue2 = \_eobj.sValue;
if (\_eobj.sValue == "END") {
\_eobj.sValue2 = "无告警"
} else if (\_eobj.sValue == "BEGIN") {
\_eobj.sValue2 = "<font style='color:red;'>告警</font>"
}
\_mhtml += ' <div class="fireLi\_DivMete" style="width:50%;">\\
<div class="fireLi\_DivMeteName" style="width:65%;">\\
' + \_eobj.meteName + ':\\
</div>\\
<div class="fireLi\_DivMeteValue" style="width:35%;">' + \_eobj.sValue2 + (\_eobj.unit ? \_eobj.unit : "") + '\\
</div>\\
</div>';
}
}
});
if (\_obj.objState == "OFFLINE") {
$("#showMetes\_" + devId).attr("class", "fireLi\_Div3D offline");
}
$("#showMeteContent3D\_" + devId).html(\_mhtml);
}
} else {
console.log("error:获取设备失败,eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee");
}
});
}, 200);
return html;
}
IndexPage.prototype.showAirControlMetesValueDetail = function (seobj) {
var _obj = seobj;
var html = '
var meteids = [];
if (_obj && _obj.extra && _obj.extra.length > 0) {
$.each(\_obj.extra, function (\_eindex, \_eobj) {
if (\_eobj.key.indexOf("控制") < 0) {
html += ' <div class="fireLi\_DivMete" style="width:50%;">\\
<div class="fireLi\_DivMeteName">\\
' + \_eobj.key + ':\\
</div>\\
<div class="fireLi\_DivMeteValue" data-keyname="' + \_eobj.key + '" id="devParamValue3D\_' + \_eobj.value + '">\\
<img src="../plugs/layer/layui/css/modules/layer/default/loading-1.gif" style="width:16px;height:16px;" />\\
</div>\\
</div>';
meteids.push(\_eobj.value);
}
});
}
html += '
webapi.bulkGetRealTimeData(meteids, function (data) {
if (data && data.length > 0) {
$.each(data, function (_dindex, _dobj) {
var keyname = $("#devParamValue3D_" + _dobj.pointId).attr("data-keyname");
if (keyname) {
if (keyname.indexOf("开关") >= 0) {
\_dobj.value = (\_dobj.value == 0 ? "关" : "开");
} else if (keyname.indexOf("模式") >= 0) {
\_dobj.value = (\_dobj.value == 1 ? "制热" : "制冷");
} else if (keyname.indexOf("报警状态") >= 0) {
\_dobj.value = (\_dobj.value == 0 ? "正常" : "<font style='color:red;'>告警</font>");
} else if (keyname.indexOf("状态") >= 0) {
\_dobj.value = (\_dobj.value == 0 ? "停止" : "<font style='color:red;'>开启</font>");
}
}
$("#devParamValue3D\_" + \_dobj.pointId).html(\_dobj.value);
$("#devParamValue\_" + \_dobj.pointId).html(\_dobj.value);
});
}
})
return html;
}
IndexPage.prototype.showAllMeteListByDev = function (devId) {
$('#devMeteListResult').html("");
var _this = this;
layer.open({
type: 1,
shade: 0.8,
skin: 'myLayer',
title: false,
area: ["700px", "615px"],
content: $('#devAllMeteList'),
colseBtn: 0,
cancel: function () {
},
success: function () {
webapi.getDevValue(devId, function (response) {
if (response && response.result) {
\_obj = response.result;
$("#devTitle").html(\_obj.objName )
if (\_obj && \_obj.values && \_obj.values.length > 0) {
var \_mhtml = "";
\_obj.values = \_obj.values.sort(function (a, b) { return a.sort - b.sort });
$.each(\_obj.values, function (\_eindex, \_eobj) {
if (\_eobj.key) {
\_eobj.sValue2 = \_eobj.sValue;
if (\_eobj.sValue == "END") {
\_eobj.sValue2 = "无告警"
} else if (\_eobj.sValue == "BEGIN") {
\_eobj.sValue2 = "<font style='color:red;'>告警</font>"
}
\_mhtml += ' <div class="fireLi\_DivMete" style="width:50%;border: 1px solid rgba(255,255,255,0.1);">\\
<div class="fireLi\_DivMeteName" style="width:65%;text-align:center;">\\
' + \_eobj.meteName + ':\\
</div>\\
<div class="fireLi\_DivMeteValue" style="width:35%;text-align:center;">' + \_eobj.sValue2 + '\\
</div>\\
</div>';
}
});
\_mhtml += '<div style="background: rgba(115,134,164,0.5);width:100%;border: 1px solid rgba(255,255,255,0.1);"></div>';
$.each(\_obj.values, function (\_eindex, \_eobj) {
if (!\_eobj.key) {
\_eobj.sValue2 = \_eobj.sValue;
if (\_eobj.sValue == "END") {
\_eobj.sValue2 = "无告警"
} else if (\_eobj.sValue == "BEGIN") {
\_eobj.sValue2 = "<font style='color:red;'>告警</font>"
}
\_mhtml += ' <div class="fireLi\_DivMete" style="width:50%;border: 1px solid rgba(255,255,255,0.1);">\\
<div class="fireLi\_DivMeteName" style="width:65%;text-align:center;">\\
' + \_eobj.meteName + ':\\
</div>\\
<div class="fireLi\_DivMeteValue" style="width:35%;text-align:center;">' + \_eobj.sValue2 + '\\
</div>\\
</div>';
}
});
$("#devMeteListResult").html(\_mhtml);
}
} else {
console.log("error:获取设备失败,eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee");
}
});
}
});
}
IndexPage.prototype.showEDevAlarmListByDev = function (devId) {
var _this = this;
layer.open({
type: 1,
shade: 0.8,
skin: 'myLayer',
title: false,
area: ["700px", "615px"],
content: $('#devAlarmList'),
colseBtn:0,
cancel: function () {
_this.runAutoRoute = false;
if (indexPage.showAutoRunRouteTimeIndex) {
clearTimeout(indexPage.showAutoRunRouteTimeIndex);
}
if (window.parent && window.parent.parent && window.parent.parent.closeAutoRoute) {
window.parent.parent.closeAutoRoute();
}
},
success: function () {
var StartTime = new Date().format("yyyy-MM-01 00:00:00");
var EndTime = new Date().format("yyyy-MM-dd hh:mm:ss");
$("#alarmStartTime").val(StartTime);
$("#alarmEndTime").val(EndTime);
$("#selectEAlarmDevid").val(devId);
\_this.showAlarmListByDev(devId, StartTime, EndTime);
}
});
}
IndexPage.prototype.showAlarmListByDev = function (devId, StartTime, EndTime) {
var layerLoadindex = layer.load();
webapi.getAlarmDataList(function (records) {
layer.close(layerLoadindex);
if (records && records.length > 0) {
if ($("#alarmDevSort").val() == 1) {
records = records.sort(function (a, b) {
return new Date(a.createTime).getTime() - new Date(b.createTime).getTime()
})
} else {
records = records.sort(function (a, b) {
return new Date(b.createTime).getTime() - new Date(a.createTime).getTime()
})
}
console.log(records);
var \_html = '';
$.each(records, function (\_index, \_obj) {
if (\_obj.device) {
\_html += '<div style="float:left;width:99%;">\\
<table class="devAlarmTable">\\
<tr>\\
<td class="devAlarm\_paramName">报警类型</td>\\
<td class="devAlarm\_paramValue">' + \_obj.message + '</td>\\
<td class="devAlarm\_paramName">报警时间</td>\\
<td class="devAlarm\_paramValue">' + \_obj.createTime + '</td>\\
<td class="devAlarm\_paramName">解除时间</td>\\
<td class="devAlarm\_paramValue">' + \_obj.updateTime + '</td>\\
</tr>\\
</table>\\
</div>';
}
});
$("#devAlarmListResult").html(\_html);
} else {
$("#devAlarmListResult").html("<div style='width:100%;text-align:center;'>查无数据</div>");
}
}, devId,StartTime, EndTime);
}
//==============广播============================
IndexPage.prototype.radioPage = function (id, name) {
var _this = this;
$("#chart_" + id).show();
createCSystemStatic(id, name, config.radio.deviceTypeId, false, function (result) {
_this.showRadioListDetail(result);
});
}
IndexPage.prototype.showRadioListDetail = function (result) {
var _this = this;
var html = "";
result = result.sort(function (a, b) { return b.onlineState - a.onlineState });
$.each(result, function (_index, _obj) {
html += _this.showRadioDetail(_obj);
});
$("#radio_2").html(html);
}
IndexPage.prototype.showRadioDetail = function (_obj, td) {
var html = '
\
音量调节:\
\
//
return html;
}
IndexPage.prototype.setRadioVolume = function (id, state) {
if (state != "1") {
layer.msg("设备离线,无法控制");
return;
}
layer.confirm('
title: "音量设置",
success: function () {
layui.use('slider', function () {
var $ = layui.$
, slider = layui.slider;
//默认滑块
slider.render({
elem: '#slideTest1',
min: 0 //最小值
, max: 15, //最大值,
change: function (value) {
$("#slideTest1Value").val(value);
console.log('当前数值:' + value);
}
});
});
}
}, function () {
var data = {
data: [id],
volume: parseInt($("#slideTest1Value").val())
}
webapi.setmachinecodece(id, parseInt($("#slideTest1Value").val()), function (res) {
console.log(res);
if (res.msg && res.status!=200) {
layer.msg(res.msg);
}else{
layer.closeAll();
}
});
}, function () { })
}
IndexPage.prototype.RadioCloseOpenBtn = function (devControlBtnId) {
var className = $("#" + devControlBtnId).attr("class");
var devid = devControlBtnId.split("_")[devControlBtnId.split("_").length - 1];
if (className.indexOf("closeBtn") >= 0) {
layer.msg("远程关机接口异常");
return;
layer.confirm("是否确认关机", { title: "远程关机" }, function () {
//webapi.remoteDoorCloseById(devid, function (res) {
// if (res.status == 200) {
// layer.closeAll();
// layer.msg("远程关机成功");
// // $("#" + devControlBtnId).attr("class", "doorLi\_openClose closeBtn");
// } else {
// console.log(res);
// layer.msg("远程关机异常:" + res.msg);
// }
//})
}, function () { })
} else {
layer.confirm("开门时长:秒", { title: "远程开门" }, function () {
var timelong = parseInt($("#timeLong").val());
webapi.remoteDoorOpenById(devid, timelong, function (res) {
if (res.status == 200) {
layer.closeAll();
layer.msg("远程开门成功");
$("#" + devControlBtnId).attr("class", "doorLi_openClose");
} else {
console.log(res);
layer.msg("远程开门失败:" + res.msg);
}
})
}, function () { })
}
}
//==============摄像头============================
IndexPage.prototype.videooPage = function (id, name) {
var _this = this;
$("#chart_" + id).show();
createCSystemStatic(id, name, config.video.deviceTypeId, false, function (result) {
_this.showVideoListDetail(result);
});
}
IndexPage.prototype.showVideoListDetail = function (result) {
var _this = this;
var html = "";
result = result.sort(function (a, b) { return b.onlineState - a.onlineState });
result = result.sort(function (a, b) { return b.status - a.status });
var showNub = 0;
$.each(result, function (_index, _obj) {
if (showNub < 6) {
showNub++;
html += _this.showVideoDetail(_obj);
}
});
$("#video_2").html(html);
$.each(result, function (_index, _obj) {
if (_index < 6) {
if (_obj.stream) {
indexPage.commonFunc.addVideo("videoList_" + _obj.id, config.videoBaseUrl, _obj.stream)
}
}
});
}
IndexPage.prototype.showVideoDetail = function (_obj) {
var html = '
return html;
}
//电梯
IndexPage.prototype.showLiftDetailByModel = function (modelName) {
$("#liftNub").html(config.liftRunningDetail[modelName].name);
var cameraId = config.Videos[modelName];
webapi.runningDetail(config.liftRunningDetail[modelName].identifier, function (data) {
$("#nowFloor").html(data.floor);
$("#liftequipmentStatus").html(data.equipmentStatus);
$("#lifttimes").html(data.times);
$("#liftmileage").html(data.mileage);
});
}
function createCSystemStatic(id, count, onlineState) {
$("#chart_" + id).show();
var _html = "
\ | \
|
";
$("#" + id + "_chart").html(_html);
$("#right_" + id + "_all").html(count);
$("#right_" + id + "_offline").html(count - onlineState);
$("#right_" + id + "_online").html(onlineState);
var rate = 0;
if (count > 0) {
rate = onlineState / count;
}
createDevRunPercent("index_chart1", rate);
}
function createCSystemRoomsStatic(id, count, onlineState) {
$("#chart_" + id).show();
var _html = "
\ | \
|
";
$("#" + id + "_chart").html(_html);
$("#right_" + id + "_all").html(count);
$("#right_" + id + "_offline").html(count - onlineState);
$("#right_" + id + "_online").html(onlineState);
var rate = 0;
if (count > 0) {
rate = onlineState / count;
}
createDevRunPercent("index_chart1", rate);
}
function createDevRunPercent(id,value) {
$("#" + id).html("
var myChart = echarts.init(document.getElementById(id + "_Chart"));
let title = '运行率';
let int = value.toFixed(2).split('.')[0];
let float = value.toFixed(2).split('.')[1];
var percent = parseInt(parseFloat(value.toFixed(2)) * 100)
option = {
title: {
text: '{a|' + percent + '}{b|%}\n{c|' + title + '}',
x: 'center',
y: 'center',
textStyle: {
rich: {
a: {
fontSize: 28,
color: '#fff',
fontWeight: '600',
},
b: {
fontSize: 16,
color: '#fff',
padding: [0, 0, 14, 0]
},
c: {
fontSize: 16,
color: '#fff',
padding: [5, 0]
}
}
}
},
series: [
{
type: 'gauge',
radius: '100%',
clockwise: false,
startAngle: '90',
endAngle: '-269.9999',
splitNumber: 30,
detail: {
offsetCenter: [0, -20],
formatter: ' '
},
pointer: {
show: false
},
axisLine: {
show: true,
lineStyle: {
color: [
[0, '#2CFAFC'],
[( 1 - (parseFloat(value.toFixed(2))==1?0.999: parseFloat(value.toFixed(2)))) , '#0ff'],
[1, '#0f232e']
],
width: 20
}
},
axisTick: {
show: false
},
splitLine: {
show: true,
length: 100,
lineStyle: {
shadowBlur: 10,
shadowColor: 'rgba(0, 255, 255, 1)',
shadowOffsetY: '0',
color: '#020f18',
width: 2
}
},
axisLabel: {
show: false
}
},
{
type: 'pie',
radius: ['74%', '75%'],
hoverAnimation: false,
clockWise: false,
itemStyle: {
normal: {
color: '#0C355E'
}
},
label: {
show: false
},
data: _dashed()
},
{
type: 'pie',
radius: \[0, '60%'\],
hoverAnimation: false,
clockWise: false,
itemStyle: {
normal: {
shadowBlur: 20,
shadowColor: '#000',
color: new echarts.graphic.RadialGradient(0.4, 0.3, 1, \[{
offset: 0,
color: '#0FF',
}, {
offset: 1,
color: '#060f20'
}\])
}
},
label: {
show: false
},
data: \[100\]
},
{
type: 'pie',
radius: \['94%', '95.5%'\],
hoverAnimation: false,
clockWise: false,
itemStyle: {
normal: {
shadowBlur: 20,
shadowColor: 'rgba(0, 255, 255,.3)',
color: '#0f232e'
}
},
label: {
show: false
},
data: \[100\]
},
{
type: 'pie',
radius: \['98%', '99.5%'\],
hoverAnimation: false,
clockWise: false,
itemStyle: {
normal: {
shadowBlur: 20,
shadowColor: 'rgba(0, 255, 255,.3)',
color: 'rgba(15, 35, 46,.6)',
}
},
label: {
show: false
},
data: \[100\]
},
\]
};
function \_dashed() {
let dataArr = \[\];
for (var i = 0; i < 100; i++) {
if (i % 2 === 0) {
dataArr.push({
name: (i + 1).toString(),
value: 20,
itemStyle: {
normal: {
color: 'rgb(0,255,255,.3)',
}
}
})
} else {
dataArr.push({
name: (i + 1).toString(),
value: 20,
itemStyle: {
normal: {
color: 'rgb(0,0,0,0)',
borderWidth: 1,
borderColor: "rgba(0,255,255,1)"
}
}
})
}
}
return dataArr
}
myChart.setOption(option);
}
//创建在线离线柱状图
function createDevNubs(id, allDates, onlinedatas) {
$("#" + id).html("
{
var myChart = echarts.init(document.getElementById(id + "_Chart"));
var salvProName = ["F13", "F12", "F11", "F10", "F9", "F8", "F7", "F6", "F5", "F4", "F3", "F2", "F1"];
var salvProValue = onlinedatas;
//for (var i = 0; i < 13; i++) {
// salvProValue.push(parseInt(Math.random()*100));
//}
var salvProMax = allDates;//背景按最大值
//for (let i = 0; i < salvProValue.length; i++) {
// salvProMax.push(100)
//}
option = {
grid: {
left: '2%',
right: '2%',
bottom: '2%',
top: '2%',
containLabel: true
},
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'none'
},
formatter: function (params) {
return params[0].name + ' : ' + params[0].value
}
},
xAxis: {
show: false,
type: 'value'
},
yAxis: [{
type: 'category',
inverse: true,
axisLabel: {
show: true,
textStyle: {
color: '#fff',fontSize:9
},
},
splitLine: {
show: false
},
axisTick: {
show: false
},
axisLine: {
show: false
},
data: salvProName
}, {
type: 'category',
inverse: true,
axisTick: 'none',
axisLine: 'none',
show: true,
axisLabel: {
textStyle: {
color: 'rgb(46,200,207,1)',
fontSize: '10'
},
},
data: salvProValue
}],
series: [{
name: '值',
type: 'bar',
zlevel: 1,
itemStyle: {
normal: {
barBorderRadius:9,
color: new echarts.graphic.LinearGradient(0, 0, 1, 0, [{
offset: 0,
color: 'rgb(46,200,207,0)'
}, {
offset: 1,
color: 'rgb(46,200,207,1)'
}]),
},
},
barWidth: 4,
data: salvProValue
},
{
name: '背景',
type: 'bar',
barWidth: 4,
barGap: '-100%',
data: salvProMax,
itemStyle: {
normal: {
color: 'rgba(24,31,68,1)',
barBorderRadius: 9,
}
},
},
{
name: '检查',
type: 'pictorialBar',
symbol: 'image://',
symbolSize: [18, 18], symbolPosition: 'end',
symbolOffset: [8, 0],
z: 12,
data: salvProValue
}
]
};
myChart.setOption(option);
}
{
var myChart = echarts.init(document.getElementById(id + "\_Chart2"));
var salvProName = \["F13", "F12", "F11", "F10", "F9", "F8", "F7", "F6", "F5", "F4", "F3", "F2", "F1"\];
var salvProValue = \[\];
//for (var i = 0; i < 13; i++) {
// salvProValue.push(parseInt(Math.random() \*30));
//}
var offlineData = \[\];
$.each(allDates, function (\_i,\_o) {
offlineData.push(\_o - onlinedatas\[\_i\]);
})
salvProValue = offlineData;
var salvProMax = allDates;//背景按最大值
//for (let i = 0; i < salvProValue.length; i++) {
// salvProMax.push(100)
//}
option = {
grid: {
left: '2%',
right: '2%',
bottom: '0%',
top: '2%',
containLabel: true
},
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'none'
},
formatter: function (params) {
return params\[0\].name + ' : ' + params\[0\].value
}
},
xAxis: {
show: false,
type: 'value'
},
yAxis: \[{
type: 'category',
inverse: true,
axisLabel: {
show: false,
textStyle: {
color: '#fff'
},
},
splitLine: {
show: false
},
axisTick: {
show: false
},
axisLine: {
show: false
},
data: salvProName
}, {
type: 'category',
inverse: true,
axisTick: 'none',
axisLine: 'none',
show: true,
axisLabel: {
textStyle: {
color: '#ff8D63',
fontSize: '10'
},
},
data: salvProValue
}\],
series: \[{
name: '值',
type: 'bar',
zlevel: 1,
itemStyle: {
normal: {
barBorderRadius: 9,
color: new echarts.graphic.LinearGradient(0, 0, 1, 0, \[{
offset: 0,
color: 'rgb(238,141,99,0)'
}, {
offset: 1,
color: '#EE8D63'
}\]),
},
},
barWidth: 4,
data: salvProValue
},
{
name: '背景',
type: 'bar',
barWidth: 4,
barGap: '-100%',
data: salvProMax,
itemStyle: {
normal: {
color: 'rgba(24,31,68,1)',
barBorderRadius: 9,
}
},
}
\]
};
myChart.setOption(option);
}
}
function showDevDetail(objname) {
//devType, devId, devName
//"devLogo_" + _this.functionState + "_" + _obj.type+"_" + _obj.id + "_" + _obj.name;
var devType = objname.split("\_")\[1\];
var devId = objname.split("\_")\[3\];
var devName = objname.split("\_")\[4\];
var html = "设备信息";
var height = "150px";
var width = "100px";
{
switch (devType) {
case "rooms": {
html = '
height = "50px"
width = "auto"
} break;
case "xzldb":
case "xfmdyl":
{
html = indexPage.showMetesValueDetail(objname);
height = "160px"
width = "415px"
} break;
case "door": {
html = indexPage.showDoorDetail(devDataInfo, "3d");
setTimeout(function () {
indexPage.getDoorState(true);
}, 200)
height = "220px"
width = "185px"
} break;
case "aircontrol": {
html = indexPage.showAirControlMetesValueDetail(devDataInfo);
height = "150px"
width = "270px"
} break;
case "radio": {
html = indexPage.showRadioDetail(devDataInfo);
height = "220px"
width = "185px"
} break;
case "fire": {
} break;
case "TV": {
html = indexPage.showTVDetail(devDataInfo, "3d");
height = "250px"
width = "185px"
} break;
case "video": {
html = '<div class="videoShowDiv' + (devDataInfo.onlineState == 1 ? "" : " offline") + '"" style="width: 190px;height:110px; float: left;">\\
<video id="videoDetail\_' + devDataInfo.id + '" muted playsinline controls style="width:190px; height:110px;position:relative;"></video>\\
<div class="indexVideoContent" style="position:relative;bottom:36px;">\\
<font class="indexVideoTitle">' + devDataInfo.name + '</font>\\
<font class="indexVideoState">' + (devDataInfo.onlineState == 1 ? "在线" : "离线") + '</font>\\
</div>\\
<div id="playbtn\_' + devDataInfo.id + '" style="position:relative;bottom:130px;width:100%;height:60px;padding-left:60px;cursor:pointer;" ><img onclick="$(\\'#playbtn\_' + devDataInfo.id + '\\').hide();indexPage.commonFunc.addVideo(\\'videoDetail\_' + devDataInfo.id + '\\', \\'' + config.videoBaseUrl + '\\', \\'' + devDataInfo.stream + '\\');" src="../img/pics/icons/play-filling.png" style="width:60px;height:60px;"/></div>\\
</div>';
height = "140px";
width = "220px";
//if (devDataInfo.stream) {
//setTimeout(function () {
//
//}, 1000);
//}
} break;
case "lift": { } break;
}
}
return {
html:html,
width: width,
height: height,
};
}
function showDevListByType(devType,list) {
switch (devType) {
case "door": { indexPage.showDoorListDetail(list); } break;
case "aircontrol": { indexPage.showAircontrolListDetail(list); } break;
case "radio": { indexPage.showRadioListDetail(list); } break;
case "fire": { } break;
case "TV": {indexPage.showTVListDetail(list);} break;
case "video": { indexPage.showVideoListDetail(list); } break;
case "environment": { indexPage.showEnvironmentListDetail(list); } break;
case "lift": { } break;
}
}
function getDevInfoByTypeIdAndDevId(tid,did) {
var devDatas = webapi.DeviceListCache["deviceType_" + tid];
var devinfo = null;
$.each(devDatas, function (_index, _obj) {
if (_obj.id == did) {
devinfo = _obj;
}
});
return devinfo;
}
由于篇幅原因,这一课先介绍到这里
后面我将继续讲解用webgl 建立 3D隧道、3D桥梁、webgl实现三维隧道桥梁、three.js实现三维隧道桥梁、桥梁隧道三维应用炫酷效果等等
技术交流 1203193731@qq.com
交流微信:
如果你有什么要交流的心得 可邮件我
其它相关文章:
使用webgl(three.js)创建3D机房,3D机房微模块详细介绍(升级版二)
如何用webgl(three.js)搭建一个3D库房-第一课
如何用webgl(three.js)搭建一个3D库房,3D密集架,3D档案室,-第二课
使用webgl(three.js)搭建一个3D建筑,3D消防模拟——第三课
使用webgl(three.js)搭建一个3D智慧园区、3D建筑,3D消防模拟,web版3D,bim管理系统——第四课
如何用webgl(three.js)搭建不规则建筑模型,客流量热力图模拟
使用webgl(three.js)搭建一个3D智慧园区、3D建筑,3D消防模拟,web版3D,bim管理系统——第四课(炫酷版一)
使用webgl(three.js)搭建3D智慧园区、3D大屏,3D楼宇,智慧灯杆三维展示,3D灯杆,web版3D,bim管理系统——第六课
手机扫一扫
移动阅读更方便
你可能感兴趣的文章