在做企业应用项目时,尤其涉及到国家单位里面的关于某个市里面某个区的统计信息,会经常用到画出区边界的功能。
如果是用存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);