配置项如下
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,
};