百度地图MapV实现海量数据画线、点聚合等功能

前言

MapVGL,是一款基于WebGL的地理信息可视化库,可以用来展示大量基于3D的地理信息点线面数据。设计初衷主要是为了解决大数据量的三维地理数据展示问题及一些炫酷的三维效果。

官网地址:MapV开发文档

公司项目中针对地图上的数据展示效果,由于数据量过大,有些是路段展示,有些是点展示,用百度地图原本的地图画线、打点功能也能实现,但是交互效果不是很好,首次加载很慢且拖动地图会卡,用到mapV这个类似可以解决海量数据展示问题。

一、使用步骤

1、前期准备

首先vue项目下要在html页面引入几个官方js文件,马赛克的是百度ak 需要自己去申请。

js文件引入过后 在页面就可以开始用mapv可视化 实现想要的地图效果了 ↓↓↓↓

2、开始开发

首先初始化百度地图, 然后定义mapView实例, 我在全局定义了一个,方便后面能直接拿到,

画线功能↓↓

mapData是后端返回的要展示的数据,这个根据数据结构来筛选要的经纬度集合,因为是画线,coordinates这个对应的是每个线段的经纬度集合,new mapvgl.LineLayer后面对象里面就是对线条的一些样式大,data把所有要展示的线条赋值就行,onClick鼠标点击线条触发,可以做一些交互的效果 也有右击onRightClick ,最后把创建的实例添加到全局mapView.addLayer(this.lineLayer)

点聚合功能↓↓

和画线功能类似,只不过coordinates对应是点的经纬度,因为点聚合最后的地图级别显示的是点,点的样式可以自行设置 icon,  后面的属性都大差不差了。

最后给大家看看效果~~~

 3、补充

官网有些文档写的还算详细的,有些图层类的操作也能用到

removeAllLayers: 删除所有图层

hideLayer:隐藏对应图层

showLayer:显示对应图层


总结

加油呀!!!   有问题可以多多沟通交流哈 小白还请大家多多指教

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
以下是一个简单的Android Studio实现百度地图及定位的代码示例: 1. 在build.gradle文件中添加以下依赖: ``` implementation 'com.baidu.android:location:7.6.0' implementation 'com.baidu.lbsapi:baseutils:1.1.9' implementation 'com.baidu.lbsapi:search:7.6.0' implementation 'com.baidu.lbsapi:mapv4-sdk:5.2.0' ``` 2. 在布局文件中添加MapView组件: ``` <com.baidu.mapapi.map.MapView android:id="@+id/mapView" android:layout_width="match_parent" android:layout_height="match_parent" /> ``` 3. 在Activity中声明MapView和BaiduMap对象: ``` private MapView mapView; private BaiduMap baiduMap; ``` 4. 在onCreate()方法中初始化MapView和BaiduMap: ``` @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_maps); mapView = (MapView) findViewById(R.id.mapView); baiduMap = mapView.getMap(); baiduMap.setMapType(BaiduMap.MAP_TYPE_NORMAL); baiduMap.setMyLocationEnabled(true); } ``` 5. 在Activity中声明LocationClient和BDLocationListener对象: ``` private LocationClient locationClient; private BDLocationListener locationListener; ``` 6. 在onCreate()方法中初始化LocationClient和BDLocationListener,实现位置信息回调: ``` locationClient = new LocationClient(getApplicationContext()); locationListener = new BDLocationListener() { @Override public void onReceiveLocation(BDLocation location) { if (location == null || mapView == null) { return; } MyLocationData myLocationData = new MyLocationData.Builder() .accuracy(location.getRadius()) .direction(location.getDirection()) .latitude(location.getLatitude()) .longitude(location.getLongitude()) .build(); baiduMap.setMyLocationData(myLocationData); LatLng latLng = new LatLng(location.getLatitude(), location.getLongitude()); MapStatusUpdate mapStatusUpdate = MapStatusUpdateFactory.newLatLngZoom(latLng, 18); baiduMap.animateMapStatus(mapStatusUpdate); } }; locationClient.registerLocationListener(locationListener); LocationClientOption option = new LocationClientOption(); option.setScanSpan(1000); option.setCoorType("bd09ll"); option.setOpenGps(true); locationClient.setLocOption(option); locationClient.start(); ``` 7. 在onResume()方法中启动地图: ``` @Override protected void onResume() { super.onResume(); mapView.onResume(); } ``` 8. 在onPause()方法中暂停地图: ``` @Override protected void onPause() { super.onPause(); mapView.onPause(); } ``` 9. 在onDestroy()方法中销毁地图: ``` @Override protected void onDestroy() { super.onDestroy(); mapView.onDestroy(); locationClient.stop(); baiduMap.setMyLocationEnabled(false); } ``` 这样,就可以在Android Studio中实现百度地图及定位功能了。当用户位置发生变化时,会在地图上显示当前位置的标记,并自动调整地图视角。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值