var pic = '' var room = '' var data = [{ name: '干部宿舍楼', total: 120, use: 60, empty: 60, }, { name: '公寓住房', total: 110, use: 40, empty: 70, }] // 计算总数 var total = 0; var seriesOption = [] data.map((item, index) => { total+=item.total seriesOption.push({ name: '柱背景', type: 'bar', xAxisIndex: index, yAxisIndex: index, data: [{ }, { name: item.name, value: item.total, rate: (item.use / item.total).toFixed(2) * 100 + '%', }], barWidth: 16, itemStyle: { normal: { barBorderRadius: 8, color: '#DFEEFF' } }, label: { show: true, position: 'insideRight', formatter: params => { return `{pb|使用率:${params.data.rate}}` }, rich: { pb: { color: '#4B96F3', padding: [0, 0, -30, 0] } } } }) seriesOption.push({ value: item.use, max: item.total, name: item.name, zlevel: 2, type: 'bar', yAxisIndex: index, xAxisIndex: index, data: [{ }, { value: item.use, use:item.use, empty:item.empty, total:item.total }], label:{ show:true, color:'transparent', position:'insideLeft', formatter:params=>{ console.log(params) return `{pb|}\n{imgIcon|} {normalText|房间:${params.data.total}间} \n\n{circleYellow|●} {normalText|使用:${params.data.use}间} \n\n{circleGreen|●} {normalText|空闲:${params.data.empty}间}` }, rich:{ circleYellow:{ color:'#FFA83E', width:16, height:16, fontSize:20, lineHeight:20, padding:[0,0,0,4] }, pb:{ padding:[0,0,200,0] }, circleGreen:{ color:'#36C78B', fontSize:20, width:16, height:16, lineHeight:20, padding:[0,0,0,4] }, imgIcon:{ backgroundColor:{ image:room, }, width:20, height:20, }, normalText:{ fontSize:15, height:20, textVeticalAlign:'middle', color:'#666666' } } }, rate: item.total === 0 ? 0 : (item.use / item.total).toFixed() * 100 + '%', barGap: '-100%', barWidth: 16, itemStyle: { normal: { barBorderRadius: 8, color: '#4B96F3' } } }) }) option = { graphic: { elements: [{ type: 'image', left: 'center', top: 25, style: { image: pic, width: 136, height: 136, textAlign: 'center' } }, { type: 'text', left: 'center', top: 180, style: { text: '房间总数', fill: '#333333', fontSize:16, } }, { type: 'rect', left: 'center', top: 200, textVeticalAlign:'middle', shape:{ width:80, height:36, }, style: { color:'#FFFFFF', fontSize:20, fontWeight:'bold', text:total, fill: '#4B96F3', } }] }, grid: [{ left: '5%', top: '5%', width: '30%', bottom: '5%', containLabel: true, }, { left: '35%', top: '5%', width: '30%', bottom: '5%', containLabel: true, }, { left: '65%', top: '5%', width: '30%', bottom: '5%', containLabel: true, }], yAxis: [{ type: 'category', data: ['', '干部宿舍楼'], gridIndex: 0, axisLabel: { inside: true, padding: [0, 0, 48, 0], color: '#333333', fontWeight: 'bold' }, axisTick: { show: false, }, axisLine: { show: false, } }, { type: 'category', data: ['', '公寓住房'], gridIndex: 2, axisLabel: { inside: true, padding: [0, 0, 48, 0], color: '#333333', fontWeight: 'bold' }, axisTick: { show: false, }, axisLine: { show: false, } }], xAxis: [{ type: 'value', gridIndex: 0, max: data[0].total, show: false, }, { type: 'value', gridIndex: 2, max: data[1].total, show: false, }], series: [...seriesOption] }