<template>
<div class="echarts12">
<div class="echarts1" ref="echarts">
</div>
</div>
</template>
<script>
import map from './map.json'
export default {
name: 'echarts1',
components: { },
props: {
id: {
type: String,
default () {
return ''
}
}
},
data () {
return {
status: '',
}
},
watch: {},
mounted () {
this.drawechartmap()
},
methods: {
drawechartmap () {
var that = this
var geoCoordMap = {
'上海': [119.1803, 31.2891],
'福建': [119.4543, 25.9222],
'重庆': [108.384366, 30.439702],
'北京': [116.4551, 40.2539],
'辽宁': [123.1238, 42.1216],
'河北': [114.4995, 38.1006],
'天津': [117.4219, 39.4189],
'山西': [112.3352, 37.9413],
'陕西': [109.1162, 34.2004],
'甘肃': [103.5901, 36.3043],
'宁夏': [106.3586, 38.1775],
'青海': [101.4038, 36.8207],
'新疆': [87.9236, 43.5883],
'西藏': [91.11, 29.97],
'四川': [103.9526, 30.7617],
'吉林': [125.8154, 44.2584],
'山东': [117.1582, 36.8701],
'河南': [113.4668, 34.6234],
'江苏': [118.8062, 31.9208],
'安徽': [117.29, 32.0581],
'湖北': [114.3896, 30.6628],
'浙江': [119.5313, 29.8773],
'内蒙古': [110.3467, 41.4899],
'江西': [116.0046, 28.6633],
'湖南': [113.0823, 28.2568],
'贵州': [106.6992, 26.7682],
'云南': [102.9199, 25.4663],
'广东': [113.12244, 23.009505],
'广西': [108.479, 23.1152],
'海南': [110.3893, 19.8516],
'黑龙江': [127.9688, 45.368],
'台湾': [121.4648, 25.5630]
}
var mapDate = []
window.addEventListener('resize', this.drawechartmap)
var myChart = this.$echarts.init(this.$refs.echarts)
this.$echarts.registerMap('china', map)
var data = [
{
name: '北京',
value: 2
}, {
name: '天津',
value: 5
}, {
name: '上海',
value: 1
}, {
name: '重庆',
value: 0
}, {
name: '河北',
value: 0
}, {
name: '河南',
value: 0
}, {
name: '云南',
value: 0
}, {
name: '辽宁',
value: 0
}, {
name: '黑龙江',
value: 0
}, {
name: '湖南',
value: 0
}, {
name: '安徽',
value: 0
}, {
name: '山东',
value: 0
}, {
name: '新疆',
value: 0
}, {
name: '江苏',
value: 0
}, {
name: '浙江',
value: 0
}, {
name: '江西',
value: 0
}, {
name: '湖北',
value: 0
}, {
name: '广西',
value: 0
}, {
name: '甘肃',
value: 0
}, {
name: '山西',
value: 0
}, {
name: '内蒙古',
value: 0
}, {
name: '陕西',
value: 0
}, {
name: '吉林',
value: 5
}, {
name: '福建',
value: 5
}, {
name: '贵州',
value: 15
}, {
name: '广东',
value: 15
}, {
name: '青海',
value: 0
}, {
name: '西藏',
value: 0
}, {
name: '四川',
value: 0
}, {
name: '宁夏',
value: 0
}, {
name: '海南',
value: 0
}]
const tooltipFormatter = function (params) {
console.log(params)
return `<div style="width: 100px;height: 46px;position: relative">
<img src=""
style="width:24px;position: absolute;left: -30px;top: -50px" alt="">
<div style="width: 100px;height: 46px;top: -50px;position: absolute;
background: #0080EE;box-shadow:#0759AA 0 0 10px 2px;border-radius: 10px;">
<div style="font-size: 12px; padding-left:5px;font-family: PingFang;font-weight: 500;color: #FFFFFF;">累计车位数:</div>
<div style="font-size: 16px; padding-left:5px;font-family: DIN;font-weight: bold;color: #FFFFFF;">${params.data.value}</div>
</div>
</div>`
}
var option = {
//地图显示:移动鼠标,显示数据
tooltip: {
trigger: 'item',
show: false,
showDelay: 0,
transitionDuration: 0.2,
borderWidth: 0,
backgroundColor: 'rgba(255,255,255,0)',
padding: 0,
formatter: tooltipFormatter
},
//图例
visualMap: {
min: 19000,
max: 70000,
right: 10,
bottom: 40,
showLabel: !0,
textStyle: {
color: 'rgba(167, 194, 240, 1)'
},
pieces: [{
gt: 10,
lt: 20,
label: '投放运营',
color: 'rgba(255, 187, 5, 1)'
}, {
gt: 0,
lt: 10,
label: '战略部署',
color: 'rgba(0, 228, 102, 1)'
}, {
gt: 0,
lt: 0,
label: '',
color: '#00338F'
}],
show: !0
},
toolbox: {
show: false,
orient: 'vertical',
left: 'right',
top: 'center',
feature: {
dataView: {
readOnly: false
},
restore: {},
saveAsImage: {}
}
},
geo: {
map: 'china',
zoom: 1,
label: {
normal: {
show: false,
color: '#000000'
},
emphasis: {
show: false,
color: '#292929'
}
},
roam: false,
itemStyle: {
normal: {
areaColor: '#00338F'
},
}
},
series: [
{
type: 'map',
mapType: 'china',
map: 'china',
itemStyle: {
normal: {
areaColor: '#00338F',
borderColor: '#0094D6',
borderWidth: 0.5,
label: {
show: false,
}
},
emphasis: {
areaColor: '#FFBB07',
borderColor: '#0094D6',
areaStyle: '#FFBB07',
label: {
show: false,
}
}
},
label: {
normal: {
show: false
},
emphasis: {
show: false
}
},
data: data
},
{
type: 'scatter',
coordinateSystem: 'geo',
// symbol: 'pin',
symbol: function (value, params) {
return 'image://'
},
symbolSize: [24, 35],
symbolOffset: [-0, -0],
hoverAnimation: true,
itemStyle: {
normal: {
color: 'pink' // 标志颜色
}
},
zlevel: 6,
data: []
},
{
type: 'scatter',
coordinateSystem: 'geo',
label: {
normal: {
show: true,
formatter: function (params) {
var name = params.name
var value = params.data.datas
var text = `{fline|累计车位数:}\n{tline|${params.data.number}}`
return text
},
color: '#fff',
rich: {
fline: {
padding: [0, 10, 5, 15],
color: '#fff',
fontSize: 12,
fontWeight: 400,
},
tline: {
padding: [5, 15],
color: '#fff',
fontSize: 16,
fontFamily: 'DIN',
fontWeight: 'bold'
},
},
},
emphasis: {
show: true,
},
},
itemStyle: {
color: '#00FFF6',
},
symbol: function (value, params) {
return 'image://'
},
symbolSize: [118, 64],
symbolOffset: [70, 5],
z: 999,
data: [],
},
]
}
myChart.resize()
myChart.setOption(option)
myChart.on('click', function (params) {
var valarr = geoCoordMap[params.name]
console.log(valarr)
console.log(option.series[1])
option.series[1].data = [{
name: params.name,
value: valarr,
number: 1354,
}]
option.series[2].data = [{
name: params.name,
value: valarr,
number: 1354,
}]
myChart.setOption(option, false)
})
myChart.on('dblclick', function (params) {
console.log('双击')
console.log(params)
that.$refs.pops.getshow()
myChart.setOption(option, false)
})
}
}
}
</script>
<style lang="scss" scoped>
.echarts1 {
position: relative;
width: 100%;
height: calc(100% - 0px);
}
.echarts12 {
position: relative;
width: 100%;
height: calc(100% - 0px);
}
</style>