新的google.maps.LatLngBounds()绑定扩展和中心工作随机
new google.maps.LatLngBounds() bound extend and center working random
我试图在地图上放置一些标记。数据从数据库中检索并使用 JSON 循环读取。
标记已放置,但我也尝试显示地图上的所有标记并使视图居中。这似乎是随机工作的,我刷新页面,有时它显示 3 个标记,有时它只显示我的起始 LatLng,这只是岛中间的一个随机点。如果我缩小标记就在那里。因此,这似乎是标记的 LatLng 有时不会在循环中扩展的问题。
任何帮助将不胜感激。
<script type="text/javascript">
$(document).ready(function(){
var myCenter=new google.maps.LatLng(12.106058, -68.935192);
var mapOptions = {
mapTypeId:google.maps.MapTypeId.ROADMAP
};
var map = new google.maps.Map(document.getElementById('map-canvas'),mapOptions);
bounds = new google.maps.LatLngBounds();
bounds.extend(myCenter);
$.getJSON('map.php',function(data){
if(data.success == true) {
if(data.CData.length > 0){
$.each(data.CData,function(index, value){
CID = value.CID;
Active = value.Active;
Name = value.Name;
Tel = value.Tel;
Lng = value.Longitude;
Lat = value.Latitude;
i=0;
addMarker(map, i, CID, Active, Name, Tel, Lat, Lng);
setBounds(Lat, Lng);
i++;
});
}
}
});
map.setCenter(bounds.getCenter());
map.fitBounds(bounds);
});
function addMarker(map, i, CID, Active, Name, Tel, Lat, Lng){
if (Active == 1){
if (Lat != null && Lng != null){
//alert("loop start!");
var myLatLng = new google.maps.LatLng(Lat, Lng);
var imageUrl = 'Images/default.png';
var markerImage = new google.maps.MarkerImage(imageUrl);
var marker = new google.maps.Marker({
position: myLatLng,
map: map,
icon: markerImage,
title: Name,
zIndex: i
});
image = '<img src="image.php?cid='+CID+'" class="img-responsive img-thumbnail" />';
var content = '<div class="">'+image+'<h4>'+Name+'</h4><h4><span class="label label-danger">Tel: '+ Tel +'</span></h4></div>';
var infowindow = new google.maps.InfoWindow({
content: content,
maxWidth: 370
});
google.maps.event.addListener(marker, 'click', function (){
infowindow.open(map, marker);
});
}
}
}
function setBounds(Lat, Lng){
var newLatLng = new google.maps.LatLng(Lat, Lng);
bounds.extend(newLatLng);
}
</script>
获取标记数据的 ajax 调用异步发生,即它可以在调用 map.setCenter 和 map.fitBound 后完成。 您应该尝试将它们移动到addMarker函数中,或者仅在所有标记完成添加后执行,例如
$.getJSON('map.php',function(data){
if(data.success == true) {
if(data.CData.length > 0){
$.each(data.CData,function(index, value){
CID = value.CID;
Active = value.Active;
Name = value.Name;
Tel = value.Tel;
Lng = value.Longitude;
Lat = value.Latitude;
i=0;
addMarker(map, i, CID, Active, Name, Tel, Lat, Lng);
setBounds(Lat, Lng);
i++;
});
map.setCenter(bounds.getCenter());
map.fitBounds(bounds);
}
}
});
相关文章:
- jQuery.load随机工作,绝望
- 从数组中随机选择,但在for循环中选择是不可能的;没有按预期工作
- 新的google.maps.LatLngBounds()绑定扩展和中心工作随机
- 在页面上放置一个随机生成器脚本 - 它可以工作.添加另一个具有不同名称的 - 不起作用
- javascript动画ScrollTop随机工作
- 这里有一些用于随机化数组的javascript.有人可以一点一点地解释它是如何工作的
- JQuery Click函数随机停止工作
- 引导模式随机停止工作
- Javascript中具有最小值和最大值的随机生成器不工作
- 循环以在工作不正常的表中生成随机单元格
- 索引工作良好,即使图像是随机显示的
- 随机CSS文件加载-不工作在IE8 (7?)
- 随机报价按钮不工作(简单)(HTML, JS, CSS)
- setinterval工作非常随机
- 随机音乐播放通过HTML javascript不正常工作
- 工作与Imacros javascript,需要随机变量除了一个值
- Javascript onclick随机工作
- JavaScript不工作在随机引号生成器
- 数学.随机函数不能正常工作在javascript与if语句
- JavaScript不工作?随机函数发生器的代码