OpenLayers结合Echarts实现海量点的前端可视化

前言

OpenLayers这个库在前端操作地图自然是数一数二的存在,但是对于在地图上海量数据的绘制就显得有点力不从心,虽然目前Openlayers4以后地图上数据的绘制相关绘制接口已经开始基于WebGL进行封装,一定程度上决解决了数据绘制速度问题但对于海量数据绘制到客户端所带来的内存占用问题并没有得到解决,这其实也怪不得OL的开发者,人家本来就不是为了数据可视化打造的,之所以开始采用WebGL进行绘图API的封装也仅仅是为了给地图相关应用的开发起到锦上添花的作用,这时deck.gl Echarts等便可提枪上马了,目前对于前端点绘制优化相关的例子都是针对矢量地图进行的,这里采用栅格瓦片作为底图实现对于10W级别点的前端绘制

方法比较

OpenLayers4结合setInterval函数实现简单的地图动画----以溢油粒子的漂移扩散为例
这个小功能实现之后甲方提出了新要求,目前在OpenLayers加载的栅格瓦片上绘制的最大点数为72000个,在拖动时发现出现卡顿,并且又提出最终需要在地图上展示30多万个点(这尼玛这么密的点不做聚类全部展示出来有意义吗)没有办法,甲方这样要求老师说让这样整,那我就照做,初步想法有下面几种
1 Openlayers cluster实现聚类(或者有其它相关包实现聚类)
2 使用imagecanvas将绘制的点作为图片加载地图上
3 利用第三方专门做可视化的库与OpenLayers结合
1 2 都被老师华丽的否决了,那就沿着第三条路走到黑了

方法2的实现过程

其实解决前端地图拖动过程

  • 5
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
OpenLayers是一个开源的JavaScript库,用于在Web浏览器中显示交互式地图。OpenLayers可以加载各种类型的地图数据,包括矢量数据、栅格数据、WMS服务等。下面是实现可视化的步骤: 1. 准备气象战数据,可以是CSV、JSON等格式的文件。 2. 在HTML页面中添加OpenLayers的引用: ``` <script src="https://cdn.jsdelivr.net/npm/ol@6.4.3/dist/ol.js"></script> <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/ol@6.4.3/dist/ol.css" /> ``` 3. 创建一个地图容器: ``` <div id="map" style="width: 100%; height: 600px;"></div> ``` 4. 创建一个OpenLayers地图对象: ``` var map = new ol.Map({ target: 'map', layers: [ new ol.layer.Tile({ source: new ol.source.OSM() }) ], view: new ol.View({ center: ol.proj.fromLonLat([120, 30]), zoom: 8 }) }); ``` 5. 加载气象战数据: ``` var features = []; // 读取CSV文件中的数据 d3.csv("data.csv", function(data) { data.forEach(function(d) { // 将数据转换为OpenLayers要求的格式 var feature = new ol.Feature({ geometry: new ol.geom.Point(ol.proj.fromLonLat([+d.lng, +d.lat])), name: d.name, value: +d.value }); features.push(feature); }); // 创建矢量图层 var vectorLayer = new ol.layer.Vector({ source: new ol.source.Vector({ features: features }), style: function(feature) { // 根据value的值设置的颜色和大小 var color = 'rgba(255, 0, 0, 0.5)'; var size = 10; if (feature.get('value') > 10) { color = 'rgba(0, 255, 0, 0.5)'; size = 20; } return new ol.style.Style({ image: new ol.style.Circle({ radius: size, fill: new ol.style.Fill({ color: color }) }) }); } }); // 将矢量图层添加到地图中 map.addLayer(vectorLayer); }); ``` 6. 根据需要设置地图的样式和交互功能。 以上就是使用OpenLayers加载气象战数据实现可视化的步骤。需要注意的是,代码中使用了d3.csv方法读取CSV文件中的数据,因此需要在HTML页面中添加d3.js的引用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值