百度地圖如何獲取國內行政區的邊界,同時添加覆蓋物並且填充顏色

在做企業應用項目時,尤其涉及到國家單位裏面的關於某個市裏面某個區的統計信息,會經常用到畫出區邊界的功能。

如果是用存gis開發的方法做圖估計複雜,對於簡單的項目比較划不來。

這裏我們介紹下一種比較簡單的方法:

通過百度地圖接口獲取行政區的邊界,並且在地圖上畫出區域的多邊覆蓋圖形,且可以填充顏色。

下面是代碼:

先添加html,同時設置您的百度地圖密鑰:

<!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="//api.map.baidu.com/api?v=2.0&ak=您的密鑰"></script>
    <title>添加行政區劃</title>
</head>
<body>
    <div id="allmap"></div>
</body>
</html>

然後添加調用百度地圖的js:

    var map = new BMap.Map("allmap");
    map.centerAndZoom(new BMap.Point(116.403765, 39.914850), 5);
    map.enableScrollWheelZoom();

    function getBoundary(){       
        var bdary = new BMap.Boundary();
        bdary.get("長沙市芙蓉區", 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], {strokeWeight: 2, strokeColor: "#ffffff"}); //建立多邊形覆蓋物
              ply.setFillColor("#22B8DD");
                map.addOverlay(ply);  //添加覆蓋物
                pointArray = pointArray.concat(ply.getPath());
            }    
            map.setViewport(pointArray);    //調整視野           
        });   
    }

    setTimeout(function(){
        getBoundary();
    }, 2000);

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