我有我的JSON結果顯示如下,我已經退出了我的數據庫,Iwant顯示在谷歌地圖上使用基於位置顯示的標記這裏是結果;如何獲得放置在Google地圖上的JSON結果?
{
"user": [{
"name" : "xxxxxxxxx",
"posn" : [53.491314, -2.249451]
}, {
"name" : "xxxxxxxxxx",
"posn" : [54.949231, -1.620483]
}]
}
如何獲取用戶名和位置放置在谷歌地圖上?爲我的googlemaps編碼如下;
<div id="map_canvas" style="width:800px; height:600px;"></div>
<script type="text/javascript"src="http://maps.googleapis.com/maps/api/js?sensor=false"></script>
<script src="/Scripts/markermanager.js" type="text/javascript"></script>
<script src="/Scripts/google_northamerica_offices.js" type="text/javascript"></script>
<script type="text/javascript">
var map;
var bounds = new google.maps.LatLngBounds();
var mgr;
function initialize() {
var myOptions = {
zoom: 4,
center: new google.maps.LatLng(-34.397, 150.644),
mapTypeId: google.maps.MapTypeId.ROADMAP
};
map = new google.maps.Map(document.getElementById("map_canvas"), myOptions);
mgr = new MarkerManager(map);
google.maps.event.addListener(mgr, 'loaded', function() {
for (var i = 0; i < 10; i++) {
var latlng = new google.maps.LatLng(Math.random() * 180 - 90, Math.random() * 360 - 180);
bounds.extend(latlng);
var marker = new google.maps.Marker({
position: latlng,
// animation: google.maps.Animation.DROP, // animation disabled because it slows down performance
title: "RedStar Creative Marker #" + i
});
mgr.addMarker(marker, 0);
}
mgr.refresh();
map.fitBounds(bounds);
});
}
$(document).ready(function() {
initialize();
});
</script>
我試着做它像這樣,不知道它在做它,使用JSON第一次以正確的方式;
function setupUserMarkers() {
var markers = [];
for (var j in layer["users"]) {
var place = layer["users"][j];
var title = place["name"];
var posn = new GLatLng(place["posn"][0], place["posn"][1]);
var marker = createMarker(posn,title);
markers.push(marker);
allmarkers.push(marker);
}
mgr.addMarkers(markers, layer["zoom"][0], layer["zoom"][1]);
}
mgr.refresh();
}
UPDATE:使用AJAX我能添加一個基於JSON結果兩個標記,試圖找出如何添加一個窗口彈出所以它會顯示這個人在窗口的圖像。我知道我需要一個google.maps.event.addListener,下一步它對我來說現在正在研究,希望下面的AJAX能夠幫助其他遇到類似問題的人幫助我。
$.ajax({
url: "/Home/GetUser",
context: document.body,
success: function (data) {
for (var i = 0; i < data.user.length; i++) {
var label = data.user[i].name;
var lat = data.user[i].posn[0];
var long = data.user[i].posn[1];
var latlng = new google.maps.LatLng(lat, long);
bounds.extend(latlng);
var marker = new google.maps.Marker({
position: latlng,
title: label
});
後工作是否有一個公開網址JSON?如果是這樣,我可以在jsFiddle上設置一個演示。 –
@Salman抱歉沒有公共鏈接,因爲我正在使用Visual Web Dev在本地主機上工作。雖然有Facebook的個人資料圖片的網址。 – MJCoder