var imgurl = 'image://'; var mainData = []; mainData.push({ name: '充值收入', value: 342305, prevalue: 382305, hismax: 455898, per: '25%' }); mainData.push({ name: '包月收入', value: 1332042, prevalue: 1552305, hismax: 1896900, per: '25%' }); mainData.push({ name: '道具消费', value: 305652, prevalue: 323305, hismax: 446783, per: '25%' }); mainData.push({ name: '新增用户', value: 31861, prevalue: 30805, hismax: 77598, per: '25%' }); mainData.push({ name: '活跃用户', value: 114553, prevalue: 120105, hismax: 145898, per: '25%' }); function createSeries(mainData) { var result = []; var insideLabel = { normal: { position: 'center', formatter: function(params) { if (params.name == "other") return ""; var str = ''; for (var i = 0; i < params.name.length; i++) { console.log(params.name[i]) str += params.name[i]; if ((i + 1) % 2 == 0) { str += '\n'; } } return str; }, textStyle: { fontStyle: 'normal', fontWeight: 'normal', fontSize: 12, color: '#666' } } }; var outsideLabel = { normal: { show: false } }; var itemOthers = { normal: { color: '#eee' } }; for (var i = 0; i < mainData.length; i++) { var increase = mainData[i].value > mainData[i].prevalue; result.push({ type: 'pie', center: [i * 20 + 10 + '%', 30 + (i - 2) * (i - 2) * 5 + '%'], radius: ['20%', '22%'], label: insideLabel, angleAxis: { clockwise: true }, data: [{ name: mainData[i].name, value: mainData[i].value, // prevalue: mainData[i].prevalue },{ name: 'other', value: mainData[i].hismax - mainData[i].value, itemStyle: itemOthers }], markPoint: { data: [{ symbol: '', symbolSize: 15, // symbolRotate: increase ? 0 : 180, itemStyle: { normal: { color: 'transparent' } }, // name: mainData[i].name, value: mainData[i].per, x: i * 20 + 9 + '%', y: 14 + (i - 2) * (i - 2) * 5 + '%', label: { normal: { show: true, position: 'cener', formatter: function(params) { return params.value; }, textStyle: { color: '#333' } } }, }] } }); } var youxiji = { name: 'hill', type: 'pictorialBar', symbolSize: ['20%', '25%'], barCategoryGap: '-50%', symbolOffset: [0, '-50%'], symbol: imgurl, label: { normal: { show: true, position: 'top', color: '#333' } }, data: ['1'], z: 10, itemStyle: { normal: { opacity: 0.8, //每根柱子颜色设置 color: function(params) { let colorList = [ "#1cd389", "#668eff", "#ffc751", "#5bd1ff", "#ff6e72", "#16c1af", "#9692ff", "#eeeeee", ]; return colorList[params.dataIndex]; } }, emphasis: { opacity: 1 } }, } result.push(youxiji) return result; } var option = { backgroundColor: '#fff', xAxis: { data: ['a'], axisTick: { show: false }, axisLine: { show: false }, axisLabel: { show: false } }, yAxis: { splitLine: { show: false }, axisTick: { // 刻度线 show: false }, axisLine: { // 轴线 show: false }, axisLabel: { // 轴坐标文字 show: false } }, series: createSeries(mainData) }