let color = ['#FF8700', '#ffc300', '#00e473', '#009DFF']; let nameList = [2016, 2017, 2018, 2019, 2020]; let valueList = [51.77, 62.33, 66.28, 73.43, 79.15]; let colorList = [ { type: 'linear', // 两端添加透明度,模拟两端线收缩 colorStops: [ { offset: 0, color: '#008AFF', // 0% 处的颜色 }, { offset: 1, color: '#21F7FF', }, ], }, { type: 'linear', // 两端添加透明度,模拟两端线收缩 colorStops: [ { offset: 0, color: '#06CA70', // 0% 处的颜色 }, { offset: 1, color: '#43F2B6', }, ], }, { type: 'linear', // 两端添加透明度,模拟两端线收缩 colorStops: [ { offset: 0, color: '#867DFF', // 0% 处的颜色 }, { offset: 1, color: '#A59EFF', }, ], }, { type: 'linear', // 两端添加透明度,模拟两端线收缩 colorStops: [ { offset: 0, color: '#4186FF', // 0% 处的颜色 }, { offset: 1, color: '#7BB2FF', }, ], }, { type: 'linear', // 两端添加透明度,模拟两端线收缩 colorStops: [ { offset: 0, color: '#FFA531', // 0% 处的颜色 }, { offset: 1, color: '#FFC949', }, ], }, ]; // let chartData = [{ // name: "2020年", // value: 13211, // }, // { // name: "2019年", // value: 42111, // }, // { // name: "2018年", // value: 81711, // }, // { // name: "2017年", // value: 121711, // }, // { // name: "2016年", // value: 121711, // } // ]; let chartData = []; nameList.map((item, idx) => { chartData.push({ name: item + '年', value: valueList[idx], }); }); let arrName = []; let arrValue = []; let sum = 0; let pieSeries = [], lineYAxis = []; // 数据处理 chartData.forEach((v, i) => { arrName.push(v.name); arrValue.push(v.value); sum = sum + v.value; }); function getRadius(i) { return [67 - i * 12 + '%', 59 - i * 12 + '%']; } // 图表option整理 chartData.forEach((v, i) => { pieSeries.push({ name: '生均占地面积(平方米)', type: 'pie', clockWise: true, hoverAnimation: false, radius: getRadius(i), center: ['50%', '50%'], itemStyle: { color: colorList[i], }, label: { show: false, }, data: [ { value: v.value, name: v.name, }, { value: sum - v.value, name: 'no', itemStyle: { color: 'rgba(0,0,0,0)', }, }, ], }); // pieSeries.push({ // name: '', // type: 'pie', // silent: true, // z: 1, // clockWise: true, //顺时加载 // hoverAnimation: false, //鼠标移入变大 // radius: getRadius(i), // center: ["50%", "50%"], // label: { // show: false // }, // data: [{ // value: 7.5, // itemStyle: { // color: "#E3F0FF" // } // }, { // value: 2.5, // name: '', // itemStyle: { // color: "rgba(0,0,0,0)" // } // }] // }); v.percent = ((v.value / sum) * 100).toFixed(2); lineYAxis.push({ value: i, textStyle: { rich: { circle: { color: color[i], padding: [0, 5], }, }, }, }); }); console.log('pieSeries', pieSeries); option = { tooltip: { backgroundColor: 'transparent', borderWidth: 0, trigger: 'item', formatter: (item) => { console.log(item); if (item['name'] == 'no') { return; } else { return `<div style='width:289px;height:107px;background:url("") no-repeat center center'> <div style='color:#CAEEFF;font-size:14px;padding-left:25px;padding-top:30px'>${item.marker}${item.name}</div> <div style='color:#31C2FF;font-size:16px;padding-left:25px;'>${item.seriesName}:${item.value}</div> </div>`; } }, extraCssText:'box-shadow: none;' }, color: color, grid: { top: '15%', bottom: '54%', left: '50%', containLabel: false, }, yAxis: [ { type: 'category', inverse: true, axisLine: { show: false, }, axisTick: { show: false, }, axisLabel: { formatter: function (params) { let item = chartData[params]; console.log(item); return '{name|' + item.name + '-}{percent|' + item.value + '}'; }, interval: 0, inside: false, textStyle: { color: '#333', fontSize: 14, rich: { name: { color: 'rgba(202, 238, 255, 1)', fontSize: 14, }, bd: { color: '#ccc', padding: [0, 5], fontSize: 14, }, percent: { color: 'rgba(202, 238, 255, 1)', fontSize: 14, }, value: { color: '#333', fontSize: 16, fontWeight: 500, padding: [0, 0, 0, 20], }, }, }, show: true, }, data: lineYAxis, }, ], xAxis: [ { show: false, }, ], series: pieSeries, };