配置项如下
let img1 = '';
let img2 = '';
// 数据及颜色设置
let bgColor = '#051234';
let scale = 1;
let echartData = [{
name: 'A类',
value: 30,
unit: '元',
detail: [{name: 'TypeA', value: 22},{name: 'TypeB', value: 8}]
},
{
name: 'B类',
value: 20,
unit: '元',
detail: [{name: 'TypeA', value: 12},{name: 'TypeB', value: 8}]
}, {
name: 'C类',
value: 30,
unit: '元',
detail: [{name: 'TypeA', value: 12},{name: 'TypeB', value: 18}]
}, {
name: 'D类',
value: 20,
unit: '元',
detail: [{name: 'TypeA', value: 3},{name: 'TypeB', value: 17}]
}
];
let total = echartData.reduce((a, b) => {
return a + b.value * 1
}, 0)
option = {
backgroundColor: bgColor,
color: ['#2EB2FA', '#43CC31', '#FFC145', '#FFA8A8'],
title: [{
text: '异常分布情况',
x: 'center',
y: 20,
textStyle: {
fontWeight: 'normal',
fontSize: 24 * scale,
color: "#fff",
}
},{
text: '分类统计',
x: 'center',
y: 'center',
textStyle: {
fontWeight: 'normal',
fontSize: 20 * scale,
color: "#ccc",
}
}],
tooltip: {
show: false
},
legend: {
icon: 'square',
itemWidth: 12 * scale,
itemGap: 25,
top: 20,
right: 30,
textStyle: {
color: '#fff'
},
data: [{
name: 'TypeA',
icon: 'image://'+img1
}, {
name: 'TypeB',
icon: 'image://'+img2
}]
},
series: [{
type: 'pie',
name: 'TypeB', // 内层细圆环2
radius: ['45%', '46%'],
hoverAnimation: false,
clockWise: false,
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0.05,
color: 'rgba(0,117,255, 1)'
}, {
offset: 0.5,
color: 'rgba(0,117,255, 0.1)'
}, {
offset: 1,
color: 'rgba(0,117,255, 1)'
}]),
}
},
label: {
show: false
},
data: [100]
},
{
type: 'pie',
name: 'TypeA', // 外层圆环1(用于遮挡labelLine)
radius: ['56%', '60%'],
hoverAnimation: false,
clockWise: false,
itemStyle: {
normal: {
color: bgColor,
}
},
label: {
show: false
},
data: [100]
},
{
type: 'pie',
name: 'TypeB', // 最外层细圆环
hoverAnimation: false,
clockWise: false,
radius: ['60%', '61%'],
itemStyle: {
normal: {
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0.05,
color: 'rgba(0,117,255, 1)'
}, {
offset: 0.5,
color: 'rgba(0,117,255, 0.1)'
}, {
offset: 1,
color: 'rgba(0,117,255, 1)'
}]),
}
},
label: {
show: false
},
data: [100]
},
{
name: '饼图内容区',
type: 'pie',
clockWise: false,
radius: ['50%', '56%'],
hoverAnimation: false,
data: echartData,
label: {
normal: {
formatter: function(params, ticket, callback) {
return '{normal|' + params.name + '}\n{A|}{value|' + params.data.detail[0].value + '个}\n{B|}{value|' + params.data.detail[1].value + '个}';
},
padding: [0, -80],
rich: {
normal: {
color: '#fff',
fontSize: 14 * scale,
padding: [20, 4],
align: 'left'
},
value: {
color: '#fff',
align: 'left',
fontSize: 14 * scale,
padding: [2, 4],
},
A: {
width: 14,
height: 14,
align: 'left',
backgroundColor: {
image: img1
}
},
B: {
width: 14,
height: 14,
align: 'left',
backgroundColor: {
image: img2
}
}
}
}
},
labelLine: {
length: 30,
length2: 100
}
}
]
};