我正在使用Google Maps API制作地图,该地图将显示服务器上玩家的当前位置。该列表由游戏服务器更新,数据存储在Web应用程序所在的MySql数据库中。当用户打开地图时,玩家列表及其位置将从数据库中提取并发送到View
public ActionResult Index()
{
return View(loadData()); //List<MapModel>
}
在视图上我为每个玩家在各自的位置创建一个标记。我有一个计时器,可以创建/更新/删除标记(我已经删除了此演示的不必要代码)
setInterval("updateMap();", 1000);
function updateMap()
{
**<update data somehow>**
@foreach(var player in Model)
{
<text>
players[@player.playerid] = new google.maps.Marker({
position: SanMap.getLatLngFromPos(@player.pos_x, @player.pos_y),
map: map
});
</text>
}
}
问题是如何更新数据?
答案 0 :(得分:1)
尝试这样的事情。
public JsonResult GetPlayers()
{
return Json(loadData()); //List<MapModel>
}
然后在javascript中使用jquery post方法
function updateMap()
{
$.post('/SomeController/GetPlayers', function(data){
for(var i =0; i<data.length; i++)
{
players[data[i].playerid] = new google.maps.Marker({
position: SanMap.getLatLngFromPos(data[i].pos_x, data[i].pos_y),
map: map
});
}
});
}