AMap.DistrictSearch行政区查询服务插件,提供全国各省、市、县、区的中心点经纬度、行政区边界坐标组、下级行政区等信息。根据行政区边界坐标组可在地图上绘制行政区边界。(本文为原创,并在项目中验证成功。作者:张甫军)

第一步,插件及样式的引用:

    <link rel="stylesheet" href="http://cache.amap.com/lbs/static/main1119.css" />
<script src="http://webapi.amap.com/maps?v=1.3&key=7defcebd378d7fcd05dbcb9298d20d2e&plugin=AMap.PolyEditor,AMap.CircleEditor,AMap.MouseTool,AMap.DistrictSearch"></script>
<script type="text/javascript" src="http://cache.amap.com/lbs/static/addToolbar.js"></script>
<script type="text/javascript" src="http://webapi.amap.com/demos/js/liteToolbar.js"></script>

第二步,HTML代码:

  <div id="container"></div>
<div id="tip">
省:<select id='province' style="width:100px" onchange='search(this)'></select>
市:<select id='city' style="width:100px" onchange='search(this)'></select>
区:<select id='district' style="width:100px" onchange='search(this)'></select>
街道:<select id='street' style="width:100px" onchange='setCenter(this)'></select>
&nbsp;&nbsp;<input type="button" id="clearMap" onclick="clearMap()" value="清除" />
</div>

第三步,页面CSS样式:

    <style type="text/css">
#tip {
background-color: #fff;
padding: 0 10px;
border: 1px solid silver;
box-shadow: 3px 4px 3px 0px silver;
position: absolute;
font-size: 12px;
right: 10px;
top: 5px;
border-radius: 3px;
line-height: 36px;
}
</style>

第四步,JavaScript代码:

  1. 初始化地图:

            var editorTool, district, polygons = [], citycode, map = new AMap.Map("container", {
    //resizeEnable: true,
    //center: [116.403322, 39.900255],
    //zoom: 13
    resizeEnable: true,
    //center: [116.30946, 39.937629],
    zoom: 3
    });
  2. 初始化搜索下拉框:
            var citySelect = document.getElementById('city');
    var districtSelect = document.getElementById('district');
    var areaSelect = document.getElementById('street'); var opts = {
    subdistrict: 1,
    level: 'city',
    showbiz: false
    };
    district = new AMap.DistrictSearch(opts);
    district.search('中国', function (status, result) {
    if (status == 'complete') {
    getData(result.districtList[0]);
    }
    });
    var mapCenter = null;
    var districtObj = {
    Center: null,
    Bounds: null
    };
    function getData(data) {
    var bounds = data.boundaries;
    mapCenter = data.center;
    districtObj.Center = data.center;
    districtObj.Bounds = bounds == null ? districtObj.Bounds : bounds;
    console.log('default1');
    if (bounds && '@((int)ElectronicFenceModel.ShapeType.District)' == '@((int)shapeType)') {
    for (var i = 0, l = bounds.length; i < l; i++) {
    var polygon = new AMap.Polygon({
    map: map,
    strokeWeight: 1,
    strokeColor: '#CC66CC',
    fillColor: '#CCF3FF',
    fillOpacity: 0.5,
    path: bounds[i]
    });
    polygons.push(polygon);
    }
    map.setFitView();
    } var subList = data.districtList;
    var level = data.level; if (level === 'province') {
    nextLevel = 'city';
    citySelect.innerHTML = '';
    districtSelect.innerHTML = '';
    areaSelect.innerHTML = '';
    } else if (level === 'city') {
    nextLevel = 'district';
    districtSelect.innerHTML = '';
    areaSelect.innerHTML = '';
    } else if (level === 'district') {
    nextLevel = 'street';
    areaSelect.innerHTML = '';
    }
    if (subList) {
    var contentSub = new Option('--请选择--');
    for (var i = 0, l = subList.length; i < l; i++) {
    var name = subList[i].name;
    var levelSub = subList[i].level;
    var cityCode = subList[i].citycode;
    if (i == 0) {
    document.querySelector('#' + levelSub).add(contentSub);
    }
    contentSub = new Option(name);
    contentSub.setAttribute("value", levelSub);
    contentSub.center = subList[i].center;
    contentSub.adcode = subList[i].adcode;
    document.querySelector('#' + levelSub).add(contentSub);
    }
    } }
    function search(obj) {
    //清除地图上所有覆盖物
    for (var i = 0, l = polygons.length; i < l; i++) {
    polygons[i].setMap(null);
    }
    var option = obj[obj.options.selectedIndex];
    var keyword = option.text; //关键字
    var adcode = option.adcode;
    district.setLevel(option.value); //行政区级别
    district.setExtensions('all');
    //行政区查询
    //按照adcode进行查询可以保证数据返回的唯一性
    district.search(adcode, function (status, result) {
    if (status === 'complete') {
    getData(result.districtList[0]);
    setFence();
    }
    });
    }
    function setCenter(obj) {
    mapCenter = obj[obj.options.selectedIndex].center;
    map.setCenter(obj[obj.options.selectedIndex].center);
    setFence();
    } function clearMap() {
    map.clearMap();
    }

    以上代码,可以完成行政区查询,提供全国各省、市、县、区的中心点经纬度、行政区边界坐标组、下级行政区等信息。根据行政区边界坐标组可在地图上绘制行政区边界。注意:AMap.DistrictSearch行政区查询服务插件的初始化有2种方式,第一种:使用插件同步下发功能才能这样直接使用(本文采用此种方式,注意查看插件的引用);第二种:(查看下面的代码)

    mapObj.plugin('AMap.DistrictSearch', function () {
    var opts = {
    subdistrict: 0, //返回下一级行政区
    extensions: 'all', //返回行政区边界坐标组等具体信息
    level:'city' //查询行政级别为 市
    };

      

mapObj.plugin('AMap.DistrictSearch', function () {

var opts = {

subdistrict: 0, //返回下一级行政区

extensions: 'all', //返回行政区边界坐标组等具体信息

level:'city'//查询行政级别为市

};

AMap行政区查询服务的更多相关文章

  1. C#调用天气查询服务

    先引入天气查询服务 1.有点引用导入服务引用 //实例化            web引用名.WeatherWebService cn = new web引用名.WeatherWebService() ...

  2. .NET应用架构设计—面向查询服务的参数化查询设计(分解业务点,单独配置各自的数据查询契约)

    阅读目录: 1.背景介绍 2.对业务功能点进行逻辑划分(如:A.B.C分别三个业务点) 2.1.配置映射关系,对业务点配置查询契约(构造VS插件方便生成查询契约) 2.2.将配置好的映射策略文件放在调 ...

  3. 用.net访问电子枢纽信用中心的数据查询服务

    概要说明 电子枢纽全称国家交通运输物流公共信息平台,主要提供物流及生产企业进行物流相关数据交换的标准和API,详细介绍可参考其官网www.logink.org,本文假定阅读者对该平台已有了解,并已成功 ...

  4. MVC项目实践,在三层架构下实现SportsStore-09,ASP.NET MVC调用ASP.NET Web API的查询服务

    ASP.NET Web API和WCF都体现了REST软件架构风格.在REST中,把一切数据视为资源,所以也是一种面向资源的架构风格.所有的资源都可以通过URI来唯一标识,通过对资源的HTTP操作(G ...

  5. AspNet.WebAPI.OData.ODataPQ实现WebAPI的分页查询服务-(个人拙笔)

    AspNet.WebAPI.OData.ODataPQ 这是针对 Asp.net WebAPI OData 协议下,查询分页.或者是说 本人在使用Asp.Net webAPI 做服务接口时写的一个分页 ...

  6. 基于FeignClient提供简单的用户查询服务

    前言: 由于系统升级,之前的员工数据库(mongo库)被弃用,改为用python维护的mysql库,其他系统访问通过http请求,表结构对外不可见,其他系统之前对员工mongo库的依赖要解除.每套系统 ...

  7. Ajax轮询——“定时的通过Ajax查询服务端”

    Ajax轮询——"定时的通过Ajax查询服务端". 概念: 轮询(polling):客户端按规定时间定时像服务端发送ajax请求,服务器接到请求后马上返回响应信息并关闭连接. 百闻 ...

  8. AspNet.WebAPI.OData.ODataPQ实现WebAPI的分页查询服务-(个人拙笔)(转)

    出处:http://www.bubuko.com/infodetail-827612.html AspNet.WebAPI.OData.ODataPQ 这是针对 Asp.net WebAPI ODat ...

  9. GraphQL介绍&使用nestjs构建GraphQL查询服务

    GraphQL介绍&使用nestjs构建GraphQL查询服务(文章底部附demo地址) GraphQL一种用为你 API 而生的查询语言.出自于Facebook,GraphQL非常易懂,直接 ...

随机推荐

  1. WAMPserver配置(允许外部访问、phpmyadmin设置为输入用户名密码才可登录等)

    对于很多不熟悉PHP环境安装的朋友来说,用集成环境可以更快的上手,更方便的搭建PHP的运行环境,但是,WAMP的集成环境仅仅是将底层基础工作做好 了,有些个别关键的配置操作并没有集成到环境安装中,所以 ...

  2. PHPnow在win8下安装失败的解决办法

    提示: 安装服务[ Apache_pn ]失败,可能原因如下:1.服务名已存在,请卸载或使用不同服务名.2.非管理员权限,不能操作Window NT服务. 解决方案: 搜索:命令提示符   , 右键以 ...

  3. div中显示页面

    在css中显示页面,在页面布局中很多时候都要在一个div 里显示某些页面.在这里写下我用到的一种方式. <script type="text/javascript"> ...

  4. C#基础——静态成员,static关键字

    当声明一个类成员为静态时,意味着无论创建多少个类的对象,只会有一个该静态成员的副本. 关键字static意味着只有一个该成员的实例.静态变量用于定义常量,因为它们的值可以通过直接调用类而不需要创建类的 ...

  5. tornado中self.write() 写list

    tornado源码中不支持在self.write()中直接传入list对象,源代码如下 def write(self, chunk): if self._finished: raise Runtime ...

  6. Vim速查脑图

  7. Please allow Subclipse team to receive anonymous usage statistics for this Eclipse intance(info)

    本文转载自:http://blog.csdn.net/myfxx/article/details/21096949 今天在用eclipse启动项目的时候发现了一个问题,就是每次启动项目的时候,ecli ...

  8. 99乘法表(bash)

    awk方式: # awk 'BEGIN{for(i=1;i<=9;i++){for(j=1;j<=i;j++){printf j"x"i"="i*j ...

  9. lnmp搭建的常见错误

    1:运行nginx时的错误 ./configure: error: the HTTP rewrite module requires the PCRE library. 解决: [root@svr11 ...

  10. maven项目导入tomcat7源码

    大家好,今天给大家分享对于tomcat源码在eclipse上的导入运行.此次为以tomcat7为例. 1去官网tomcat7的下载页面下载源码网址http://tomcat.apache.org/do ...