const dataSource = [ {name:'基地5',value:580}, {name:'基地1',value:536}, {name:'基地2',value:500}, {name:'基地3',value:350}, {name:'基地4',value:300}, {name:'基地8',value:280}, {name:'基地6',value:240}, {name:'基地7',value:200}, ]; let barWidth = 10 /* 进度条及进度条radius宽度 */, nameWidth = 60 /* 进度条名称宽度 */, unit = '人' /* 单位 */, attaData = [] /* 进度条数据 */, attaVal = [] /* 进度条数值 */, topName = [] /* 进度条名称 */, salvProMax = []; /* 背景条数据 */ dataSource.forEach((it, i) => { // let itemStyle = { // color: i > 3 ? attackSourcesColor[3] : attackSourcesColor[i], // }; topName[i] = `${it.name}`; attaVal[i] = it.value; attaData[i] = { value: parseFloat(it.value).toFixed(2), // itemStyle: itemStyle, }; }); /* 该值无具体作用,取进度最大值 * 1.2 */ salvProMax = Array(attaVal.length).fill(Math.max(...attaVal) * 1.2); const img3 = ''; const img2 = ''; const img1 = ''; const img4 = '' option = { backgroundColor:'#000', grid: [ { left: 0, top: 40, right: 10, bottom: 40, containLabel: true, }, ], xAxis: [ { gridIndex: 0, type: 'value', axisLabel: { show: false }, axisLine: { show: false }, splitLine: { show: false }, axisTick: { show: false }, }, { gridIndex: 0, type: 'value', max: 100, axisLabel: { show: false }, axisLine: { show: false }, splitLine: { show: false }, axisTick: { show: false }, }, ], yAxis: [ { gridIndex: 0, type: 'category', inverse: true, position: 'left', data: dataSource.map((item) => item.name), axisTick: { show: false }, axisLine: { show: false }, splitLine: { show: false }, axisLabel: { width: 80, padding: [0, 0, 40, -20], align: 'left', formatter: (name, index) => { const id = index + 1; if (id < 4) { return `{icon${id}|}`; } else { return `{count|${id}}`; } }, rich: { icon1: { width: 20, height: 20, align: 'center', borderRadius: 50, backgroundColor: { image: img1, }, }, icon2: { width: 20, height: 20, align: 'center', borderRadius: 50, backgroundColor: { image: img2, }, }, icon3: { width: 20, height: 20, shadowColor: '#3374ba', borderColor: '#3374ba', borderWidth: 1, borderRadius: 50, align: 'center', backgroundColor: { image: img3, }, }, count: { padding: [2, 0, 0, 0], width: 20, height: 18, color: '#fff', align: 'center', fontSize: 12, fontFamily: 'DIN', fontWeight: 500, shadowColor: '#008AFF', borderColor: '#008AFF', borderRadius: 50, borderWidth: 1, backgroundColor: { image: img4, }, }, name: { width: 80, fontSize: 12, align: 'left', color: '#fff', fontFamily: 'Source Han Sans CN', fontWeight: 500, }, }, }, }, { gridIndex: 0, type: 'category', inverse: true, data: dataSource.map((item) => item.name), axisTick: { show: false }, axisLine: { show: false }, splitLine: { show: false }, position: 'left', axisLabel: { width: 80, padding: [0, 0, 40, 40], align: 'left', formatter: (name, index) => { return `{value|${name}}`; }, rich: { value: { color: '#fff', fontSize: 12, fontWeight: 500, }, }, }, }, { gridIndex: 0, type: 'category', position: 'right', inverse: true, margin: 20, data: dataSource.map((item) => item.name), axisTick: { show: false }, axisLine: { show: false }, splitLine: { show: false }, axisLabel: { align: 'right', padding: [0, 0, 50, -40], formatter: (_, index) => { return `{value|${dataSource[index].value}吨}`; }, rich: { value: { color: '#fff', fontSize: 12, fontWeight: 500, }, }, }, }, ], series: [ { z: 1, type: 'bar', xAxisIndex: 0, yAxisIndex: 0, barWidth: 10, data: dataSource.map((item) => item.value), silent: true, itemStyle: { emphasis: { barBorderRadius: [0, 20, 20, 0], }, normal: { // barBorderRadius: [0, 20, 20, 0], barBorderRadius: [30, 30, 30, 30], color: new echarts.graphic.LinearGradient( 0, 0, 1, 0, [ { offset: 0, color: '#01A6EB', // 0% 处的颜色 }, { offset: 1, color: '#005CD8', // 100% 处的颜色 }, ], false ), }, }, }, { z: 3, name: '背景', type: 'bar', barWidth: 10, barGap: '-100%', data: salvProMax, itemStyle: { normal: { color: 'rgba(131, 132, 132, 0.1)', barBorderRadius: [30, 30, 30, 30], borderColor:'#004FBB' }, }, }, ], };