使用富文本配置legend
配置项如下
const title = '总量'
const color = ['#5E944A', '#C2A349', '#54B4DC', '#1D48BB', '#1C89FA']
const formatNumber = function (num) {
const reg = /(?=(\B)(\d{3})+$)/g
return num.toString().replace(reg, ',')
}
const chartIcon = [
'',
'',
'',
'',
''
]
const echartData = [{
name: '无通行证闯禁',
value: '256'
},
{
name: '不按规定路线行驶',
value: '212'
},
{
name: '不按规定时间行驶',
value: '231'
},
{
name: '高速右转',
value: '222'
},
{
name: '疲劳驾驶',
value: '244'
}
]
const total = function () {
let num = 0
echartData.forEach(item => {
num =num + (+item.value)
})
return num
}
option = {
color: color,
tooltip: {
trigger: 'item'
},
title: [{
text: '{val|' + formatNumber(total()) + '}\n{name|' + title + '}',
top: '40%',
left: '40%',
textAlign: 'center',
textStyle: {
rich: {
val: {
fontSize: 24,
color: '#3196FA',
fontWeight: 'bold'
},
name: {
fontSize: 14,
color: '#8F9CB2',
padding: [10, 0]
}
}
}
}],
legend: {
orient: 'vertical',
icon: 'none',
x: '65%',
y: 'center',
itemWidth: 12,
itemHeight: 12,
itemGap: 20,
width: '263',
align: 'left',
formatter: function (name) {
let str = ''
let res = echartData.filter(v => v.name === name)
res = res[0] || {}
switch (name) {
case '无通行证闯禁':
str = '{a|}{name|' + name + ' }{value|' + res.value + '}{unit|次}'
break;
case '不按规定路线行驶':
str = '{b|}{name|' + name + ' }{value|' + res.value + '}{unit|次}'
break;
case '不按规定时间行驶':
str = '{c|}{name|' + name + ' }{value|' + res.value + '}{unit|次}'
break;
case '高速右转':
str = '{d|}{name|' + name + ' }{value|' + res.value + '}{unit|次}'
break;
case '疲劳驾驶':
str = '{e|}{name|' + name + ' }{value|' + res.value + '}{unit|次}'
break;
}
return str
},
textStyle: {
color: '#A6A6A6',
rich: {
a: {
width: 20,
height: 20,
lineHeight: 20,
backgroundColor: {
image: chartIcon[0]
},
align: 'left'
},
b: {
width: 20,
height: 20,
lineHeight: 20,
backgroundColor: {
image: chartIcon[1]
},
align: 'left'
},
c: {
width: 20,
height: 20,
lineHeight: 20,
backgroundColor: {
image: chartIcon[2]
},
align: 'left'
},
d: {
width: 20,
height: 20,
lineHeight: 20,
backgroundColor: {
image: chartIcon[3]
},
align: 'left'
},
e: {
width: 20,
height: 20,
lineHeight: 20,
backgroundColor: {
image: chartIcon[4]
},
align: 'left'
},
name: {
fontSize: 12,
padding: [0, 0, 0, 5],
width: 100
},
value: {
fontSize: 20,
color: '#3196FA',
padding: [0, 5, 0, 50]
},
unit: {
fontSize: 20
}
}
}
// formatter: function (name) {
// let res = echartData.filter(v => v.name === name)
// res = res[0] || {}
// const unit = res.unit || ''
// return '{name|' + name + '}{value|' + res.value + '}{unit|次}'
// }
// data: legendName
},
series: [{
type: 'pie',
radius: ['45%', '60%'],
center: ['40%', '50%'],
data: echartData,
hoverAnimation: false,
itemStyle: {
normal: {
borderColor: '#fff',
borderWidth: 0
}
},
labelLine: {
show: false
},
label: {
show: false
}
}]
};