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

你可以在图片中看到正在发生的事情。这是一个新用户触发应用程序中的跟踪功能的时刻。在第二个用户激活跟踪功能之前,第一个用户的标记正在正常移动。
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);
});
});
}发布于 2012-01-29 19:10:27
考虑到我不太了解javascript,我在这里可能大错特错了,但我假设作为参数发送给setInterval的匿名函数被多次调用(?)。
如果是这样的话,我希望marker1会被重用,因为它是在函数外部声明的,也就是说,在这部分代码中,它与每个函数调用使用的marker1相同
//update the current location marker
if (marker1 != null) {
marker1.setPosition(current_loc);
}我猜您可以对marker1使用与处理loc相同的方法,将其作为按用户ID索引的数组(也许将其命名为currentLocationMarker也会更好)。
另一种方法是让marker1只存在于函数中,但这可能导致用户以前的所有当前位置标记都是可见的。不确定,我不知道你正在构建的这个系统的全貌。
发布于 2012-01-30 02:14:01
目前还不完全清楚问题是什么,但您尝试过使用.panTo()吗?它可以平滑地滚动到一个新的位置。以你的.setPosition()命名它。
if (marker1 != null) {
marker1.setPosition(current_loc);
map.panTo( current_loc );
}https://stackoverflow.com/questions/9051896
复制相似问题