Google 地图 API 标记刷新
Google maps API marker refresh
我正在使用 Syrus GPS 调制解调器为 GPS 定位服务构建网站服务。我有两个文件,一个 python 代码用于捕获来自调制解调器的信息,另一个 HTML
文件是网页,python 脚本直接重写为 HTML 使用:
def replace_line(file_name, line_num, text):
lines = open(file_name, 'r').readlines()
lines[line_num] = text
out = open(file_name, 'w')
out.writelines(lines)
out.close
我意识到为了更新地图中的标记我必须更新整个网页,这是不切实际的。
我使用了来自 google API 站点的示例:
<script src="https://maps.googleapis.com/maps/api/js?v=3.exp&signed_in=true"></script>
<script>
function initialize() {
var myLatlng = new google.maps.LatLng(21.0056,-75.8196);
var mapOptions = {
zoom: 15,
center: myLatlng
}
var map = new google.maps.Map(document.getElementById('map-canvas'), mapOptions);
var marker = new google.maps.Marker({
position: myLatlng,
map: map,
title: 'Diseno 201510'
});
}
google.maps.event.addDomListener(window, 'load', initialize);
</script>
我只是用纬度和经度替换线。那么有没有更简单的方法来更新标记而不刷新整个网页?
是的。但我不确定这会有多容易,因为我不完全确定您首先是如何通过 Python 更新地图的。 IE。您是否正在使用 websockets、重新渲染模板等...
当我被困在做同样的事情时,我使用了网络套接字(具体来说,socket.io)和我的 Flask 应用程序。每隔“x
”秒,我将更新后的 Lat/Long 坐标发送到站点并使用 map.panTo(coordinates)
命令将地图移动到新坐标 而无需 刷新页面。这是我用来执行此操作的 javascript 代码:
socket.on('newnumber', function(data){
lat = data.number[0];
lng = data.number[1];
$('#locationText').text(data.number[3]);
console.log("Lat: " + lat + " Long: " + lng);
// Construct new LatLong Object
var myLatlng = new google.maps.LatLng(lng, lat);
latLong = myLatlng;
// Draw marker on the map
var marker = new google.maps.Marker({
position: myLatlng,
map: map,
title: data.number[3]
});
// Move map to new coordinates w/o refreshing page
map.panTo(latLong);
});
我正在使用 Syrus GPS 调制解调器为 GPS 定位服务构建网站服务。我有两个文件,一个 python 代码用于捕获来自调制解调器的信息,另一个 HTML
文件是网页,python 脚本直接重写为 HTML 使用:
def replace_line(file_name, line_num, text):
lines = open(file_name, 'r').readlines()
lines[line_num] = text
out = open(file_name, 'w')
out.writelines(lines)
out.close
我意识到为了更新地图中的标记我必须更新整个网页,这是不切实际的。
我使用了来自 google API 站点的示例:
<script src="https://maps.googleapis.com/maps/api/js?v=3.exp&signed_in=true"></script>
<script>
function initialize() {
var myLatlng = new google.maps.LatLng(21.0056,-75.8196);
var mapOptions = {
zoom: 15,
center: myLatlng
}
var map = new google.maps.Map(document.getElementById('map-canvas'), mapOptions);
var marker = new google.maps.Marker({
position: myLatlng,
map: map,
title: 'Diseno 201510'
});
}
google.maps.event.addDomListener(window, 'load', initialize);
</script>
我只是用纬度和经度替换线。那么有没有更简单的方法来更新标记而不刷新整个网页?
是的。但我不确定这会有多容易,因为我不完全确定您首先是如何通过 Python 更新地图的。 IE。您是否正在使用 websockets、重新渲染模板等...
当我被困在做同样的事情时,我使用了网络套接字(具体来说,socket.io)和我的 Flask 应用程序。每隔“x
”秒,我将更新后的 Lat/Long 坐标发送到站点并使用 map.panTo(coordinates)
命令将地图移动到新坐标 而无需 刷新页面。这是我用来执行此操作的 javascript 代码:
socket.on('newnumber', function(data){
lat = data.number[0];
lng = data.number[1];
$('#locationText').text(data.number[3]);
console.log("Lat: " + lat + " Long: " + lng);
// Construct new LatLong Object
var myLatlng = new google.maps.LatLng(lng, lat);
latLong = myLatlng;
// Draw marker on the map
var marker = new google.maps.Marker({
position: myLatlng,
map: map,
title: data.number[3]
});
// Move map to new coordinates w/o refreshing page
map.panTo(latLong);
});