谷歌地图 API 标记刷新

Posted

技术标签:

【中文标题】谷歌地图 API 标记刷新【英文标题】:Google maps API marker refresh 【发布时间】:2015-05-09 06:42:46 【问题描述】:

我正在使用 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】:

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

当我被困在做同样的事情时,我将 Web 套接字(特别是 socket.io)与我的 Flask 应用程序一起使用。每隔“x”秒,我将更新的纬度/经度坐标发送到站点并使用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);
);

【讨论】:

谢谢你,你真的帮了我,我在语法上遇到了麻烦

以上是关于谷歌地图 API 标记刷新的主要内容,如果未能解决你的问题,请参考以下文章

刷新/重新加载地图:谷歌地图 API V2

如何在使用新地图刷新之前清除谷歌地图标记? [复制]

如何在不刷新整个地图的情况下更新谷歌地图上的标记位置?

重新加载/刷新谷歌地图

如何在同一张地图上使用带有多个标记的谷歌地图 API

在谷歌地图javascript api中 - 如何移动地图而不是标记