尽管花了整天的搜索和尝试无数的代码方法,但我仍然遇到了尝试正确居中和缩放谷歌地图的问题。谷歌地图v3 - 设置界标到标记中心
我不知道是否有人会那么善良,以指出我的代码中我做错了什么。在v2中一切正常,但我很难更新到v3。
有关信息 地图是一个更大的PHP应用程序的一小部分,并且所需要的纬度&长地图参数已经通过它们在主PROG使用和声明其他方法如下制得: -
var myDestination=new google.maps.LatLng(e_lat,e_long);
var myHome=new google.maps.LatLng(h_lat,h_long);
除了变焦和中心外,一切似乎都可以正常工作。 有问题的代码如下: -
function initialize()
{
// set the map properties
var mapProp = {
center:myHome,
zoom:12,
mapTypeId:google.maps.MapTypeId.ROADMAP
};
var map=new google.maps.Map(document.getElementById("googleMap"),mapProp);
// set the home marker
var marker_home=new google.maps.Marker({
position:myHome,
icon:'house.png'
});
marker_home.setMap(map);
//set the destination marker
var marker_destination=new google.maps.Marker({
position:myDestination,
icon:'flag_red.png'
});
marker_destination.setMap(map);
//google polyline between the 2 points
var myPolyline = [myDestination,myHome];
var directPath = new google.maps.Polyline({
path:myPolyline,
strokeColor:"#0000FF",
strokeOpacity:0.8,
strokeWeight:2
});
directPath.setMap(map);
// Make an array of the LatLng's of the markers you want to show
var LatLngList = array (new google.maps.LatLng (e_lat,e_long), new google.maps.LatLng (h_lat,h_long));
// Create a new viewpoint bound
var bounds = new google.maps.LatLngBounds();
// Go through each...
for (var i = 0, LtLgLen = LatLngList.length; i < LtLgLen; i++) {
// And increase the bounds to take this point
bounds.extend (LatLngList[i]);
}
// Fit these bounds to the map
map.fitBounds (bounds);
}
google.maps.event.addDomListener(window, 'load', initialize);
TIA的任何帮助:)
它正在做什么?你有任何的JavaScript错误?既然你只有2点,它应该没有循环工作。你能提供一个链接到一个展现问题的地图(或创建一个jsfiddle)吗? – geocodezip 2013-03-09 07:49:07
它似乎显示确定..只是fitBounds似乎不起作用,因此没有正确地居中两点之间。 http://jsfiddle.net/klaw/tQf9n/3/ – klaw 2013-03-09 11:36:49