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 } }] };