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

最近在做一个演示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" οnclick="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和按钮,进行消息触发。



由于百度提供的边界线接口中,县级区域数据并未完全更新完整,如三沙市,广丰县实质上已经变为区等,所以这样界线数据相对来说还是有些滞后。


  • 0
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
百度地图提供了一种方便的方法,可以通过JSON边界下载来获取地图数据。 首先,要使用百度地图JSON边界下载功能,需要使用开发者密钥。开发者密钥用于向百度地图API发送请求,并获取相应的地图数据。 接下来,可以通过发送HTTP GET请求来获取JSON边界数据。在请求URL,需要包含相应的参数,如请求类型(type)为边界类型(bound)等。百度地图支持多个边界类型,例如省级边界(province)、市级边界(city)和区县级边界(district)等。 请求发送后,百度地图API会返回相应的JSON数据,其包括了所请求的边界数据。可以通过解析JSON数据获取到地图的边界坐标信息。 对于省、市、区县等不同级别的边界数据百度地图提供了相应的接口和参数,可以根据需求进行选择和调整。例如,可以通过设置返回数据的坐标类型(坐标系类型),进行数据的适配和转换。 JSON边界下载功能在许多应用场景都有广泛的应用。例如,可以通过获取市级边界数据,进行城市边界划定和画图等操作。也可以通过获取区县边界数据,进行行政区划相关的分析和展示等。 总之,百度地图的JSON边界下载功能提供了一种方便的方式,可以获取到所需的地图边界数据。通过发送请求,并解析返回的JSON数据,可以实现对地图数据的灵活应用和定制。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值