From 86ad93ea04241928a06b06ab3fbe1c92faef9106 Mon Sep 17 00:00:00 2001
From: ZhuDongming <773644075@qq.com>
Date: Mon, 29 Jun 2020 16:39:14 +0800
Subject: [PATCH] update
---
src/main/webapp/js/newmoralmap.js | 93 ++++++++++++++++++++++++++++++++++------------
1 files changed, 69 insertions(+), 24 deletions(-)
diff --git a/src/main/webapp/js/newmoralmap.js b/src/main/webapp/js/newmoralmap.js
index 3a90815..b7842a8 100644
--- a/src/main/webapp/js/newmoralmap.js
+++ b/src/main/webapp/js/newmoralmap.js
@@ -644,6 +644,7 @@
return listView;
}
+
moralMap.MoralMarker = function (option) {
var _option = option;
var _pointObj = new BMap.Point(_option['longitude'], _option['latitude']);
@@ -696,21 +697,60 @@
})
}
- moralMap.WindMarker = function (option, target) {
+ moralMap.WindMarker = function (option, moralMap) {
var _option = option;
var _pointObj = new BMap.Point(_option['longitude'], _option['latitude']);
- var _iconObj = new BMap.Icon("/img/wind_dir.png", new BMap.Size(25, 25));
+ var _iconObj = _getWindIcon(1);
this._point = _pointObj;
+
+ function _getWindIcon(speedLevel) {
+ speedLevel = speedLevel == null ? 0 : speedLevel;
+ var icon = _option["icon"];
+ var url = icon["url"] + speedLevel + ".png";
+ return new BMap.Icon(url, new BMap.Size(icon["width"], icon["height"]), {
+ imageSize: new BMap.Size(icon["width"], icon["height"])
+ });
+ }
this.constructor.call(this, _pointObj, {
icon: _iconObj,
- offset: new BMap.Size(0, -35),
+ offset: new BMap.Size(0, -11),
enableMassClear: true
})
return $.extend(this, {
- refreshWindDir: function (windDir) {
+ refreshWindDir: function (windDir, windSpeed) {
//���������������������������������������������
- this.setRotation(windDir);
+ if (windDir == undefined || windSpeed == undefined) {
+ moralMap.removeOverlay(this);
+ } else {
+ var speedLevel;
+ if (windSpeed >= 0 && windSpeed <= 0.2) {
+ speedLevel = 0;
+ } else if (windSpeed > 0.2 && windSpeed <= 1.5) {
+ speedLevel = 1;
+ } else if (windSpeed > 1.5 && windSpeed <= 3.3) {
+ speedLevel = 2;
+ } else if (windSpeed > 3.3 && windSpeed <= 5.4) {
+ speedLevel = 3;
+ } else if (windSpeed > 5.4 && windSpeed <= 7.9) {
+ speedLevel = 4;
+ } else if (windSpeed > 7.9 && windSpeed <= 10.7) {
+ speedLevel = 5;
+ } else if (windSpeed > 10.7 && windSpeed <= 13.8) {
+ speedLevel = 6;
+ } else if (windSpeed > 13.8 && windSpeed <= 17.1) {
+ speedLevel = 7;
+ } else if (windSpeed > 17.1) {
+ speedLevel = 8;
+ }
+ if (speedLevel == 0) {
+ moralMap.removeOverlay(this);
+ } else {
+ var iconObj = _getWindIcon(speedLevel);
+ this.setIcon(iconObj);
+ this.setRotation(windDir);
+ }
+ }
},
getOption: function () {
return _option;
@@ -823,14 +863,19 @@
}
}
}
- var windMarker = new moralMap.WindMarker(option);
+ var icon = {};
+ icon["url"] = "/img/icoWind0";
+ icon["width"] = 25;
+ icon["height"] = 25;
+ option["icon"] = icon;
+ var windMarker = new moralMap.WindMarker(option, moralMap);
moralMap.putDevice(option['mac'], windMarker);
var refreshWindMarker = windMarker.refreshWindDir;
return $.extend(windMarker, {
refreshWindDir: function (data) {
if (data != null && data != "") {
this.setData(data); //������������
- refreshWindMarker.call(this, data["e23"]);
+ refreshWindMarker.call(this, data["e23"], data["e18"]);
}
},
setData: function (data) {
@@ -898,15 +943,15 @@
}
var mouseOverHandle = option['mouseover'];
moralMarker.addEventListener("mouseover", function () {
- /* var obj = {};
- obj['methodName'] = 'deliverMac';
- obj['mac'] = option['mac'];
- var objStr = JSON.stringify(obj);
- if (!!window['external'] && !!window['external']['callWin']) {
- window['external'].callWin(objStr);
- } else {
- alert(objStr);
- }*/
+ /* var obj = {};
+ obj['methodName'] = 'deliverMac';
+ obj['mac'] = option['mac'];
+ var objStr = JSON.stringify(obj);
+ if (!!window['external'] && !!window['external']['callWin']) {
+ window['external'].callWin(objStr);
+ } else {
+ alert(objStr);
+ }*/
moralMap.showSensors = function (jsonData) {
var deviceSensors = jsonData;
@@ -958,14 +1003,14 @@
});
moralMarker.addEventListener("mouseout", function () {
- /* var obj = {};
- obj['methodName'] = 'stopDeliverMac';
- var objStr = JSON.stringify(obj);
- if (!!window['external'] && !!window['external']['callWin']) {
- window['external'].callWin(objStr);
- } else {
- alert(objStr);
- }*/
+ /* var obj = {};
+ obj['methodName'] = 'stopDeliverMac';
+ var objStr = JSON.stringify(obj);
+ if (!!window['external'] && !!window['external']['callWin']) {
+ window['external'].callWin(objStr);
+ } else {
+ alert(objStr);
+ }*/
moralMap.closeInfoWindow();
});
--
Gitblit v1.8.0