tencent-map-support

This commit is contained in:
Eason010212
2025-07-29 01:37:48 +08:00
parent d35f1ebb8f
commit 9c7a118102
4 changed files with 652 additions and 326 deletions

View File

@@ -101,13 +101,13 @@ https://gitee.com/bnu_mixly/mixio-linux-x86-dist/blob/darwin/mixio
16. BAIDU_MAP_AK - string百度地图客户端应用AKOFFLINE_MODE=false时可配置默认为"" 16. BAIDU_MAP_AK - string百度地图客户端应用AKOFFLINE_MODE=false时可配置默认为""
17. BAIDU_MAP_SERVER_AK - string百度地图服务端应用AKOFFLINE_MODE=false时可配置默认为"" 17. BAIDU_MAP_SERVER_AK - string百度地图服务端应用AKOFFLINE_MODE=false时可配置默认为""
18. TENCENT_MAP_KEY - string, 腾讯地图keyOFFLINE_MODE=false时可配置默认为"",和百度地图二选一进行配置即可,同时配置时优先启用百度地图 18. TENCENT_MAP_KEY - string, 腾讯地图keyOFFLINE_MODE=false时可配置默认为"",和百度地图二选一进行配置即可,同时配置时优先启用百度地图
18. BAIDU_STAT_LINK - string, 百度统计链接,通常以"https://hm.baidu.com/hm.js?"开头 19. BAIDU_STAT_LINK - string, 百度统计链接,通常以"https://hm.baidu.com/hm.js?"开头
19. ADMIN_USERNAME - string管理后台用户名默认为"admin" 20. ADMIN_USERNAME - string管理后台用户名默认为"admin"
20. ADMIN_PASSWORD - string管理后台密码默认为"public" 21. ADMIN_PASSWORD - string管理后台密码默认为"public"
21. STORAGE_ENGINE - string数据库引擎默认为"sqlite" 22. STORAGE_ENGINE - string数据库引擎默认为"sqlite"
22. MYSQL_HOST - stringMySQL地址STORAGE_ENGINE="mysql"时必须配置),默认为"localhost" 23. MYSQL_HOST - stringMySQL地址STORAGE_ENGINE="mysql"时必须配置),默认为"localhost"
23. MYSQL_PORT - intMySQL地址STORAGE_ENGINE="mysql"时必须配置默认为3306 24. MYSQL_PORT - intMySQL地址STORAGE_ENGINE="mysql"时必须配置默认为3306
24. MYSQL_USER - stringMySQL用户名STORAGE_ENGINE="mysql"时必须配置),默认为"" 25. MYSQL_USER - stringMySQL用户名STORAGE_ENGINE="mysql"时必须配置),默认为""
25. MYSQL_PASS - stringMySQL密码STORAGE_ENGINE="mysql"时必须配置),默认为"" 26. MYSQL_PASS - stringMySQL密码STORAGE_ENGINE="mysql"时必须配置),默认为""
26. MYSQL_DB - stringMySQL数据库名STORAGE_ENGINE="mysql"时必须配置),默认为"mixio", 27. MYSQL_DB - stringMySQL数据库名STORAGE_ENGINE="mysql"时必须配置),默认为"mixio",
27. FOOTER - string显示在首页的备案信息公网部署时请务必配置此项支持HTML语言请注意为双引号添加转义字符\\),默认为"" 28. FOOTER - string显示在首页的备案信息公网部署时请务必配置此项支持HTML语言请注意为双引号添加转义字符\\),默认为""

View File

@@ -24,6 +24,9 @@
<% if (configs['OFFLINE_MODE']==false) { %> <% if (configs['OFFLINE_MODE']==false) { %>
<script>var baidu_ak = "<%=configs['BAIDU_MAP_AK']%>"</script> <script>var baidu_ak = "<%=configs['BAIDU_MAP_AK']%>"</script>
<% } %> <% } %>
<% if (configs['OFFLINE_MODE']==false) { %>
<script>var tencent_key = "<%=configs['TENCENT_MAP_KEY']%>"</script>
<% } %>
<script src="js/districts.js"></script> <script src="js/districts.js"></script>
<script src="js/jsgrid.min.js"></script> <script src="js/jsgrid.min.js"></script>
<script src="js/tools.js"></script> <script src="js/tools.js"></script>

View File

@@ -22,6 +22,9 @@
<% if (configs['OFFLINE_MODE']==false) { %> <% if (configs['OFFLINE_MODE']==false) { %>
<script>var baidu_ak = "<%=configs['BAIDU_MAP_AK']%>"</script> <script>var baidu_ak = "<%=configs['BAIDU_MAP_AK']%>"</script>
<% } %> <% } %>
<% if (configs['OFFLINE_MODE']==false) { %>
<script>var tencent_key = "<%=configs['TENCENT_MAP_KEY']%>"</script>
<% } %>
<script src="js/districts.js"></script> <script src="js/districts.js"></script>
<script src="js/jsgrid.min.js"></script> <script src="js/jsgrid.min.js"></script>
<script src="js/tools.js?v=14"></script> <script src="js/tools.js?v=14"></script>

View File

@@ -3762,342 +3762,662 @@ function add_dashboard(user_title, user_topic, user_content, user_style, title_s
function add_map(user_title, user_topic, user_content, user_style, title_style) { function add_map(user_title, user_topic, user_content, user_style, title_style) {
var modald = showmodaltext("<div style='text-align:center'><i class='fa fa-spin fa-cog' style='font-size:2rem;color:#4e73df'></i><p style='margin-top:6px;margin-bottom:0;color:#4e73df;font-size:1rem;font-weight:bold'>加载地图引擎...</p></div>") var modald = showmodaltext("<div style='text-align:center'><i class='fa fa-spin fa-cog' style='font-size:2rem;color:#4e73df'></i><p style='margin-top:6px;margin-bottom:0;color:#4e73df;font-size:1rem;font-weight:bold'>加载地图引擎...</p></div>")
$.getScript("//api.map.baidu.com/getscript?type=webgl&v=3.0&ak="+baidu_ak, function() { if(baidu_ak!='')
modald.close().remove() {
var isAlive = true $.getScript("//api.map.baidu.com/getscript?type=webgl&v=3.0&ak="+baidu_ak, function() {
var contents = [] modald.close().remove()
var title = $("<h4 class='userTitle'>" + user_title + "</h4>") var isAlive = true
title.attr("hidden", title_style) var contents = []
contents.push(title) var title = $("<h4 class='userTitle'>" + user_title + "</h4>")
var topicDiv = $("<div class='topicDiv'/>") title.attr("hidden", title_style)
var topic = $("<span class='index-topic' style='margin:0;color:#858796;'>" + user_topic + "</span>") contents.push(title)
topicDiv.append($("<i class='fa fa-podcast' style='color:#858796;margin-right:3px'></i>")) var topicDiv = $("<div class='topicDiv'/>")
topicDiv.append(topic) var topic = $("<span class='index-topic' style='margin:0;color:#858796;'>" + user_topic + "</span>")
var randomName = randomString() + "map" topicDiv.append($("<i class='fa fa-podcast' style='color:#858796;margin-right:3px'></i>"))
var mapDiv = $("<div style='width:calc(100% - 20px);height:calc(100% - 60px)'/>") topicDiv.append(topic)
mapDiv.attr("id", randomName) var randomName = randomString() + "map"
mapDiv.bind('click', function(event) { var mapDiv = $("<div style='width:calc(100% - 20px);height:calc(100% - 60px)'/>")
event.stopPropagation() mapDiv.attr("id", randomName)
}) mapDiv.bind('click', function(event) {
mapDiv.bind('pointerdown', function(event) { event.stopPropagation()
event.stopPropagation() })
}) mapDiv.bind('pointerdown', function(event) {
mapDiv.bind('mousedown', function(event) { event.stopPropagation()
event.stopPropagation() })
}) mapDiv.bind('mousedown', function(event) {
mapDiv[0].addEventListener('touchstart', function(event) { event.stopPropagation()
event.stopPropagation() })
}, { passive: false }) mapDiv[0].addEventListener('touchstart', function(event) {
contents.push(mapDiv) event.stopPropagation()
attrs = [ }, { passive: false })
['user-type', 'output_map'], contents.push(mapDiv)
['user-title', user_title], attrs = [
['user-topic', user_topic], ['user-type', 'output_map'],
['user-content', user_content], ['user-title', user_title],
['title-hidden', title_style] ['user-topic', user_topic],
] ['user-content', user_content],
var itemdiv = add_block(3, 3, contents, attrs) ['title-hidden', title_style]
var maxLeft = mapDiv[0].clientWidth ]
var maxTop = mapDiv[0].clientHeight var itemdiv = add_block(3, 3, contents, attrs)
var markers = [] var maxLeft = mapDiv[0].clientWidth
var setContent = function() { var maxTop = mapDiv[0].clientHeight
var tmp = [] var markers = []
for (marker in markers) { var setContent = function() {
console.log(markers[marker]) var tmp = []
tmp.push(markers[marker].long) for (marker in markers) {
tmp.push(markers[marker].lat) console.log(markers[marker])
tmp.push(markers[marker].time) tmp.push(markers[marker].long)
tmp.push(markers[marker].message) tmp.push(markers[marker].lat)
tmp.push(markers[marker].clientid) tmp.push(markers[marker].time)
tmp.push(markers[marker].message)
tmp.push(markers[marker].clientid)
}
title.parent().parent().attr('user-content', tmp.join("@#@$@"))
} }
title.parent().parent().attr('user-content', tmp.join("@#@$@")) itemdiv.bind(MixIO.actionTags.DATA_MAP_CHANGE, function(event, message) {
} MixIO.publish(topic.text(), JSON.stringify(message))
itemdiv.bind(MixIO.actionTags.DATA_MAP_CHANGE, function(event, message) { })
MixIO.publish(topic.text(), JSON.stringify(message)) itemdiv.bind(MixIO.actionTags.DATA_MAP_CLEAR, function() {
}) clear_on_click()
itemdiv.bind(MixIO.actionTags.DATA_MAP_CLEAR, function() { })
clear_on_click() client.on('message', function(topic1, message1) {
})
client.on('message', function(topic1, message1) {
if (isAlive && isRunning) if (isAlive && isRunning)
if (topic1.split("/")[(isMixly ? 3 : 2)] == topic.text()) { if (topic1.split("/")[(isMixly ? 3 : 2)] == topic.text()) {
var label = (new Date().getHours() + ":" + (new Date().getMinutes() < 10 ? "0" : "") + new Date().getMinutes() + ":" + (new Date().getSeconds() < 10 ? "0" : "") + new Date().getSeconds()) var label = ((new Date().getHours() < 10 ? "0" : "") + new Date().getHours() + ":" + (new Date().getMinutes() < 10 ? "0" : "") + new Date().getMinutes() + ":" + (new Date().getSeconds() < 10 ? "0" : "") + new Date().getSeconds())
if (isJSON(String(message1)) && ("long" in JSON.parse(String(message1))) && ("lat" in JSON.parse(String(message1))) && JSON.parse(String(message1)).clientid) { if (isJSON(String(message1)) && ("long" in JSON.parse(String(message1))) && ("lat" in JSON.parse(String(message1))) && JSON.parse(String(message1)).clientid) {
var jsonMessage = JSON.parse(String(message1)) var jsonMessage = JSON.parse(String(message1))
console.log(jsonMessage) console.log(jsonMessage)
itemdiv.trigger(MixIO.eventTags.DATA_MAP_CHANGED, [jsonMessage.clientid, jsonMessage.long, jsonMessage.lat, jsonMessage.message]) itemdiv.trigger(MixIO.eventTags.DATA_MAP_CHANGED, [jsonMessage.clientid, jsonMessage.long, jsonMessage.lat, jsonMessage.message])
var newOrNot = true var newOrNot = true
var markerIndex = -1 var markerIndex = -1
for (marker in markers) { for (marker in markers) {
if (jsonMessage.clientid == markers[marker].clientid) { if (jsonMessage.clientid == markers[marker].clientid) {
newOrNot = false newOrNot = false
markerIndex = marker markerIndex = marker
break break
}
} }
} if (newOrNot) {
if (newOrNot) { var msgstr = ""
var msgstr = "" if (typeof jsonMessage.message == "string")
if (typeof jsonMessage.message == "string") jsonMessage.message = JSON.parse(jsonMessage.message)
jsonMessage.message = JSON.parse(jsonMessage.message) for (msg in jsonMessage.message) {
for (msg in jsonMessage.message) { msgstr = msgstr + jsonMessage.message[msg].label + ":" + jsonMessage.message[msg].value + "<br>"
msgstr = msgstr + jsonMessage.message[msg].label + ":" + jsonMessage.message[msg].value + "<br>" }
} var point = new BMapGL.Point(jsonMessage.long, jsonMessage.lat)
var point = new BMapGL.Point(jsonMessage.long, jsonMessage.lat) var newMarker = new BMapGL.Marker(point)
var newMarker = new BMapGL.Marker(point) markerIndex = markers.length
markerIndex = markers.length var bubble = create_a_map_bubble(msgstr, label, point)
var bubble = create_a_map_bubble(msgstr, label, point) newMarker.bubble = bubble
newMarker.bubble = bubble console.log(msgstr)
console.log(msgstr) markers.push({
markers.push({ "clientid": jsonMessage.clientid,
"clientid": jsonMessage.clientid, "long": jsonMessage.long,
"long": jsonMessage.long, "lat": jsonMessage.lat,
"lat": jsonMessage.lat, "time": label,
"time": label, "message": msgstr,
"message": msgstr, "target": newMarker,
"target": newMarker, "point": point
"point": point })
}) if (markers.length == 1) {
if (markers.length == 1) { map.centerAndZoom(markers[markerIndex].point, 17);
map.centerAndZoom(markers[markerIndex].point, 17); }
} map.addOverlay(newMarker)
map.addOverlay(newMarker) newMarker.addEventListener('click', function() {
newMarker.addEventListener('click', function() { if (map.getOverlays().indexOf(bubble) == -1)
map.addOverlay(bubble)
else
map.removeOverlay(bubble)
})
map.addOverlay(bubble)
} else {
markers[markerIndex].time = label
var msgstr = ""
if (typeof jsonMessage.message == "string")
jsonMessage.message = JSON.parse(jsonMessage.message)
for (msg in jsonMessage.message) {
msgstr = msgstr + jsonMessage.message[msg].label + ":" + jsonMessage.message[msg].value + "<br>"
}
var point = new BMapGL.Point(jsonMessage.long, jsonMessage.lat)
markers[markerIndex].long = jsonMessage.long
markers[markerIndex].lat = jsonMessage.lat
markers[markerIndex].point = point
markers[markerIndex].message = msgstr
markers[markerIndex].target.bubble.setPosition(point)
markers[markerIndex].target.setPosition(point)
markers[markerIndex].target.bubble.setContent(label + "<br>" + msgstr)
if (map.getOverlays().indexOf(bubble) == -1) if (map.getOverlays().indexOf(bubble) == -1)
map.addOverlay(bubble) map.addOverlay(bubble)
else
map.removeOverlay(bubble)
})
map.addOverlay(bubble)
} else {
markers[markerIndex].time = label
var msgstr = ""
if (typeof jsonMessage.message == "string")
jsonMessage.message = JSON.parse(jsonMessage.message)
for (msg in jsonMessage.message) {
msgstr = msgstr + jsonMessage.message[msg].label + ":" + jsonMessage.message[msg].value + "<br>"
} }
var point = new BMapGL.Point(jsonMessage.long, jsonMessage.lat) setContent()
markers[markerIndex].long = jsonMessage.long } else {
markers[markerIndex].lat = jsonMessage.lat showtext(JSLang[lang].mapJSON)
markers[markerIndex].point = point
markers[markerIndex].message = msgstr
markers[markerIndex].target.bubble.setPosition(point)
markers[markerIndex].target.setPosition(point)
markers[markerIndex].target.bubble.setContent(label + "<br>" + msgstr)
if (map.getOverlays().indexOf(bubble) == -1)
map.addOverlay(bubble)
} }
setContent()
} else {
showtext(JSLang[lang].mapJSON)
} }
}
})
var map = new BMapGL.Map(randomName)
map.centerAndZoom(new BMapGL.Point(116.373, 39.967), 17)
map.enableScrollWheelZoom(true);
map.disableContinuousZoom();
map.disableInertialDragging();
var opts = {
offset: new BMapGL.Size(0, 0)
};
var label = new BMapGL.Label();
label.setStyle({
color: '#4e73df',
borderRadius: '5px',
borderColor: '#ccc',
backgroundColor: 'rgba(255,255,255,0.8)',
padding: '8px',
fontSize: '1rem',
fontFamily: 'Nunito'
});
map.addEventListener('mousemove', function(e) {
if (!isRunning) {
map.addOverlay(label)
label.setContent(e.latlng.lng.toFixed(4) + ',' + e.latlng.lat.toFixed(4))
label.setPosition(new BMapGL.Point(e.latlng.lng, e.latlng.lat))
} else
map.removeOverlay(label)
});
var toBeAdded = user_content.split("@#@$@")
var addLength = toBeAdded.length / 5
console.log(toBeAdded)
for (var tmpi = 0; tmpi <= addLength - 1; tmpi = tmpi + 1) {
var point = new BMapGL.Point(toBeAdded[tmpi * 5], toBeAdded[tmpi * 5 + 1])
var newMarker = new BMapGL.Marker(point)
var bubble = create_a_map_bubble(toBeAdded[tmpi * 5 + 3], toBeAdded[tmpi * 5 + 2], point)
newMarker.bubble = bubble
markers.push({
"long": toBeAdded[tmpi * 5],
"lat": toBeAdded[tmpi * 5 + 1],
"time": toBeAdded[tmpi * 5 + 2],
"message": toBeAdded[tmpi * 5 + 3],
"clientid": toBeAdded[tmpi * 5 + 4],
"target": newMarker,
"point": point
}) })
if (markers.length == 1) { var map = new BMapGL.Map(randomName)
map.centerAndZoom(point, 17); map.centerAndZoom(new BMapGL.Point(116.373, 39.967), 17)
} map.enableScrollWheelZoom(true);
map.addOverlay(newMarker) map.disableContinuousZoom();
newMarker.addEventListener('click', function(bubble) { map.disableInertialDragging();
return function() { var opts = {
if (map.getOverlays().indexOf(bubble) == -1) offset: new BMapGL.Size(0, 0)
map.addOverlay(bubble) };
else var label = new BMapGL.Label();
map.removeOverlay(bubble) label.setStyle({
color: '#4e73df',
borderRadius: '5px',
borderColor: '#ccc',
backgroundColor: 'rgba(255,255,255,0.8)',
padding: '8px',
fontSize: '1rem',
fontFamily: 'Nunito'
});
map.addEventListener('mousemove', function(e) {
if (!isRunning) {
map.addOverlay(label)
label.setContent(e.latlng.lng.toFixed(4) + ',' + e.latlng.lat.toFixed(4))
label.setPosition(new BMapGL.Point(e.latlng.lng, e.latlng.lat))
} else
map.removeOverlay(label)
});
var toBeAdded = user_content.split("@#@$@")
var addLength = toBeAdded.length / 5
console.log(toBeAdded)
for (var tmpi = 0; tmpi <= addLength - 1; tmpi = tmpi + 1) {
var point = new BMapGL.Point(toBeAdded[tmpi * 5], toBeAdded[tmpi * 5 + 1])
var newMarker = new BMapGL.Marker(point)
var bubble = create_a_map_bubble(toBeAdded[tmpi * 5 + 3], toBeAdded[tmpi * 5 + 2], point)
newMarker.bubble = bubble
markers.push({
"long": toBeAdded[tmpi * 5],
"lat": toBeAdded[tmpi * 5 + 1],
"time": toBeAdded[tmpi * 5 + 2],
"message": toBeAdded[tmpi * 5 + 3],
"clientid": toBeAdded[tmpi * 5 + 4],
"target": newMarker,
"point": point
})
if (markers.length == 1) {
map.centerAndZoom(point, 17);
} }
}(bubble)) map.addOverlay(newMarker)
map.addOverlay(bubble) newMarker.addEventListener('click', function(bubble) {
} return function() {
setContent() if (map.getOverlays().indexOf(bubble) == -1)
map.addOverlay(bubble)
var delete_on_click = function() { else
$("#trashbin").append(mapDiv) map.removeOverlay(bubble)
title.parent().parent().remove(); }
isAlive = false; }(bubble))
if (tbd) map.addOverlay(bubble)
tbd.remove() }
}
var clear_on_click = function() {
map.clearOverlays()
markers = []
setContent() setContent()
}
var edit_on_click = function() { var delete_on_click = function() {
modifyDia.showModal() $("#trashbin").append(mapDiv)
if (tbd) title.parent().parent().remove();
tbd.remove() isAlive = false;
} if (tbd)
var editForm = $('<div class="nnt"/>') tbd.remove()
editForm.append($('<div style="margin-top:-63px;margin-left:82.5px;margin-bottom:15px;box-shadow: 1px 1px 20px #4e73df;background-color:white;width:75px;height:75px;padding:40px;border-radius:80px;border:solid #4e73df 3px;display:flex;align-items:center;justify-content:center"><img src="icons/output_map.svg" style="width:45px;"></div>')) }
editForm.append($('<h5 style="text-align:center">' + JSLang[lang].unitName + '</h5>')) var clear_on_click = function() {
var title_input_div = $('<div style="display:flex;flex-direction:row;align-items:center"/>') map.clearOverlays()
var title_input = $("<input class='form-control form-control-user' style='text-align:center'/>") markers = []
title_input_div.append(title_input) setContent()
editForm.append(title_input_div) }
editForm.append($('<h5 style="margin-top:15px;text-align:center">' + JSLang[lang].messTopic + '</h5>')) var edit_on_click = function() {
var topic_input_div = $('<div style="display:flex;flex-direction:row;align-items:center"/>') modifyDia.showModal()
var topic_input = $("<input class='form-control form-control-user' style='text-align:center'/>") if (tbd)
topic_input_div.append(topic_input) tbd.remove()
editForm.append(topic_input_div) }
var bottomDiv = $('<div style="width:100%;margin-top:15px;display:flex;flex-direction:row;align-items:center;justify-content:space-around"/>') var editForm = $('<div class="nnt"/>')
var confirmEdit = $('<a class="btn btn-primary btn-circle" style="margin-right:10px;box-shadow:1px 1px 5px #4e73df"><i class="fa fa-check"></i></a>') editForm.append($('<div style="margin-top:-63px;margin-left:82.5px;margin-bottom:15px;box-shadow: 1px 1px 20px #4e73df;background-color:white;width:75px;height:75px;padding:40px;border-radius:80px;border:solid #4e73df 3px;display:flex;align-items:center;justify-content:center"><img src="icons/output_map.svg" style="width:45px;"></div>'))
bottomDiv.append(confirmEdit) editForm.append($('<h5 style="text-align:center">' + JSLang[lang].unitName + '</h5>'))
confirmEdit.click(function() { var title_input_div = $('<div style="display:flex;flex-direction:row;align-items:center"/>')
if (getByteLen(title_input.val()) > 0 && getByteLen(title_input.val()) < 21) { var title_input = $("<input class='form-control form-control-user' style='text-align:center'/>")
var re = /^[a-z0-9]+$/i; title_input_div.append(title_input)
if (getByteLen(topic_input.val()) > 0 && getByteLen(topic_input.val()) < 11) editForm.append(title_input_div)
if (true) { editForm.append($('<h5 style="margin-top:15px;text-align:center">' + JSLang[lang].messTopic + '</h5>'))
if (countSubstr(grid.html(), 'user-title=\"' + title_input.val() + '\"', false) <= (title_input.val() == title.text() ? 1 : 0)) { var topic_input_div = $('<div style="display:flex;flex-direction:row;align-items:center"/>')
title.parent().parent().attr('user-title', title_input.val()) var topic_input = $("<input class='form-control form-control-user' style='text-align:center'/>")
title.parent().parent().attr('user-topic', topic_input.val()) topic_input_div.append(topic_input)
if (title.parent().parent().attr('user-content') == undefined) editForm.append(topic_input_div)
title.parent().parent().attr('user-content', "") var bottomDiv = $('<div style="width:100%;margin-top:15px;display:flex;flex-direction:row;align-items:center;justify-content:space-around"/>')
title.text(title_input.val()) var confirmEdit = $('<a class="btn btn-primary btn-circle" style="margin-right:10px;box-shadow:1px 1px 5px #4e73df"><i class="fa fa-check"></i></a>')
topic.text(topic_input.val()) bottomDiv.append(confirmEdit)
modifyDia.close() confirmEdit.click(function() {
if (getByteLen(title_input.val()) > 0 && getByteLen(title_input.val()) < 21) {
var re = /^[a-z0-9]+$/i;
if (getByteLen(topic_input.val()) > 0 && getByteLen(topic_input.val()) < 11)
if (true) {
if (countSubstr(grid.html(), 'user-title=\"' + title_input.val() + '\"', false) <= (title_input.val() == title.text() ? 1 : 0)) {
title.parent().parent().attr('user-title', title_input.val())
title.parent().parent().attr('user-topic', topic_input.val())
if (title.parent().parent().attr('user-content') == undefined)
title.parent().parent().attr('user-content', "")
title.text(title_input.val())
topic.text(topic_input.val())
modifyDia.close()
} else
showtext(JSLang[lang].sameUnit)
} else } else
showtext(JSLang[lang].sameUnit) showtext("")
} else else
showtext("") showtext(JSLang[lang].topicLenIllegal)
else } else
showtext(JSLang[lang].topicLenIllegal) showtext(JSLang[lang].nameLenIllegal)
} else })
showtext(JSLang[lang].nameLenIllegal) var cancelEdit = $('<a class="btn btn-danger btn-circle" style="box-shadow:1px 1px 5px #e74a3b"><i class="fa fa-arrow-left"></i></a>')
}) cancelEdit.click(function() {
var cancelEdit = $('<a class="btn btn-danger btn-circle" style="box-shadow:1px 1px 5px #e74a3b"><i class="fa fa-arrow-left"></i></a>') modifyDia.close()
cancelEdit.click(function() { })
modifyDia.close() bottomDiv.append(cancelEdit)
}) editForm.append(bottomDiv)
bottomDiv.append(cancelEdit) var modifyDia = dialog({
editForm.append(bottomDiv) content: editForm[0],
var modifyDia = dialog({ cancel: false
content: editForm[0], })
cancel: false var showEditBubble = function(event) {
}) if(tbd)
var showEditBubble = function(event) { tbd.remove()
if(tbd) if (typeof startX != "undefined" && (startX - endX < 5 && endX - startX < 5) && (startY - endY < 5 && endY - startY < 5)) {
tbd.remove() var editButton = $('<a class="btn btn-primary btn-circle bbbt"><i class="fa fa-cog"></i></a>')
if (typeof startX != "undefined" && (startX - endX < 5 && endX - startX < 5) && (startY - endY < 5 && endY - startY < 5)) { var clearButton = $('<a class="btn btn-warning btn-circle bbbt"><i class="fa fa-eraser"></i></a>')
var editButton = $('<a class="btn btn-primary btn-circle bbbt"><i class="fa fa-cog"></i></a>') var deleteButton = $('<a class="btn btn-danger btn-circle bbbt"><i class="fa fa-trash"></i></a>')
var clearButton = $('<a class="btn btn-warning btn-circle bbbt"><i class="fa fa-eraser"></i></a>') var bubble = $('<div style="text-align:center"/>')
var deleteButton = $('<a class="btn btn-danger btn-circle bbbt"><i class="fa fa-trash"></i></a>') bubble.append(topicDiv)
var bubble = $('<div style="text-align:center"/>') var d = dialog({
bubble.append(topicDiv) align: 'top',
var d = dialog({ content: bubble[0],
align: 'top', quickClose: true,
content: bubble[0], autofocus: false
quickClose: true, });
autofocus: false tbd = d;
}); editButton.click(edit_on_click)
tbd = d; clearButton.click(clear_on_click)
editButton.click(edit_on_click) deleteButton.click(delete_on_click)
clearButton.click(clear_on_click) if (!isRunning)
deleteButton.click(delete_on_click) bubble.append(editButton)
if (!isRunning) bubble.append(clearButton)
bubble.append(editButton) if (!isRunning)
bubble.append(clearButton) bubble.append(deleteButton)
if (!isRunning) if (!isRunning)
bubble.append(deleteButton) {
if (!isRunning) copyButton.attr("user-origin", title.text())
bubble.append(copyButton)
styleButton.attr("user-origin", title.text())
bubble.append(styleButton)
helpButton.attr("user-origin", attrs[0][1])
bubble.append(helpButton)
}
title_input.val(title.text())
topic_input.val(topic.text())
if (!d.open)
{ {
copyButton.attr("user-origin", title.text()) d.show(itemdiv[0]);
bubble.append(copyButton) setTimeout(function() {
styleButton.attr("user-origin", title.text()) $(".ui-popup-backdrop").css("pointer-events", "auto")
bubble.append(styleButton) },100)
helpButton.attr("user-origin", attrs[0][1]) }
bubble.append(helpButton) else
d.close()
} }
title_input.val(title.text())
topic_input.val(topic.text())
if (!d.open)
{
d.show(itemdiv[0]);
setTimeout(function() {
$(".ui-popup-backdrop").css("pointer-events", "auto")
},100)
}
else
d.close()
} }
} if (window.screen.width > 800)
if (window.screen.width > 800) {
{ itemdiv.click(showEditBubble)
itemdiv.click(showEditBubble) itemdiv.on('contextmenu', function(event) {
itemdiv.on('contextmenu', function(event) { event.preventDefault()
event.preventDefault() event.stopPropagation()
showEditBubble(event)
})
}
else
itemdiv[0].addEventListener('touchend', function(event) {
event.preventDefault()
showEditBubble(event)
})
itemdiv[0].addEventListener('touchmove', function(e) {
e.preventDefault()
})
if (user_style != undefined)
itemdiv.attr('style', user_style)
itemdiv.resizable({
minWidth: 300,
minHeight: 300,
onStopResize: function() {
var stdLeft = parseInt(itemdiv.css('left')) - parseInt(itemdiv.css('left')) % 20 + (parseInt(itemdiv.css('left')) % 20 > 10 ? 1 : 0) * 20
var stdTop = parseInt(itemdiv.css('top')) - parseInt(itemdiv.css('top')) % 20 + (parseInt(itemdiv.css('top')) % 20 > 10 ? 1 : 0) * 20
itemdiv.css('left', stdLeft)
itemdiv.css('top', stdTop)
var stdWidth = parseInt(itemdiv.css('width')) - parseInt(itemdiv.css('width')) % 20 + (parseInt(itemdiv.css('width')) % 20 > 10 ? 1 : 0) * 20
var stdHeight = parseInt(itemdiv.css('height')) - parseInt(itemdiv.css('height')) % 20 + (parseInt(itemdiv.css('height')) % 20 > 10 ? 1 : 0) * 20
itemdiv.css('width', stdWidth)
itemdiv.css('height', stdHeight)
}
})
},true);
}
else if(tencent_key!='')
{
$.getScript("//map.qq.com/api/gljs?v=1.exp&key="+tencent_key, function() {
modald.close().remove()
var isAlive = true
var contents = []
var title = $("<h4 class='userTitle'>" + user_title + "</h4>")
title.attr("hidden", title_style)
contents.push(title)
var topicDiv = $("<div class='topicDiv'/>")
var topic = $("<span class='index-topic' style='margin:0;color:#858796;'>" + user_topic + "</span>")
topicDiv.append($("<i class='fa fa-podcast' style='color:#858796;margin-right:3px'></i>"))
topicDiv.append(topic)
var randomName = randomString() + "map"
var mapDiv = $("<div style='width:calc(100% - 20px);height:calc(100% - 60px)'/>")
mapDiv.attr("id", randomName)
mapDiv.bind('click', function(event) {
event.stopPropagation() event.stopPropagation()
showEditBubble(event)
}) })
} mapDiv.bind('pointerdown', function(event) {
else event.stopPropagation()
itemdiv[0].addEventListener('touchend', function(event) {
event.preventDefault()
showEditBubble(event)
}) })
itemdiv[0].addEventListener('touchmove', function(e) { mapDiv.bind('mousedown', function(event) {
e.preventDefault() event.stopPropagation()
}) })
if (user_style != undefined) mapDiv[0].addEventListener('touchstart', function(event) {
itemdiv.attr('style', user_style) event.stopPropagation()
itemdiv.resizable({ }, { passive: false })
minWidth: 300, contents.push(mapDiv)
minHeight: 300, attrs = [
onStopResize: function() { ['user-type', 'output_map'],
var stdLeft = parseInt(itemdiv.css('left')) - parseInt(itemdiv.css('left')) % 20 + (parseInt(itemdiv.css('left')) % 20 > 10 ? 1 : 0) * 20 ['user-title', user_title],
var stdTop = parseInt(itemdiv.css('top')) - parseInt(itemdiv.css('top')) % 20 + (parseInt(itemdiv.css('top')) % 20 > 10 ? 1 : 0) * 20 ['user-topic', user_topic],
itemdiv.css('left', stdLeft) ['user-content', user_content],
itemdiv.css('top', stdTop) ['title-hidden', title_style]
var stdWidth = parseInt(itemdiv.css('width')) - parseInt(itemdiv.css('width')) % 20 + (parseInt(itemdiv.css('width')) % 20 > 10 ? 1 : 0) * 20 ]
var stdHeight = parseInt(itemdiv.css('height')) - parseInt(itemdiv.css('height')) % 20 + (parseInt(itemdiv.css('height')) % 20 > 10 ? 1 : 0) * 20 var itemdiv = add_block(3, 3, contents, attrs)
itemdiv.css('width', stdWidth) var maxLeft = mapDiv[0].clientWidth
itemdiv.css('height', stdHeight) var maxTop = mapDiv[0].clientHeight
var markers = []
var setContent = function() {
var tmp = []
var markergeos = []
var layergeos = []
for (marker in markers) {
tmp.push(markers[marker].long)
tmp.push(markers[marker].lat)
tmp.push(markers[marker].time)
tmp.push(markers[marker].message)
tmp.push(markers[marker].clientid)
markergeos.push({
"id": markers[marker].clientid + "marker",
"styleId": "myStyle",
"position": new TMap.LatLng(markers[marker].lat, markers[marker].long)
})
layergeos.push({
"id": markers[marker].clientid + "layer",
"styleId": "label",
"position": new TMap.LatLng(markers[marker].lat, markers[marker].long),
"content": markers[marker].message + " " + markers[marker].time
})
}
console.log(markergeos)
if(markergeos.length == 1){
map.setCenter(new TMap.LatLng(markers[0].lat, markers[0].long))
}
title.parent().parent().attr('user-content', tmp.join("@#@$@"))
markerLayer.setGeometries(markergeos)
mapTextLayer.setGeometries(layergeos)
} }
}) itemdiv.bind(MixIO.actionTags.DATA_MAP_CHANGE, function(event, message) {
},true); MixIO.publish(topic.text(), JSON.stringify(message))
})
itemdiv.bind(MixIO.actionTags.DATA_MAP_CLEAR, function() {
clear_on_click()
})
client.on('message', function(topic1, message1) {
if (isAlive && isRunning)
if (topic1.split("/")[(isMixly ? 3 : 2)] == topic.text()) {
var label = ((new Date().getHours() < 10 ? "0" : "") + new Date().getHours() + ":" + (new Date().getMinutes() < 10 ? "0" : "") + new Date().getMinutes() + ":" + (new Date().getSeconds() < 10 ? "0" : "") + new Date().getSeconds())
if (isJSON(String(message1)) && ("long" in JSON.parse(String(message1))) && ("lat" in JSON.parse(String(message1))) && JSON.parse(String(message1)).clientid) {
var jsonMessage = JSON.parse(String(message1))
console.log(jsonMessage)
itemdiv.trigger(MixIO.eventTags.DATA_MAP_CHANGED, [jsonMessage.clientid, jsonMessage.long, jsonMessage.lat, jsonMessage.message])
var newOrNot = true
var markerIndex = -1
for (marker in markers) {
if (jsonMessage.clientid == markers[marker].clientid) {
newOrNot = false
markerIndex = marker
break
}
}
if (newOrNot) {
var msgstr = ""
if (typeof jsonMessage.message == "string")
jsonMessage.message = JSON.parse(jsonMessage.message)
for (msg in jsonMessage.message) {
msgstr = msgstr + jsonMessage.message[msg].label + ": " + jsonMessage.message[msg].value + " "
}
markers.push({
"clientid": jsonMessage.clientid,
"long": jsonMessage.long,
"lat": jsonMessage.lat,
"time": label,
"message": msgstr
})
} else {
markers[markerIndex].time = label
var msgstr = ""
if (typeof jsonMessage.message == "string")
jsonMessage.message = JSON.parse(jsonMessage.message)
for (msg in jsonMessage.message) {
msgstr = msgstr + jsonMessage.message[msg].label + ": " + jsonMessage.message[msg].value + " "
}
markers[markerIndex].long = jsonMessage.long
markers[markerIndex].lat = jsonMessage.lat
markers[markerIndex].message = msgstr
}
setContent()
} else {
showtext(JSLang[lang].mapJSON)
}
}
})
var map = new TMap.Map(document.getElementById(randomName), {
center: new TMap.LatLng(39.967, 116.373),
zoom: 17,
pitch: 43.5,
rotation: 45
});
var markerLayer = new TMap.MultiMarker({
map: map, //指定地图容器
styles: {
//创建一个styleId为"myStyle"的样式styles的子属性名即为styleId
"myStyle": new TMap.MarkerStyle({
"width": 25, // 点标记样式宽度(像素)
"height": 35, // 点标记样式高度(像素)
"src": '', //图片路径
//焦点在图片中的像素位置,一般大头针类似形式的图片以针尖位置做为焦点,圆形点以圆心位置为焦点
"anchor": { x: 16, y: 32 }
})
}
});
var mapTextLayer = new TMap.MultiLabel({
id: 'mapTextLayer',
map: map,
styles: {
'label': new TMap.LabelStyle({
'color': '#3777FF', //颜色属性
'strokeColor': '#ffffff',
'size': 14, //文字大小属性
'offset': { x: 0, y: 10 }, //文字偏移属性单位为像素
'angle': 0, //文字旋转属性
'alignment': 'center', //文字水平对齐属性
'verticalAlignment': 'top' //文字垂直对齐属性
})
}
});
var toBeAdded = user_content.split("@#@$@")
var addLength = toBeAdded.length / 5
for (var tmpi = 0; tmpi <= addLength - 1; tmpi = tmpi + 1) {
markers.push({
"long": toBeAdded[tmpi * 5],
"lat": toBeAdded[tmpi * 5 + 1],
"time": toBeAdded[tmpi * 5 + 2],
"message": toBeAdded[tmpi * 5 + 3],
"clientid": toBeAdded[tmpi * 5 + 4]
})
}
setContent()
var delete_on_click = function() {
$("#trashbin").append(mapDiv)
title.parent().parent().remove();
isAlive = false;
if (tbd)
tbd.remove()
}
var clear_on_click = function() {
markers = []
setContent()
}
var edit_on_click = function() {
modifyDia.showModal()
if (tbd)
tbd.remove()
}
var editForm = $('<div class="nnt"/>')
editForm.append($('<div style="margin-top:-63px;margin-left:82.5px;margin-bottom:15px;box-shadow: 1px 1px 20px #4e73df;background-color:white;width:75px;height:75px;padding:40px;border-radius:80px;border:solid #4e73df 3px;display:flex;align-items:center;justify-content:center"><img src="icons/output_map.svg" style="width:45px;"></div>'))
editForm.append($('<h5 style="text-align:center">' + JSLang[lang].unitName + '</h5>'))
var title_input_div = $('<div style="display:flex;flex-direction:row;align-items:center"/>')
var title_input = $("<input class='form-control form-control-user' style='text-align:center'/>")
title_input_div.append(title_input)
editForm.append(title_input_div)
editForm.append($('<h5 style="margin-top:15px;text-align:center">' + JSLang[lang].messTopic + '</h5>'))
var topic_input_div = $('<div style="display:flex;flex-direction:row;align-items:center"/>')
var topic_input = $("<input class='form-control form-control-user' style='text-align:center'/>")
topic_input_div.append(topic_input)
editForm.append(topic_input_div)
var bottomDiv = $('<div style="width:100%;margin-top:15px;display:flex;flex-direction:row;align-items:center;justify-content:space-around"/>')
var confirmEdit = $('<a class="btn btn-primary btn-circle" style="margin-right:10px;box-shadow:1px 1px 5px #4e73df"><i class="fa fa-check"></i></a>')
bottomDiv.append(confirmEdit)
confirmEdit.click(function() {
if (getByteLen(title_input.val()) > 0 && getByteLen(title_input.val()) < 21) {
var re = /^[a-z0-9]+$/i;
if (getByteLen(topic_input.val()) > 0 && getByteLen(topic_input.val()) < 11)
if (true) {
if (countSubstr(grid.html(), 'user-title=\"' + title_input.val() + '\"', false) <= (title_input.val() == title.text() ? 1 : 0)) {
title.parent().parent().attr('user-title', title_input.val())
title.parent().parent().attr('user-topic', topic_input.val())
if (title.parent().parent().attr('user-content') == undefined)
title.parent().parent().attr('user-content', "")
title.text(title_input.val())
topic.text(topic_input.val())
modifyDia.close()
} else
showtext(JSLang[lang].sameUnit)
} else
showtext("")
else
showtext(JSLang[lang].topicLenIllegal)
} else
showtext(JSLang[lang].nameLenIllegal)
})
var cancelEdit = $('<a class="btn btn-danger btn-circle" style="box-shadow:1px 1px 5px #e74a3b"><i class="fa fa-arrow-left"></i></a>')
cancelEdit.click(function() {
modifyDia.close()
})
bottomDiv.append(cancelEdit)
editForm.append(bottomDiv)
var modifyDia = dialog({
content: editForm[0],
cancel: false
})
var showEditBubble = function(event) {
if(tbd)
tbd.remove()
if (typeof startX != "undefined" && (startX - endX < 5 && endX - startX < 5) && (startY - endY < 5 && endY - startY < 5)) {
var editButton = $('<a class="btn btn-primary btn-circle bbbt"><i class="fa fa-cog"></i></a>')
var clearButton = $('<a class="btn btn-warning btn-circle bbbt"><i class="fa fa-eraser"></i></a>')
var deleteButton = $('<a class="btn btn-danger btn-circle bbbt"><i class="fa fa-trash"></i></a>')
var bubble = $('<div style="text-align:center"/>')
bubble.append(topicDiv)
var d = dialog({
align: 'top',
content: bubble[0],
quickClose: true,
autofocus: false
});
tbd = d;
editButton.click(edit_on_click)
clearButton.click(clear_on_click)
deleteButton.click(delete_on_click)
if (!isRunning)
bubble.append(editButton)
bubble.append(clearButton)
if (!isRunning)
bubble.append(deleteButton)
if (!isRunning)
{
copyButton.attr("user-origin", title.text())
bubble.append(copyButton)
styleButton.attr("user-origin", title.text())
bubble.append(styleButton)
helpButton.attr("user-origin", attrs[0][1])
bubble.append(helpButton)
}
title_input.val(title.text())
topic_input.val(topic.text())
if (!d.open)
{
d.show(itemdiv[0]);
setTimeout(function() {
$(".ui-popup-backdrop").css("pointer-events", "auto")
},100)
}
else
d.close()
}
}
if (window.screen.width > 800)
{
itemdiv.click(showEditBubble)
itemdiv.on('contextmenu', function(event) {
event.preventDefault()
event.stopPropagation()
showEditBubble(event)
})
}
else
itemdiv[0].addEventListener('touchend', function(event) {
event.preventDefault()
showEditBubble(event)
})
itemdiv[0].addEventListener('touchmove', function(e) {
e.preventDefault()
})
if (user_style != undefined)
itemdiv.attr('style', user_style)
itemdiv.resizable({
minWidth: 300,
minHeight: 300,
onStopResize: function() {
var stdLeft = parseInt(itemdiv.css('left')) - parseInt(itemdiv.css('left')) % 20 + (parseInt(itemdiv.css('left')) % 20 > 10 ? 1 : 0) * 20
var stdTop = parseInt(itemdiv.css('top')) - parseInt(itemdiv.css('top')) % 20 + (parseInt(itemdiv.css('top')) % 20 > 10 ? 1 : 0) * 20
itemdiv.css('left', stdLeft)
itemdiv.css('top', stdTop)
var stdWidth = parseInt(itemdiv.css('width')) - parseInt(itemdiv.css('width')) % 20 + (parseInt(itemdiv.css('width')) % 20 > 10 ? 1 : 0) * 20
var stdHeight = parseInt(itemdiv.css('height')) - parseInt(itemdiv.css('height')) % 20 + (parseInt(itemdiv.css('height')) % 20 > 10 ? 1 : 0) * 20
itemdiv.css('width', stdWidth)
itemdiv.css('height', stdHeight)
}
})
},true);
}
} }
function create_a_map_bubble(messageBody, time, point) { function create_a_map_bubble(messageBody, time, point) {