地图上分成一块一块区域 高德地图_在谷歌地图上绘制行政区域轮廓【结合高德地图的API】...

实现思路:

1.利用高德地图行政区域API获得坐标列表

2.将坐标列表绘制在谷歌地图上【因为高德地图和国内的谷歌地图都是采用GCJ02坐标系,所有误差很小,可以不进行坐标误差转换】

注意点:

1.用百度地图的API来绘制行政区域,不太准确,很不推荐。(1)百度地图查询行政区域本身不准确,有的地方本来应该属于该区,被划分到其他区了(2)即使要用百度api,也要注意转换坐标,因为百度,谷歌坐标系不同。贴段转换代码

var x_pi = Math.PI * 3000.0 / 180.0;//将 BD-09 坐标转换成 GCJ-02 坐标(例如:百度坐标-->谷歌坐标)

functionbd_decrypt(bd_lat, bd_lon) {var x = bd_lon - 0.0065, y = bd_lat - 0.006;var z = Math.sqrt(x * x + y * y) - 0.00002 * Math.sin(y *x_pi);var theta = Math.atan2(y, x) - 0.000003 * Math.cos(x *x_pi);var gg_lon = z *Math.cos(theta);var gg_lat = z *Math.sin(theta);var result ={};

result.gg_lon= gg_lon;//纬度

result.gg_lat = gg_lat;//经度

returnresult;

}

2.高德地图API文档写的很好,推荐使用高德地图

不完美的地方:

1.高德地图API提供的坐标,不能完整的画出一个区的轮廓,比如上海崇明区的被划分成几个小圈,而实际上,应该用一个大圈把崇明区包裹起来

对应的需求,绘制出上海的所有行政区的轮廓,实现效果:

核心代码:

showBoundarys();//显示行政区域

functionshowBoundarys() {//利用高德地图的【行政区划查询】api获取上海包含的所有区

AMap.service('AMap.DistrictSearch', function() {var opts ={

subdistrict:2, 返回下一级行政区。取值2,可以获取到上海的所有区

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

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

};//实例化DistrictSearch

var district = newAMap.DistrictSearch(opts);//行政区查询

district.search("上海市", function(status, result) {var cityArr = result.districtList[0].districtList[0].districtList;for(var i=0;i

showBoundary(cityArr[i].adcode);

}

})

});

}/**

* 用adcode(区域编码)查询,可以唯一定位到具体的地址。

* 用name(行政区名称)可能查出多个地址,不精确*/

functionshowBoundary(adcode) {//利用高德地图的【行政区划查询】api获取每个区的行政区边界坐标点,再根据这些坐标点在谷歌地图上绘制区域轮廓线

//加载行政区划插件

AMap.service('AMap.DistrictSearch', function() {var opts ={

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

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

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

};//实例化DistrictSearch

var district = newAMap.DistrictSearch(opts);

district.setLevel('district');//行政区查询

district.search(adcode, function(status, result) {var bounds = result.districtList[0].boundaries;if(bounds) {for (var i = 0, l = bounds.length; i < l; i++) {//每个区域可能有分能几个小块,比如金山区除了有一块陆地圈,还有海上独立的三个小岛

var boundsItem =bounds[i];var triangleCoords =[];for(var j = 0; j < boundsItem.length; j++){

triangleCoords.push(newgoogle.maps.LatLng(boundsItem[j].lat, boundsItem[j].lng));

}var bermudaTriangle = newgoogle.maps.Polygon({

paths : triangleCoords,

strokeColor :"#1c49ff",

strokeOpacity :0.8,

strokeWeight :1,//fillColor : "#FF0000",

fillOpacity : 0,

text:"xxxxx"});

bermudaTriangle.setMap(map);

map.setZoom(9);

}

}

});

});

}

参考网址:

4.高德地图的API比百度、谷歌的好用,比如行政区域的坐标比百度的精确,接口文档详细,而谷歌的文档还是英文的,例子也不够全。以后选择地图,首选高德地图

6.地球坐标系 (WGS-84)到火星坐标系 (GCJ-02) Javascript版

https://github.com/hiwanz/wgs2mars.js

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值