实际效果如下:
第一步,我们先获取地图底图,不包含区镇的地图文件可以从这个网站 上面下载DataV.GeoAtlas地理小工具系列,
如果要获取市或县底下的区镇数据,可通过下面的链接来获取
https://blog.sina.cn/dpool/blog/s/blog_c47286b00102zg2p.html
通过bigemap和geojson获取echarts精确到乡镇、街道的地图json数据(获取的json数据与echarts比少cp坐标,自行添加即可)
通过bigemap和geojson获取echarts精确到乡镇、街道的地图json数据
(一):进入bigemap下载页面,下载红框里的版本
(二):下载安装之后打开,可以在右上角进行区域的选择,可以发现,它是精确到镇级的,然后选择每个乡镇街道的区名等下载相应的kml,然后所有的区的kml文件放在一个文件夹
这里 不要点击左边的下载按钮,请选择图中 红框选中的导出按钮,即可保存kml文件:
可以在地图上看到效果:
(三)在geojson.io上把刚刚在bigemap地图下载器导出的kml文件导入进来geojson.io | powered by Mapbox
open-file 选中刚才的文件打开它
可以看到,左边就是你导入文件选择的数据区域,右边则是自动生成的geojson数据。
这样就完成了北京-平谷区其中一部分区域的绘制
接下来只要把所有区域选择一个区域一个区域下载下来,生成的kml文件导出保存在一个文件夹,再导入到这个网站,像拼拼图一样拼起来就可以了。
最后全部导入拼好之后,全选右边的数据,新建一个.json文件,拷贝进去保存,这样引用的时候就可以正常使用了。
既然地图的json已经获取到了,那如何通过echarts做成第一张的样子,下面是接口中返回的数据
[{
"xmmc": "xxxx",
"dtdmc": "xxxx",
"sl": 101,
"cfdjd": "120.980000",
"cfdwd": "31.380000",
"mddjd": "120.865",
"mddwd": "31.145"
}]
<template>
<div class="content" ref="echarts"></div>
</template>
<script>
// 引入echarts
import * as echarts from 'echarts'
// 引入地图
import 'echarts/lib/chart/map'
import chinaMap from '@/utils/china.json'
// 引入js
// import 'echarts/map/js/china.js'
export default {
components: {},
props: ['mapArr', 'isOpen'],
watch: {
isOpen: {
handler(newVal) {
if (newVal) {
this.lineData = this.mapArr
}
},
deep: true
}
},
data() {
// 这里存放数据
return {
planePath:
'image://',
res: [],
series: [],
lineData: []
}
},
mounted() {
// this.$nextTick(() => {
// this.init()
// })
},
// 方法集合
methods: {
init() {
echarts.registerMap('china', { geoJSON: chinaMap }) // 注册地图文件
const myChart = echarts.init(this.$refs.echarts)
this.res = []
this.series = []
let arr = []
for (var i = 0; i < this.lineData.length; i++) {
if (this.lineData[i].cfdjd && this.lineData[i].cfdwd) {
arr.push({
name: this.lineData[i].xmmc,
value: [this.lineData[i].cfdjd, this.lineData[i].cfdwd],
count: this.lineData[i].sl
})
}
if (this.lineData[i].mddjd && this.lineData[i].mddwd) {
arr.push({
name: this.lineData[i].dtdmc,
value: [this.lineData[i].mddjd, this.lineData[i].mddwd]
})
}
if (
this.lineData[i].cfdjd &&
this.lineData[i].cfdwd &&
this.lineData[i].mddjd &&
this.lineData[i].mddwd
) {
this.res.push({
fromName: this.lineData[i].xmmc,
toName: this.lineData[i].dtdmc,
coords: [
[this.lineData[i].cfdjd, this.lineData[i].cfdwd],
[this.lineData[i].mddjd, this.lineData[i].mddwd]
],
count: this.lineData[i].sl
})
}
}
// console.log(this.res, 'this.res')
this.series.push(
//
{
name: '',
type: 'effectScatter',
coordinateSystem: 'geo',
// 要有对应的经纬度才显示,先经度再维度
data: arr,
showEffectOn: 'render',
rippleEffect: {
scale: 2, // 波纹的最大缩放比例
brushType: 'stroke'
},
// hoverAnimation: true,
label: {
normal: {
show: true,
formatter: params => {
// console.log(params, 'params')
return params.data.count ? params.data.count : ''
},
position: 'right',
// fontWeight: 500,
fontSize: 14,
// color: '#fff'
}
},
itemStyle: {
normal: {
color: '#00e3ff',
shadowBlur: 10,
shadowColor: '#333'
}
},
emphasis: {
itemStyle: {
color: '#f4e925' // 高亮颜色
}
},
zlevel: 1,
tooltip: {
show: true,
formatter: params => {
return `${params.data.name}`
// console.log(params, 'params')
}
}
},
{
name: '',
type: 'lines',
zlevel: 1,
effect: {
show: true,
constantSpeed: 20,
symbol: this.planePath,
symbolSize: 20,
trailLength: 0,
symbolRotate: 90
},
tooltip: {
formatter: function (param) {
// console.log(param, 'params')
return (`<div style="word-break: break-all;word-wrap: break-word;white-space: normal;margin: 0; padding: 0; max-width: 300px;">
<span style="margin: 0; padding: 0; line-height: 2; display: block;">起始地: ${param.data.fromName}</span>
<span style="margin: 0; padding: 0; line-height: 2; display: block;">目的地: ${param.data.toName}</span>
<span style="margin: 0; padding: 0; line-height: 2; display: block;">趟数:${param.data.count}</span>
</div>`)
// return (
// param.data.fromName +
// '>' +
// param.data.toName +
// '<br>:' +
// param.data.count
// )
}
},
lineStyle: {
normal: {
color: new echarts.graphic.LinearGradient(
0,
0,
0,
1,
[
{
offset: 0,
color: '#58B3CC'
},
{
offset: 1,
color: '#F58158'
}
],
false
),
width: 3,
opacity: 0.5,
curveness: 0.1
}
},
data: this.res
}
)
let option = {
title: {
text: '',
textStyle: {
// color: '#ffffff'
}
},
legend: {
show: true,
selected: {},
x: 'left',
orient: 'vertical',
textStyle: {
color: 'white'
},
data: []
},
tooltip: {
trigger: 'item',
show: true
},
geo: {
map: 'china',
// show: true,
roam: true,
top: '0',
center: [120.983219, 31.369131],
zoom: 36,
label: {
normal: {
show: false
},
emphasis: {
show: false
}
},
// 地图的背景色
itemStyle: {
normal: {
areaColor: '#09184F',
borderColor: '#00ffff',
shadowColor: '#09184F',
shadowBlur: 20
},
emphasis: {
// 设置高亮状态下的样式
areaColor: '#0e64d7' // 地图区域的高亮背景色
}
}
},
series: this.series
}
myChart.setOption(option)
// window.addEventListener('resize', function() {
// myChart.resize()
// })
}
}
}
</script>
<style lang="scss" scoped>
.content {
width: 100%;
height: 100%;
}
</style>