配置项如下
let imgSrc = '';
var data =
[
{name: "智能碾压", value: 20, type: 0},
{name: "border", value: 1},
{name: "隧道管理", value: 20, type: 0},
{name: "border", value: 1},
{name: "梁场管理", value: 20, type: 0},
{name: "border", value: 1}
];
var colors = ['#00ffff',
'#ffe000','#00a6ff','#ff5b00','#ff3000'];
var dataPie = [];
for (var i = 0; i < data.length; i++) {
if(data[i].type == 0){
dataPie.push({
value: data[i].value,
name: data[i].name,
itemStyle: {
normal: {
borderWidth: 5,
shadowBlur: 20,
borderColor:colors[i/2],
shadowColor: colors[i/2]
}
}
});
}else{
dataPie.push({name: "border", value: 1});
}
}
var dataText = data.map(function (item) {
if(item.type == 0){
return item.name;
}
})
option = {
title: {
text: '快捷入口',
textStyle: {
color: '#cccccc99',
fontSize: 40,
align: 'center'
},
x: 'center',
top: "50%",
},
graphic: {
elements: [{
type: "image",
z: 3,
style: {
image: imgSrc,
width: 90,
height: 90
},
left: 'center',
top: "36%",
position: [100, 100]
}]
},
tooltip: {
trigger: 'item',
formatter: "{a} <br/>{b}: {c} ({d}%)",
},
legend: false,
series: [
{
animation: false,
type:'pie',
radius: ['42%', '51%'],
data:[1],
color: ["rgb(200,200,200, 0.2)"],
itemStyle : {
normal : {
label : {
show : false
},
labelLine : {
show : false
}
},
},
},
{
name:'访问来源',
type:'pie',
radius: ['58%', '80%'],
hoverAnimation: false,
label: {
normal: {
formatter: function(item){
return item.name;
},
padding: [0, -80],
height: 60,
fontSize:30,
rich:{
c: {
lineHeight: 50,
},
}
},
},
data: dataPie,
itemStyle:{
normal:{
color: function(params){
var colorList = colors;
return (params.dataIndex % 2)? 'rgba(0,0,0,0)' : colorList[params.dataIndex/2];
},
labelLine:{
length: 80,
length2: 120,
},
shadowBlur: 40,
shadowColor: "#22ff33"
},
}
},
{
animation: false,
type:'pie',
radius: ['35%', '37%'],
data:data,
itemStyle : {
normal : {
color: function(params){
var colorList = colors;
return (params.dataIndex % 2)? 'rgba(0,0,0,0)' : "rgb(126,190,255, 0.2)";
},
label : {
show : false
},
labelLine : {
show : false
}
},
},
},
{
animation: false,
type:'pie',
radius: ['39%', '41%'],
data:data,
itemStyle : {
normal : {
color: function(params){
var colorList = colors;
return (params.dataIndex % 2)? 'rgba(0,0,0,0)' : "rgba(0,0,0,0.1)";
},
label : {
show : false
},
labelLine : {
show : false
}
},
},
},
{
type: 'pie',
zlevel: 4,
silent: true,
radius: ['86%', '87%'],
label: {
normal: {
show: false
},
},
labelLine: {
normal: {
show: false
}
},
data: _pie3()
}
]
};
function _pie3() {
let dataArr = [];
for (var i = 0; i < 15; i++) {
if (i % 2 === 0) {
dataArr.push({
name: (i + 1).toString(),
value: 25,
itemStyle: {
normal: {
color: "rgb(126,190,255, 0.4)",
borderWidth: 0,
borderColor: "rgba(0,0,0,0)"
}
}
})
} else {
dataArr.push({
name: (i + 1).toString(),
value: 10,
itemStyle: {
normal: {
color: "rgba(0,0,0,0)",
borderWidth: 0,
borderColor: "rgba(0,0,0,0)"
}
}
})
}
}
return dataArr
}
var timer;
function doing() {
let option = myChart.getOption();
option.series[2].startAngle = option.series[2].startAngle + 1;
option.series[4].startAngle = option.series[4].startAngle - 1;
myChart.setOption(option);
}
function startTimer() {
timer = setInterval(doing, 100);
}
setTimeout(startTimer, 500);