百度地圖AIP(2):地圖根據標註點位置自適應調整縮放等級
阿新 • • 發佈:2019-02-16
效果
原始碼
核心方法
// 根據點的陣列自動調整縮放級別
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>