let imgSrc = ''; let chartData = [ { value: 520, name: '幼儿园', }, { value: 280, name: '小学', }, { value: 100, name: '初中', }, { value: 100, name: '高中', }, ]; let colorList = ['#115FEA', '#10EBE3', '#10A9EB', '#EB9C10', '#2E10EB', '#9B10EB']; let sum = chartData.reduce((per, cur) => per + cur.value, 0); let gap = 1 * sum / 100; let pieData1 = []; let pieData2 = []; let gapData = { name: '', value: gap, itemStyle: { color: 'transparent', }, }; for (let i = 0; i < chartData.length; i++) { // 第一圈数据 pieData1.push({ ...chartData[i], itemStyle: { borderRadius: 10 } }); pieData1.push(gapData); // 第二圈数据 pieData2.push({ ...chartData[i], itemStyle: { color: colorList[i], opacity: 0.1, }, }); pieData2.push(gapData); } console.log(pieData2); option = { backgroundColor: '#000', tooltip: { show: false, backgroundColor: 'rgba(17,95,234,0.5)', textStyle: { color: '#F0F0F0', }, }, legend: { show: true, right: 'right', top: 'center', icon: 'rect', itemWidth: 4, itemHeight: 20, textStyle: { color: '#F0F0F0', rich: { name: { padding: [0, 10, 0, 8], color: '#fff', fontSize: 16, }, percent: { padding: [0, 0, 0, 8], color: '#fff', }, }, }, formatter: (name) => { console.log(name); console.log(chartData); let item = chartData.find((i) => { return i.name == name; }); let p = ((item.value / sum) * 100).toFixed(0); return '{name|' + name + '}' + '{percent|' + p + '}' + '%'; }, }, graphic: { elements: [{ type: "image", z: 3, style: { image: imgSrc, width: 70, height: 70, }, top: 'middle', left: 'center', scale: [1.5,1.5] }] }, grid: { top: 35, right: 30, bottom: 20, left: 30, }, color: colorList, series: [ { name: '消息来源', type: 'pie', roundCap: true, radius: ['76%', '80%'], center: ['50%', '50%'], label: { show: false, }, labelLine: { show: false, }, data: pieData1, }, { type: 'pie', radius: ['76%', '64%'], center: ['50%', '50%'], gap: 1.71, label: { show: false, }, labelLine: { show: false, }, silent: true, data: pieData2, }, { type: 'pie', center: ['50%', '50%'], radius: [0, '45.6%'], label: { show: false, }, labelLine: { show: false, }, itemStyle: { color: 'rgba(5,37,95,0.3)', }, silent: true, data: [ { value: 100, name: '', }, ], }, ], };