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);