1. 程式人生 > >百度地圖AIP(2):地圖根據標註點位置自適應調整縮放等級

百度地圖AIP(2):地圖根據標註點位置自適應調整縮放等級

效果

自動設定縮放級別

原始碼

核心方法

// 根據點的陣列自動調整縮放級別
function setZoom (bPoints) {
     var view = map.getViewport(eval(bPoints));  
        var mapZoom = view.zoom;   
        var centerPoint = view.center;   
        map.centerAndZoom(centerPoint,mapZoom);  
}

完整程式碼

<!-- 
    liaotuo 
    2016.09.11 
    自動調整縮放等級 例項
-->
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <meta name="viewport" content="initial-scale=1.0, user-scalable=no" /> <style type="text/css"> body, html,#allmap {width: 100%;height: 100%;overflow: hidden;margin:0;font-family
:"微軟雅黑"
;}
</style> <script type="text/javascript" src="http://api.map.baidu.com/api?v=2.0& ak=你自己申請的ak"></script> <title>地圖根據標註點自適應大小</title> </head> <body> <div id="allmap"></div> </body> </html> <script type="text/javascript"> // 原始gps座標
var points = [ {"lng":112.58,"lat":26.89,"url":"http://www.baidu.com","id":1,"name":"p1"}, {"lng":112.59,"lat":26.90,"url":"http://www.taobao.com","id":2,"name":"p2"}, {"lng":112.57,"lat":26.88,"url":"http://www.google.com","id":3,"name":"p3"} ]; // 百度座標系座標(地圖中需要使用這個) var bPoints = new Array(); //建立標註點並新增到地圖中 function addMarker(points) { //迴圈建立標註點 for(var i=0, pointsLen = points.length; i<pointsLen; i++) { var point = new BMap.Point(points[i].lng, points[i].lat); //將標註點轉化成地圖上的點 bPoints.push(point); // 新增到百度座標陣列 用於自動調整縮放級別 var marker = new BMap.Marker(point); //將點轉化成標註點 map.addOverlay(marker); //將標註點新增到地圖上 } } // 根據點的陣列自動調整縮放級別 function setZoom (bPoints) { var view = map.getViewport(eval(bPoints)); var mapZoom = view.zoom; var centerPoint = view.center; map.centerAndZoom(centerPoint,mapZoom); } //建立地圖 var map = new BMap.Map("allmap"); map.centerAndZoom(new BMap.Point(112.591886,26.905407), 14); // 設定中心點 addMarker(points); map.addControl(new BMap.MapTypeControl()); map.enableScrollWheelZoom(true); setTimeout(function(){ setZoom(bPoints); }, 3000)
</script>