首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >更新Google Map Marker

更新Google Map Marker
EN

Stack Overflow用户
提问于 2012-01-29 16:27:33
回答 2查看 1.2K关注 0票数 0

我正在尝试制作一个谷歌地图,当用户的位置更新时,它会更新一个标记。我已经完成了大部分工作,但我有一个小问题。我想要一个显示起始点的标记,我正在工作,但第二个点应该不断移动,它应该允许一次跟踪多个用户。

我可以让它为一个用户工作(从Android应用程序发送GPS坐标)。它将设置开始标记,当它们的位置改变时,标记将移动以反映这一点。当我开始跟踪第二个用户时,我的问题就出现了。第一个用户的当前位置标记成为第二个用户的起始位置。它从第一条路径“跳”到另一条路径(见图)。我知道这在一定程度上是由于在顶部声明了'marker1‘变量,但我尝试了许多方法,但都没有成功。我需要能够为n个用户创建任意数量的变量,所以我不能为每个用户声明一堆变量。

你可以在图片中看到正在发生的事情。这是一个新用户触发应用程序中的跟踪功能的时刻。在第二个用户激活跟踪功能之前,第一个用户的标记正在正常移动。

代码语言:javascript
复制
    function initialize() {
    var myLatlng = new google.maps.LatLng(39, -86);
    var myOptions = {
        zoom: 6,
        center: myLatlng,
        mapTypeId: google.maps.MapTypeId.ROADMAP,
    }       
    var map = new google.maps.Map(document.getElementById("map_canvas"), myOptions); 

    var loc = {};
    var mark = {};
    var markers = {};
    var marker1;

    $(function () {
        $(document).ready(function(){
            setInterval(function(){
                $.ajax({                                      
                    url: 'api.php',                  //the script to call to get data          
                    //data: "",                       
                    dataType: 'json',                //data format      
                    success: function(data){          //on recieve of reply                          


                        var user_id = data[0];
                        var lati = data[1];              //get id
                        var longi = data[2];           //get name

                        var myLatlngt = new google.maps.LatLng(lati, longi);

                        if (typeof loc[user_id] === 'undefined') {
                            loc[user_id] = [];
                            }

                        //if (typeof markers[user_id] === 'undefined') {
                            //markers[user_id] = [];
                            //}

                        if (typeof mark[user_id] === 'undefined') {
                            mark[user_id] = myLatlngt;
                            }

                        loc[user_id].push(myLatlngt);
                        //markers[user_id].push(myLatlngt);

                        var x;
                        for (x in loc) {
                            var polyline = new google.maps.Polyline({
                                map: map,
                                path: loc[x],
                                strokeColor: "#FF0000",
                                strokeOpacity: 1.0,
                                strokeWeight: 2
                                });
                            polyline.setMap(map);

                            ///location variables
                            var start_loc = loc[user_id];
                            var start_marker = start_loc[0]; //start location of given user
                            var current_loc = start_loc[start_loc.length -1]; //last known location of given user

                            //set the start marker
                            var marker = new google.maps.Marker({
                                position: start_marker,
                                title: user_id
                            });
                            marker.setMap(map); 

                            //update the current location marker
                            if (marker1 != null) {
                                marker1.setPosition(current_loc);
                            }
                            else {
                                marker1 = new google.maps.Marker({
                                    position: current_loc,
                                    map: map
                                });

                            }                   
                        }
                            //console.log('location :::', x);
                            console.log('Marker: ', mark);
                    } 
                });
            }, 1000);
        });
    });
}
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2012-01-29 19:10:27

考虑到我不太了解javascript,我在这里可能大错特错了,但我假设作为参数发送给setInterval的匿名函数被多次调用(?)。

如果是这样的话,我希望marker1会被重用,因为它是在函数外部声明的,也就是说,在这部分代码中,它与每个函数调用使用的marker1相同

代码语言:javascript
复制
//update the current location marker
if (marker1 != null) {
    marker1.setPosition(current_loc);
}

我猜您可以对marker1使用与处理loc相同的方法,将其作为按用户ID索引的数组(也许将其命名为currentLocationMarker也会更好)。

另一种方法是让marker1只存在于函数中,但这可能导致用户以前的所有当前位置标记都是可见的。不确定,我不知道你正在构建的这个系统的全貌。

票数 1
EN

Stack Overflow用户

发布于 2012-01-30 02:14:01

目前还不完全清楚问题是什么,但您尝试过使用.panTo()吗?它可以平滑地滚动到一个新的位置。以你的.setPosition()命名它。

代码语言:javascript
复制
if (marker1 != null) {
    marker1.setPosition(current_loc);
    map.panTo( current_loc );
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9051896

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档