谷歌地图API标记刷新

时间:2015-03-07 20:14:00

标签: python html google-maps gps 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>

我只是用纬度和经度替换线。那么是否有更简单的方法来更新标记而不刷新整个网页?

1 个答案:

答案 0 :(得分:1)

是。但我不确定它会有多容易,因为我不完全确定你是如何通过Python更新地图的。即你在使用websockets,重新渲染模板等等吗?

当我遇到同样的问题时,我使用了Web套接字(特别是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);
});