vue 地图可视化 (2)
2018-04-12 12:09
796 查看
MapBox
项目中用到MapBox也是偶然的机会,项目中需要采用3D地图,当现有的工具(百度地图)无法满足我们的需求,我们肯定需要更高级开源的地图,无奈谷歌地图无法在国内使用,已是便找到Leafle,一开始惊艳于leafle的开源程度和其与众不同的地图风格,后来顺藤摸瓜,找到一个商业性地图,它便是我们的主角-MapBox作为国外的一款地图,看到其效果时便一发不可收拾
由于项目主要采用3d GL,国内在这方面的文档不多,只能举起社会主义的镰刀和火炬,一遍遍地看它的官方文档
mapbox gl https://www.mapbox.com/mapbox-gl-js/api/
项目引入Mapbox
CDN模式
在项目html的中直接插入mapbox
<script src='https://api.tiles.mapbox.com/mapbox-gl-js/v0.44.2/mapbox-gl.js'></script> <link href='https://api.tiles.mapbox.com/mapbox-gl-js/v0.44.2/mapbox-gl.css' rel='stylesheet' />
module bundler模式
npm install --save mapbox-gl // cnpm install --save mapbox-gl
初始化地图
这里的思路和之前写的一遍文章
[百度地图组件化][2]一样,都是将地图单独抽出来
mapbox.vue
<template> <div style="height:100%;width:100%;text-align:left;"> <div ref="basicMapbox" :style="mapSize"></div> </div> </template> <script> import mapboxgl from 'mapbox-gl' export default { props: { mapWidth: { type: String }, mapHeight: { type: String } }, data () { return { } }, mounted () { this.init() }, methods: { // 初始化 init () { mapboxgl.accessToken = 'your AK' const map = new mapboxgl.Map({ container: this.$refs.basicMapbox, style: 'mapbox://styles/mapbox/streets-v9' }) console.log(map) } }, computed: { mapSize () { let styleObj = { width: this.mapWidth, height: this.mapHeight } return styleObj } } } </script> <style> @import url('https://api.tiles.mapbox.com/mapbox-gl-js/v0.44.2/mapbox-gl.css'); </style>
因此只需在业务组件中单独引入mapbox.vue就可以加载地图
<mapbox-map mapWidth="100%" mapHeight="600px"></mapbox-map>
效果图:
mapbox可视化
mapbox原生提供数据可视化的接口,但这并没满足我们的需求
因此我们选用前端经常使用到可视化插件d3.js和echarts,经过横向对比其性能及通用性,最后还是选择了后者
echarts也提供3D绘制的echart-gl,通过利用mapbox强大的地图服务和echaers-gl的可视化渲染,达到我们的前期需求
(3d建模需要消耗大量的GPU运算,项目前期以功能实现为主,后期将着重性能优化)
这里写图片描述
效果图:
mapbox可视化的组件化
1、地图配置:echarts-GL内封装mapbox的配置项,通过options的mapbox可以直接进行简单配置(中心点、等级、摄像机倾斜度、摄像机高度及光源等)
mapbox: { center: [113.206456, 23.072519], zoom: 6.2, pitch: 60, bearing: 0, style: 'mapbox://styles/mapbox/dark-v9', boxHeight: 20, light: { main: { intensity: 1, shadow: true, shadowQuality: 'high' }, ambient: { intensity: 0.2 } } }
2、可视化工具:echarts-Gl options的series进行图表设置,通过getModel().getComponent(‘mapbox3D’).getMapbox()获取map对象
series: { name: '常驻人口', type: 'bar3D', shading: 'realistic', coordinateSystem: 'mapbox', silent: true, barSize: 1, // 柱子粗细 bevelSize: 0.3, emphasis: { label: { show: false } }, label: { show: true, distance: 0, formatter: '{b}', textStyle: { fontSize: 12 } }, data: [] }
3、动作及拓展:mapbox通过map API的on属性和mapboxgl进行地图的操作,如修改地图样式、加载图层、添加导航工具等用户交互动作
如:添加导航操作:
this.nav = new mapboxgl.NavigationControl() map.addControl(this.nav)
添加Geojson图层
map.addSource('states', { 'type': 'geojson', 'data': gdData }) map.addLayer({ 'id': 'state-fills', 'type': 'fill', 'source': 'states', 'layout': {}, 'paint': { 'fill-color': '#627BC1', 'fill-opacity': 0.1 } })
思路汇总:通过上面三步走的思路,我们可以把组件粗略分成三部分
核心的mapbox.vue是地图视图
可视化图表由echarts-gl组成
动作及拓展对地图视图和图表进行操作
效果图:
待续,文章持续更新修改……
完整项目github地址:https://github.com/hty7/vue-demo.git
上一篇文章:vue 地图可视化(1)百度地图篇
有不懂的地方,可以在下方留言,或者私聊。对文章感兴趣的话,点下赞、收藏和github收集小星星,谢谢大家。
相关文章推荐
- vue如何引入echarts地图
- 干货 | 可视化设计:地图四部曲之迁徙图
- Basemap可视化地图信息
- WebGL可视化地球和地图引擎:Cesium.js
- 这7个不可错过的数据可视化技术,能让地图惊喜跃动
- 2015-03-29-绘图和可视化(3)-绘制地图:图形化显示海地地震危机数据
- iPviking:在线黑客攻击可视化地图
- python画地图数据可视化分析
- 使用R进行地图相关的可视化
- Raphael.js 在vue中使用说明, 以杭州市地图为例
- 成佩涛——iPviking:在线黑客攻击可视化地图
- 基于Vue 2和高德地图的地图组件 - vue-amap
- [地图可视化]Grasshopper Geography技术色线突出了全世界淡水支流的广阔范围
- vue+vuex+axios+echarts画一个动态更新的中国地图的方法
- vue高德地图之玩转周边
- 高德地图vue的调用
- 空间可视化——地图是怎么炼成的
- R语言学习笔记︱Echarts与R的可视化包——地区地图
- 干货|可视化设计:地图四部曲之地图热力+散点
- 可视化操作工具 MongoVUE Document更新