您的位置:首页 > 其它

批量获取百度地图中的县级以上行政区域的边界数据

2016-02-18 13:27 337 查看
最近在做一个演示DEMO的时候,需要省界和市一级界线的数据。以前自己是有这样的SHP数据的,然而现在由于行政区划更新很快,而自己之前下的数据还是2010年版本的国家基础数据。

网上没有相关的最新的界线数据,只好自己去搜索一下。还是不少人在做这样的东西的,如http://www.cnblogs.com/milkmap/archive/2012/04/11/2442430.html,http://www.cnblogs.com/i-gps/archive/2012/05/18/2507941.html等。而且都是利用百度地图的接口来实现的。

刚好按照网上的方法,自己也能搞定某一个边界的下载,按照网上的一个HTML页面就可以搞定的。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>获取地区轮廓线</title>

<script type="text/javascript" src="http://api.map.baidu.com/api?v=1.3">

</script>

<style type="text/css">

body{font-size:13px;margin:10px}

#container{width:800px;height:500px;border:1px solid gray}

</style>

</head>

<body>

<div id="container"></div>

<br />

输入省、直辖市或县名称:<input type="text" id="districtName" style="width:80px" value="重庆市">

<input type="button" onclick="getBoundary()" value="获取轮廓线">

<textarea id="Div1" style="width:100%;height:200px"></textarea>

<script type="text/javascript">

var map = new BMap.Map("container");

map.centerAndZoom(new BMap.Point(116.403765, 39.914850), 5);

map.addControl(new BMap.NavigationControl({type: BMAP_NAVIGATION_CONTROL_SMALL}));

map.enableScrollWheelZoom();

function getBoundary(){

var bdary = new BMap.Boundary();

var name = document.getElementById("districtName").value;

bdary.get(name, function(rs){ //获取行政区域

map.clearOverlays(); //清除地图覆盖物

document.getElementById('Div1').innerText = rs.boundaries;

var count = rs.boundaries.length; //行政区域的点有多少个

for(var i = 0; i < count; i++){

var ply = new BMap.Polygon(rs.boundaries[i], {strokeWeight: 2, strokeColor: "#ff0000"}); //建立多边形覆盖物

map.addOverlay(ply); //添加覆盖物

map.setViewport(ply.getPath()); //调整视野

}

});

}

</script>

</body>

</html>



但是中国的县级以上区域总共有3500多个,这样的话,逐个弄肯定是不行的。

于是呢,采用.net的webbrowser来实现对边界数据的批量下载。

其原理非常简单,就是通过webbrowser的document获取页面中指定的input和按钮,进行消息触发。



由于百度提供的边界线接口中,县级区域数据并未完全更新完整,如三沙市,广丰县实质上已经变为区等,所以这样界线数据相对来说还是有些滞后。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: