水平进度条

描述:当前是关于Echarts图表中的 柱状图 示例。
 
            
let icon1 = '';
let icon2 = '';
let colorList = ['#eaa257', '#11d8ff', '#11d8ff','#11d8ff', '#11d8ff', '#11d8ff']
let result = [
	{name:'路段1',value:580},
	{name:'路段2',value:536},
	{name:'路段3',value:500},
	{name:'路段4',value:350},
	{name:'路段5',value:300}
]

option = {
	color:colorList,
	backgroundColor: '#000416',
	tooltip: {
		show: true,
		trigger: 'item',
		padding: [8, 15],
		backgroundColor: 'rgba(23, 51, 67,1)',
		textStyle: {
			color: 'rgba(255, 255, 255, 1)'
		},
	},
	legend: {
		show: false,
	},
	grid: {
		left: '100',
		right: '50',
		top: '50',
		bottom: '50',
	},
	xAxis: [
		{
			splitLine: {
				show: false,
			},
			type: 'value',
			show: false,
		},
	],
	yAxis: [
		{
			splitLine: {
				show: false,
			},
			axisLine: {
				show: false,
			},
			type: 'category',
			axisTick: {
				show: false,
			},
			inverse: true,
			data: result.map((item)=>item.name),
			axisLabel: {
				color: '#fff',
				fontSize: 14,
				margin: 10,
				formatter: (name, index) => {
                    const id = index + 1;
                    if (id === 1) {
                        return `{icon1|${id}}`;
                     } else {
                        return `{icon2|${id}}`;
                     }
                },
				rich: {
					icon1: {
						width: 54,
						height: 54,
						padding: [5, 0, 2, 0],
						align: 'center',
						backgroundColor: {
							image: icon1
						},
						color: '#ffffff',
						fontSize: 20,
					},
					icon2: {
						width: 54,
						height: 54,
						padding: [5, 0, 2, 0],
						align: 'center',
						backgroundColor: {
							image: icon2
						},
						color: '#ffffff',
						fontSize: 20,
					}
				},
			},
		},
		{
			type: 'category',
			inverse: true,
			axisTick: 'none',
			axisLine: 'none',
			show: true,
			axisLabel: {
				verticalAlign:'bottom',
				align:'right',
				margin: 0,
				padding: [0,0,15,0],
				textStyle: {
					color: '#fff',
					fontSize: 12,
				},
				formatter: function (value) {
					return value;
				},
			},
			data: result.map((item)=>item.value),
		},
	],
	series: [
		{
			name: '',
			type: 'bar',
			barWidth: 20, // 柱子宽度
			MaxSize: 0,
			showBackground: true,
			barBorderRadius: [30, 0, 0, 30],
			backgroundStyle: {
				color:'rgb(33,66,88)',
			},
			 label: {
				show: true,
				offset: [7, -20],
				color: '#fff',
				fontWeight: 500,
				position: 'left',
				align: 'left',
				formatter: function (params) {
					return params.data.name;
				}
			},
			data: result.map((item,index)=>{
				return{
					name:item.name,
					value:item.value,
					itemStyle:{
						barBorderRadius: [30, 0, 0, 30],
						color:{
							type: "linear",
							x: 0,
							y: 0,
							x2: 1,
							y2: 1,
							colorStops: [
								{
									offset: 0,
									color: "#00000000",
								},
								{
									offset: 1,
									color: colorList[index],
								},
							],
               			}
					}
				}
			}),
		},
		{
			name: "外圆",
			type: "scatter",
			emphasis: {
				scale: false,
			},
			symbol: "rect",
			symbolSize: [15,32],// 进度条白点
			itemStyle: {
				barBorderRadius: [30, 0, 0, 30],
				color: '#FFF',
				shadowColor: "rgba(255, 255, 255, 0.5)",
				shadowBlur: 5,
				borderWidth: 1,
				opacity: 1,
			},
			z: 2,
			data: result,
			animationDelay: 500,
		},
	],
};