var scaleData = [{ 'name': '办公类', 'value': 20, 'top': '40%' }, { 'name': '照明类', 'value': 10, 'top': '44%' }, { 'name': '空调类', 'value': 10, 'top': '48%' }, { 'name': '其他', 'value': 10, 'top': '52%' }, { 'name': '电梯类', 'value': 10, 'top': '56%' }, ].reverse(); var rich = { white: { color: '#ddd', align: 'center', } }; var placeHolderStyle = { normal: { label: { show: false }, labelLine: { show: false }, color: 'rgba(0, 0, 0, 0)', } }; var img = ''; var data = []; var timerId; let angle = 0; var color = ['rgba(22, 172, 142, 1)', 'rgba(0, 251, 183, 1)', 'rgba(248, 136, 42, 1)', 'rgba(20, 218, 255, 1)', 'rgba(6, 232, 219, 1)'].reverse(); for (var i = 0; i < scaleData.length; i++) { data.push({ data: scaleData[i].value, value: scaleData[i].value, name: scaleData[i].name, itemStyle: { normal: { color: color[i], } } }, { value: 2, name: '', itemStyle: placeHolderStyle }); } var seriesObj = [{ name: '', type: 'pie', clockWise: true, radius: [100, 150], center: ['30%', '50%'], hoverAnimation: true, itemStyle: { normal: { label: { show: false, }, labelLine: { show: false, } } }, data: data }, // 紫色 { name: 'ring5', type: 'custom', coordinateSystem: 'none', renderItem: function (params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 3.3, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 5.6, startAngle: ((0 + angle) * Math.PI) / 180, endAngle: ((90 + angle) * Math.PI) / 180, }, style: { stroke: '#00FEFF', fill: 'transparent', lineWidth: 1.5, }, silent: true, }; }, data: [0], }, { name: 'ring5', //紫点 type: 'custom', coordinateSystem: 'none', renderItem: function (params, api) { let x0 = api.getWidth() / 3.3; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 5.6; let point = getCirlPoint(x0, y0, r, 90 + angle); return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4, }, style: { stroke: '#00FEFF', //绿 fill: '#00FEFF', }, silent: true, }; }, data: [0], }, // 蓝色 { name: 'ring5', type: 'custom', coordinateSystem: 'none', renderItem: function (params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 3.3, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 5.6, startAngle: ((180 + angle) * Math.PI) / 180, endAngle: ((270 + angle) * Math.PI) / 180, }, style: { stroke: '#00FEFF', fill: 'transparent', lineWidth: 1.5, }, silent: true, }; }, data: [0], }, { name: 'ring5', // 蓝色 type: 'custom', coordinateSystem: 'none', renderItem: function (params, api) { let x0 = api.getWidth() / 3.3; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 5.6; let point = getCirlPoint(x0, y0, r, 180 + angle); return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4, }, style: { stroke: '#00FEFF', //绿 fill: '#00FEFF', }, silent: true, }; }, data: [0], }, { name: 'ring5', type: 'custom', coordinateSystem: 'none', renderItem: function (params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 3.3, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 6, startAngle: ((270 + -angle) * Math.PI) / 180, endAngle: ((40 + -angle) * Math.PI) / 180, }, style: { stroke: '#00FEFF', fill: 'transparent', lineWidth: 1.5, }, silent: true, }; }, data: [0], }, // 橘色 { name: 'ring5', type: 'custom', coordinateSystem: 'none', renderItem: function (params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 3.3, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 6, startAngle: ((90 + -angle) * Math.PI) / 180, endAngle: ((220 + -angle) * Math.PI) / 180, }, style: { stroke: '#00FEFF', fill: 'transparent', lineWidth: 1.5, }, silent: true, }; }, data: [0], }, { name: 'ring5', type: 'custom', coordinateSystem: 'none', renderItem: function (params, api) { let x0 = api.getWidth() / 3.3; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 6; let point = getCirlPoint(x0, y0, r, 90 + -angle); return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4, }, style: { stroke: '#00FEFF', //粉 fill: '#00FEFF', }, silent: true, }; }, data: [0], }, { name: 'ring5', //绿点 type: 'custom', coordinateSystem: 'none', renderItem: function (params, api) { let x0 = api.getWidth() / 3.3; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 6; let point = getCirlPoint(x0, y0, r, 270 + -angle); return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4, }, style: { stroke: '#00FEFF', //绿 fill: '#00FEFF', }, silent: true, }; }, data: [0], }, ]; const legendData = []; scaleData.forEach((item, i) => { legendData.push({ orient: 'vertical', top: item.top, right: '30%', padding: [10, 20], icon: 'circle', backgroundColor: 'rgba(0,102,255,0.1)', itemStyle: {}, borderColor: '#0066FF', data: [{name: item.name}], textStyle: { color: '#77899c', rich: { uname: { width: 100 }, unum: { color: '#4ed139', width: 40, align: 'right' } } }, formatter(name) { return `{uname|${name}}{unum|1132}` } }); }); option = { tooltip: { show: false }, legend: legendData, toolbox: { show: false }, graphic: { elements: [ { type: 'image', z: 3, style: { image: img, width: 178, height: 178, }, left: '23%', top: 'center', position: [100, 100], }, ], }, series: seriesObj } //获取圆上面某点的坐标(x0,y0表示坐标,r半径,angle角度) function getCirlPoint(x0, y0, r, angle) { let x1 = x0 + r * Math.cos((angle * Math.PI) / 180); let y1 = y0 + r * Math.sin((angle * Math.PI) / 180); return { x: x1, y: y1, }; } function draw() { angle = angle + 3; myChart.setOption(option, true); //window.requestAnimationFrame(draw); } if (timerId) { clearInterval(timerId); } timerId = setInterval(function () { //用setInterval做动画感觉有问题 draw(); }, 100);