let colorList = ['#FF4B01', '#FF7B00', '#FFE823', '#2379FF', '#2379FF', '#2379FF'] let colorListA = ['#FC7A24', '#FFC000', '#FFEA97', '#49B1FF', '#49B1FF', '#49B1FF'] const data = { label: ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L'], value: [11, 22, 33, 44, 55, 66, 77, 88, 99, 21, 32, 43] } let dataZoomMove = { start: 0, end: 5 } let dataZoomMoveTimer = null option = { backgroundColor: "#000", tooltip: { trigger: "axis", backgroundColor: "rgba(21, 154, 255, 0.32)", textStyle: { color: "#fff", }, borderColor: "#159AFF", axisPointer: { lineStyle: { color: "transparent", }, }, }, dataZoom: [ { show: false, // 为true 滚动条出现 startValue: dataZoomMove.start, endValue: dataZoomMove.end, yAxisIndex: [0, 1], //关联多个y轴 }, { //没有下面这块的话,只能拖动滚动条,鼠标滚轮在区域内不能控制外部滚动条 type: "inside", yAxisIndex: 0, zoomOnMouseWheel: false, //滚轮是否触发缩放 moveOnMouseMove: true, //鼠标滚轮触发滚动 moveOnMouseWheel: true, }, ], grid: { containLabel: true, bottom: 20, left: 30, top: 20, right: 30, }, xAxis: { type: "value", axisLabel: { show: false, }, axisLine: { show: false, }, axisTick: { show: false, }, splitLine: { show: false, }, }, yAxis: [ { type: "category", data: data.label, inverse: true, axisLabel: { inside: true, verticalAlign: "bottom", lineHeight: 36, margin: 2, //刻度标签与轴线之间的距离 formatter: function (value) { let k = data.label.indexOf(value); // let index = k < 9 ? "0" + (k + 1) : k + 1; let index = k < 9 ? (k + 1) : k + 1; return `{b|TOP${index}} {a|${value}}`; }, rich: { b: { // borderColor: "#fff", // borderWidth: 1, padding: [3, 1, 0, 1], color: "#fff", fontSize: 14, }, a: { fontSize: 14, color: "#D0DEEE", padding: [4, 0, 0, 8], }, }, }, axisLine: { show: false, }, axisTick: { show: false, }, splitLine: { show: false, }, }, { type: "category", data: data.label, inverse: true, axisLabel: { inside: true,// 数值和图表分离 verticalAlign: "bottom", lineHeight: 34, margin: 2, formatter: function (value) { let k = data.label.indexOf(value); let index = k; return `{a|${data.value[index]}次}`; }, rich: { a: { fontSize: 16, color: "#fff", padding: [4, 0, 0, 0], fontFamily: "DOUYU", }, }, }, axisLine: { show: false, }, axisTick: { show: false, }, splitLine: { show: false, }, }, ], series: [ { data: data.value, type: "bar", barWidth: 10, // 柱子宽度 MaxSize: 0, showBackground: true, barBorderRadius: [30, 0, 0, 30], backgroundStyle: { color: 'rgba(9, 68, 131, .2)', }, label: { show: false, offset: [60, -17], color: '#fff', fontWeight: 500, position: 'left', align: 'left', fontSize: 14, formatter: function (params) { console.log(params) return params.data.name; } }, itemStyle: { barBorderRadius: [3, 0, 0, 3], color: params => { let i = colorListA.length; let f = colorList.length; return { type: "linear", x: 0, y: 0, x2: 1, y2: 1, colorStops: [ { offset: 0, color: colorListA[params.dataIndex % i] }, { offset: 1, color: colorList[params.dataIndex % f] }, ], } } } }, { name: "外圆", type: "scatter", emphasis: { scale: false, }, tooltip: { show: false }, // 小圆圈 // symbol: // "image://", // symbolSize: [20, 20], symbol: "rect", symbolSize: [5, 16],// 进度条白点 itemStyle: { barBorderRadius: [30, 0, 0, 30], color: '#FFF', shadowColor: "rgba(255, 255, 255, 0.5)", shadowBlur: 5, borderWidth: 1, opacity: 1, }, z: 2, data: data.value, animationDelay: 500, }, ], }; const startMoveDataZoom = () => { dataZoomMoveTimer = setInterval(() => { dataZoomMove.start += 1; dataZoomMove.end += 1; if (dataZoomMove.end > data.value.length - 1) { dataZoomMove.start = 0; dataZoomMove.end = 5; } myChart.setOption({ dataZoom: [ { type: "slider", // 有type这个属性,滚动条在最下面,也可以不行,写y:36,这表示距离顶端36px,一般就是在图上面。 startValue: dataZoomMove.start, endValue: dataZoomMove.end, }, ], }); }, 2500); }; startMoveDataZoom() let chartDom = myChart.getDom(); chartDom.addEventListener('mouseout', () => { if (dataZoomMoveTimer) return; let dataZoomMove_get = myChart.getOption().dataZoom[0]; dataZoomMove.start = dataZoomMove_get.startValue; dataZoomMove.end = dataZoomMove_get.endValue; startMoveDataZoom(); }) chartDom.addEventListener('mouseover', () => { clearInterval(dataZoomMoveTimer); dataZoomMoveTimer = undefined; })