最近参与了一个IOT环境项目,需要对某个城市的某几个区域做环境监控与治理,其中就用到了地图叠加层的功能,粗看很复杂,其实很简单,先来看一下效果,然后再来讲一下如何实现的:

中间的黄色轮廓线包括的几块区域就是通过gis坐标和百度的叠加层来实现的,来简单说一下实现的步骤吧:
首先需要有每块区域的坐标集合,这个主要是由工程队施工人员,在当地采集坐标,采集后会生成相应的文件给到开发人员
这些文件主要为如下:
其中这个红框内的文件是我们最需要的文件,他是一个shp文件,轮廓文件,开发人员需要转换为一个jsonlist,才可以使用,
那么如何转换呢,首先,要有个知识点需要说明,就是工程队测量的坐标系,可能并不是我们真正要使用的经纬度,因为不同坐标系的规范导致地图坐标显示不正确,所以需要转换坐标系为国标(也就是1984)
这时需要下载并且安装 ArcGis 这个软件,专门用于处理地图的,安装完毕后,如下,然后打开红框中的ArcMap
其实就是一个json对象里包含了坐标的json数组
接下来的工作就是通过js来渲染图层了
最终效果获取了某个地区进行了渲染如下:
var china = new BMap.Polygon([], {
strokeColor : "orange",
strokeWeight : 2,
strokeOpacity : 0.5,
fillOpacity: 0.1,
strokeStyle: "solid",
fillColor: "red"
}); //创建多边形
$.ajax({
url: "${ctx}/resources/module/script/dashboard/china.json",
type: 'GET',
async: true
}).done(function (res) {
var pointArray = res.geometries[0].coordinates[0];
var convertor = new BMap.Convertor();
var realPointArray = [];
for (var i = 0 ; i < pointArray.length ; i ++) {
var obj = pointArray[i];
var mapPoint = new BMap.Point(obj[0], obj[1])
var pointArr = [];
pointArr.push(mapPoint);
realPointArray.push(mapPoint);
}
china.setPath(realPointArray);
})
map.addOverlay(china);
官网itzixi.com
微信公众号:BeJavaGod
新浪微博
知乎
简书
cnblogs
今日头条
豆瓣
--> 同步更新