| var viewAB = "01";// 默认正面 | 
|   | 
| /** | 
|  * 根据设备列表渲染设备示意图,要求被渲染的divID = device_view | 
|  * | 
|  * @param listDevice | 
|  */ | 
| renderDevice = function (listDevice, depotId) { | 
|     // 首先清空div中的内容 | 
|     $("#device_view").empty(); | 
|     // 获取当前仓库效果图 | 
|     cutImg(depotId, viewAB); | 
|     // 根据设备列表添加原型信息 | 
|     addDevice(listDevice, viewAB); | 
| }; | 
|   | 
| // 切换图片a=正面,b=背面 | 
| function cutImg(depotId, target) { | 
|     //var imgData = areationImg[depotId]; | 
|     if (!depotId) | 
|         depotId = "default"; | 
|   | 
|     var imgPath = "../../static/img/areation/"+companyId+"/" + depotId+"_a.png"; | 
|     if (target == "02") | 
|         imgPath = "../../static/img/areation/"+companyId+"/" + depotId+"_b.png"; | 
|   | 
|     $("#device_view").css("background", | 
|         "url(" + imgPath + ") no-repeat 5px 5px"); | 
|   | 
|     viewAB = target; | 
| }; | 
|   | 
| // 动态添加设备信息 | 
| function addDevice(list) { | 
|     if (!list || list.length == 0) | 
|         return; | 
|     var mainImg = $("#device_view"); | 
|     var parentLeft = mainImg.offset().left, parentTop = mainImg.offset().top; | 
|   | 
|     var temp; | 
|     var left = 0, top = 0; | 
|     var imgResult; | 
|     $.each(list, function (index, item) { | 
|         // 获取PC的位置 | 
|         left = parentLeft + item.posX - 15; | 
|         top = parentTop + item.posY - 10; | 
|   | 
|         temp = ""; | 
|         if (viewAB == "01" && item.location == "02") { | 
|             return true;// 跳过 | 
|         } | 
|         if (viewAB == "02" && item.location == "01") { | 
|             return true;// 跳过 | 
|         } | 
|         imgResult = getStatusImg(item); | 
|         if (!imgResult.statusImg) { | 
|             return true;// 跳过 | 
|         } | 
|         temp += "<div id='" + item.id + "' class='device' " + "depotid='" | 
|             + item.depotId + "' name='" + item.name + "' type='" | 
|             + item.type + "' passcode='" + item.passCode + "' serid='" | 
|             + item.serId + "' posx='" + item.posXPad  | 
|             + "' posy='" + item.posYPad  | 
|             + "' status='" + item.status  | 
|             + "' link='" + item.link  | 
|             + "' select='false" | 
|             + "' onclick=showControl('" + item.id + "') style='left:" | 
|             + left + "px;top:" + top + "px;'>"; | 
|   | 
|         if (imgResult.statusImg.indexOf("gif") > 0) { | 
|             temp += "<img class='img_device' src='" + imgResult.statusImg | 
|                 + "' style='height:30px;' />"; | 
|         } else { | 
|             if (item.type == DeviceType.TYPE_04) { | 
|                 temp += "<img class='img_device' src='" + imgResult.statusImg | 
|                     + "' style='height:30px;' />"; | 
|             } else { | 
|                 temp += "<img class='img_device' src='" + imgResult.statusImg + "' />"; | 
|             } | 
|         } | 
|         //表示有故障 | 
|         if (imgResult.errorTag) { | 
|             temp += "<i class='err-img'></i>"; | 
|         } | 
|         temp += "</div>"; | 
|   | 
|         mainImg.append(temp); | 
|     }); | 
| }; | 
|   | 
| // 根据设备类型和状态,获取当前设备的显示状态图片 | 
| function getStatusImg(item) { | 
|     var result = { | 
|         statusImg: null, | 
|         errorTag: false | 
|     } | 
|   | 
|     if (!item.status || DeviceStatus.ERROR == item.status) { | 
|         result.statusImg = "../../static/img/device/lock.png"; | 
|         result.errorTag = true; | 
|         return result; | 
|     } | 
|     if (DeviceStatus.CLOSE == item.status) { | 
|         result.statusImg = "../../static/img/device/lock.png"; | 
|         return result; | 
|     } | 
|     if (DeviceStatus.OPEN == item.status) { | 
|         result.statusImg = "../../static/img/device/lock_open.png"; | 
|         return result; | 
|     } | 
|   | 
|     return result; | 
| }; | 
|   | 
| // 根据CSS标签控制那些组件支持拖拽.device | 
| function dragDevice() { | 
|     var tips = $(".device"); | 
|     if (tips.length == 0) { | 
|         return; | 
|     } | 
|     var container = $("#device_view"); | 
|     var parentLeft = container.offset().left, parentTop = container.offset().top; | 
|     // var height = container.outerHeight(); | 
|     var maxX = 1800, maxY = 1000; | 
|     $.each(tips, function (index, item) { | 
|         var dd = new Dragdrop({ | 
|             target: item, | 
|             area: [0, maxX, 0, maxY], | 
|             callback: function (obj) { | 
|                 console.log('x:' + (obj.moveX) + ' y:' + (obj.moveY)); | 
|             } | 
|         }); | 
|         dd.dragAll(); | 
|     }); | 
| }; | 
|   | 
| // 保存设备位置信息 | 
| function updatePos() { | 
|     var tips = $(".device"); | 
|     if (tips.length == 0) { | 
|         return; | 
|     } | 
|     var container = $("#device_view"); | 
|     var parentLeft = container.offset().left, parentTop = container.offset().top; | 
|     // 封装数据进行保存 | 
|     var data = new Array(); | 
|     var id = null, curDepotId = null, posXPad = 0, posYPad = 0; | 
|     var offset; | 
|   | 
|     $.each(tips, function (index, item) { | 
|         id = item.id; | 
|         posXPad = item.getAttribute("posx"); | 
|         posYPad = item.getAttribute("posy"); | 
|         curDepotId = item.getAttribute("depotid"); | 
|         offset = $('#' + id).offset(); | 
|   | 
|         data[index] = { | 
|             bizId: id, | 
|             depotId: curDepotId, | 
|             selfTag: viewAB, | 
|             posXPad: posXPad, | 
|             posYPad: posYPad, | 
|             posX: offset.left - parentLeft, | 
|             posY: offset.top - parentTop | 
|         }; | 
|     }); | 
|     $.ajax({ | 
|         type: 'POST', | 
|         url: "../../basic/common/update-door-pos", | 
|         dataType: 'JSON', | 
|         contentType: "application/json;charset=UTF-8", | 
|         data: JSON.stringify(data), | 
|         success: function (result) { | 
|             layer.msg(result.msg); | 
|         }, | 
|         error: function (result) { | 
|             layer.msg(result.msg); | 
|         } | 
|     }); | 
| }; | 
|   | 
| /** | 
|  * 根据设备类型和目标状态,调整动画效果 | 
|  * | 
|  * @param deviceType | 
|  *            设备类型 | 
|  * @param targetStatus | 
|  *            目标状态 | 
|  * @param isEnd | 
|  *            是否执行完成 | 
|  */ | 
| function updateAnimate(deviceType, targetStatus, isEnd) { | 
|     // 获取动效的操作 | 
|     var img = "../../static/img/device/lock.png"; | 
|     if (targetStatus == DeviceStatus.CLOSE) { | 
|         img = "../../static/img/device/lock.png"; | 
|         if (isEnd) | 
|             img = "../../static/img/device/lock.png"; | 
|     } | 
|     if (targetStatus == DeviceStatus.OPEN) { | 
|         img = "../../static/img/device/lock_open.png"; | 
|         if (isEnd) | 
|             img = "../../static/img/device/lock_open.png"; | 
|     } | 
|     $("#img_animate").attr('src', img); | 
| } |