// 修改自https://www.isqqw.com/add?from=35428 const dataSource = [ { value: '8', name: '千金', }, { value: '1', name: '南浔', }, { value: '2', name: '双林', }, { value: '3', name: '和孚', }, { value: '3', name: '善琏', }, { value: '1', name: '开发区', }, { value: '6', name: '石淙', }, { value: '3', name: '练市', }, { value: '5', name: '菱湖', }, ]; const img3 = ''; const img2 = ''; const img1 = ''; option = { backgroundColor: 'rgba(5, 62, 72, 1)', grid: [ { left: 10, top: 10, right: 10, bottom: 10, 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, 0, -80], align: 'left', formatter: (name, index) => { const id = index + 1; if (id < 4) { return `{icon${id}|}`; } else { return `{count|${id}}`; } }, rich: { icon1: { width: 35, height: 15, align: 'center', backgroundColor: { image: img1, }, }, icon2: { width: 35, height: 15, align: 'center', backgroundColor: { image: img2, }, }, icon3: { width: 35, height: 15, align: 'center', backgroundColor: { image: img3, }, }, count: { padding: [0, 0, 0, 0], width: 35, height: 15, color: '#A4E8E8', align: 'center', fontSize: 15, fontFamily: 'DIN', fontWeight: 500, fontStyle: 'italic', }, name: { width: 80, fontSize: 15, 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, 0], align: 'left', formatter: (name, index) => { return `{value|${name}}`; }, rich: { value: { color: '#fff', fontSize: 14, 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}.0%}`; }, rich: { value: { color: '#fff', fontSize: 14, fontWeight: 500, }, }, }, }, ], series: [ { 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], color: new echarts.graphic.LinearGradient( 0, 0, 1, 0, [ { offset: 0, color: 'rgba(0, 255, 150, 0)', // 0% 处的颜色 }, { offset: 1, color: 'rgba(0, 255, 150, 1)', // 100% 处的颜色 }, ], false ), }, }, }, { type: 'pictorialBar', data: dataSource.map((item) => item.value), xAxisIndex: 0, yAxisIndex: 0, symbol: 'circle', symbolRotate: null, symbolSize: [10, 10], symbolPosition: 'end', symbolOffset: [0, 0], itemStyle: { color: 'white', shadowColor: 'rgba(115, 243, 255, 0.2)', shadowBlur: 10, }, }, { name: '背景', type: 'bar', barWidth: 10, barGap: '-100%', data: [10, 10, 10, 10, 10, 10, 10, 10, 10], itemStyle: { normal: { color: 'rgba(131, 132, 132, 0.1)', barBorderRadius: [30, 30, 30, 30], }, }, }, ], };