更新Google地图标记

时间:2012-01-29 08:27:33

标签: php javascript android google-maps gps

我正在尝试制作一张更新标记的Google地图,因为用户的位置已更新。我已经完成了大部分工作,但我遇到了一个小问题。我想要一个标记显示我已经工作的起点,但第二个点应该继续移动,它应该允许一次跟踪多个用户。

我可以让这个用户为一个用户(从Android应用程序发送GPS坐标)。它将设置开始标记,并且随着它们的位置变化,标记将移动以反映该标记。当我开始跟踪第二个用户时,我的问题就出现了。第一个用户的当前位置标记成为第二个用户的起始位置。它从第一条路径“跳跃”到另一条路径(见图)。我知道这部分是由于在顶部声明了'marker1'变量,但我尝试了许多没有运气的事情。我需要能够为n个用户创建尽可能多的用户,因此我不能为每个用户声明一堆变量。 enter image description here

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

    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);
        });
    });
}

2 个答案:

答案 0 :(得分:1)

考虑到我真的不知道javascript,我可能完全错了,但我假设作为参数发送的匿名函数被多次调用(?)。

如果是这种情况,我希望marker1可以重用,因为它是在函数之外声明的,即,它与代码的这一部分中每个函数调用使用的是相同的marker1

//update the current location marker
if (marker1 != null) {
    marker1.setPosition(current_loc);
}

我猜你可以使用与loc1相同的方法,将它作为由用户ID索引的数组。 (也许称它为currentLocationMarker也是一个更好的名字)

另一种方法是将marker1仅存在于函数中,但这可能导致用户的所有先前当前位置标记可见。不确定,我没有全面了解你正在建设的这个系统。

答案 1 :(得分:0)

问题是什么并不完全清楚,但您是否尝试过使用.panTo()?它可以顺利滚动到新位置。请在.setPosition()

之后致电
if (marker1 != null) {
    marker1.setPosition(current_loc);
    map.panTo( current_loc );
}