百度地图如何获取国内行政区的边界,同时添加覆盖物并且填充颜色

在做企业应用项目时,尤其涉及到国家单位里面的关于某个市里面某个区的统计信息,会经常用到画出区边界的功能。

如果是用存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);

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
GeoJSON是一种用于表示地理空间数据的开放标准格式。利用GeoJSON工具可以在地图上绘制行政区边界。而基于百度地图的GeoJSON工具,就是为了在百度地图上使用GeoJSON格式的数据来绘制行政区边界。 使用百度地图的GeoJSON工具首先需要获取行政区边界的GeoJSON数据。这可以通过百度地图开放平台提供的行政区边界查询接口来获取。根据所需要的行政区域,通过接口查询并获取到对应的GeoJSON数据。 获取到GeoJSON数据后,可以使用百度地图提供的JavaScript API来在地图上绘制行政区边界。通过将GeoJSON数据传入地图的overlay对象中,可以动态地在地图上绘制出行政区边界边界线和填充色。 绘制行政区边界的过程中,可以根据需求来对绘制样式进行自定义。例如,可以设置边界线的颜色、粗细、透明度等属性,还可以设置填充色的颜色、透明度等属性,以实现不同的视觉效果。 绘制完成后,可以通过交互操作来对已绘制的行政区边界进行展示和控制。例如,可以通过添加鼠标事件,实现鼠标悬浮显示行政区名称,点击区域展示详情等功能,提供更好的用户体验。 综上所述,基于百度地图的GeoJSON工具能够方便地在地图上绘制行政区边界。通过获取GeoJSON数据并利用百度地图JavaScript API进行绘制,可以实现自定义样式、交互操作等功能,为用户提供更加直观、灵活的地图展示。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值