百度地圖行政區劃遮罩+描點+信息窗demo

工作中用到了百度地圖,將用到的代碼進行整理,供大家參考。
<!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=您的密鑰"></script>
    <!-- 點聚合需引用 -->
    <script type="text/javascript" src="http://api.map.baidu.com/library/TextIconOverlay/1.2/src/TextIconOverlay_min.js"></script>
    <script type="text/javascript" src="http://api.map.baidu.com/library/MarkerClusterer/1.2/src/MarkerClusterer_min.js"></script>
    <title>地圖展示</title>
</head>
<body>
    <div id="allmap"></div>
</body>
</html>
<script type="text/javascript">
    // 百度地圖API功能
    var map = new BMap.Map("allmap");    // 創建Map實例
    var boundary = ["石家莊市裕華區","石家莊市新華區","石家莊市橋西區","石家莊市長安區"];
    var color = ["#FFD700","#FF83FA","#FF0000","#FF4500"];
    var address = ["石家莊市鐵道大學","石家莊市物聯網大廈","石家莊科技中心","石家莊植物園","石家莊市裕華區南二環東路河北師範大學"];

    map.centerAndZoom(new BMap.Point(114.527, 38.071), 13);  // 初始化地圖,設置中心點座標和地圖級別
    //map.centerAndZoom("河北", 9);  // 初始化地圖,第一個參數可以使用中心點座標,也可以使用城市名稱;第二個參數爲地圖級別
    //添加地圖類型控件 
    map.addControl(new BMap.MapTypeControl({
        mapTypes:[
            BMAP_NORMAL_MAP,
            BMAP_HYBRID_MAP
        ]}));     
    //map.setCurrentCity("北京");          // 百度註釋(設置地圖顯示的城市 此項是必須設置的 )  不設置也不影響地圖顯示,不知道具體作用
    map.enableScrollWheelZoom(true);     //開啓鼠標滾輪縮放
    for (var i = 0; i < boundary.length; i++) {
        getBoundary(boundary[i],color[i]);  //行政區劃覆蓋遮罩
    }
    for (var j = 0; j < address.length; j++) {
        getPoint(address[j]);  //地圖描點
    }

    //點聚合
    /* var markers = [];
    for (var i = 0; i < 10; i++) {
       pt = new BMap.Point(Math.random() * 40 + 85, Math.random() * 30 + 21);
       markers.push(new BMap.Marker(pt));
    }
    var markerClusterer = new BMapLib.MarkerClusterer(map, {markers:markers}); */

    //單擊獲取點擊的經緯度
    /* map.addEventListener("click",function(e){
        alert(e.point.lng + "," + e.point.lat);
    }); */



    function getBoundary(area,color){       
        var bdary = new BMap.Boundary();
        bdary.get(area, function(rs){       //獲取行政區域
            //map.clearOverlays();        //清除地圖覆蓋物       
            var count = rs.boundaries.length; //行政區域的點有多少個
            if (count === 0) {
                alert('未能獲取當前輸入行政區域');
                return ;
            }
            var pointArray = [];
            for (var i = 0; i < count; i++) {
                var ply = new BMap.Polygon(rs.boundaries[i], {strokeColor:"green",fillColor: color ,fillOpacity:"0.3",strokeOpacity:0.3,strokeWeight: 2}); //建立多邊形覆蓋物
                map.addOverlay(ply);  //添加覆蓋物
                pointArray = pointArray.concat(ply.getPath());
            }    
            //map.setViewport(pointArray);    //調整視野  
        });   
    }
    // 將地址解析結果顯示在地圖上,並調整地圖視野
    function getPoint(address) {
        // 創建地址解析器實例
        var myGeo = new BMap.Geocoder();
        myGeo.getPoint(address, function(point){
            if (point) {
                //map.centerAndZoom(point, 16);
                var marker = new BMap.Marker(point);
                map.addOverlay(marker);  //描點
                var opts = {
                    width : 280,     // 信息窗口寬度
                    height: 150,     // 信息窗口高度
                    title : "<span class='content'>詳細信息</span>" , // 信息窗口標題
                }
                var infoWindow = new BMap.InfoWindow("<font class='content'>地址:"+address+"<br/>座標:"+point.lng+"," +point.lat+
                        "<br/><a href='javascript:void(0)' onclick='alert(\"啦啦啦!!!\")' style='font-size:18px;color:blue;text-decoration:underline;'>點擊有驚喜!!!</a></font>"
                        ,opts);  //創建信息窗口對象 
                //鼠標點擊事件
                marker.addEventListener("click", function(){          
                    map.openInfoWindow(infoWindow,point); //開啓信息窗口
                    //map.centerAndZoom(point,14);
                });
                //鼠標移入事件
                /* marker.addEventListener("mouseover", function(){            
                    map.openInfoWindow(infoWindow,point); //開啓信息窗口  
                }); */
            }else{
                alert("您選擇地址沒有解析到結果!"); 
            }
        }, "石家莊市");
    }
</script>

效果圖

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章