<script setup> const base64Img="image://" const state=reactive({ lineColor:$c.gyl3, fontColor:$c.bk, chartData:{ yAxis:['TaskA', 'TaskB', 'TaskC', 'Task Long Name', 'TaskE', 'TaskF', 'TaskG', 'TaskH', 'TaskI'], color:[$c.aql4,$c.orl5,$c.rel5], data:[69, 96, 35,26, 96, 32 ,52 ,22 ,72] }, chartOption:{} }) const {lineColor,fontColor}=toRefs(state) const fillArr=computed(()=>{ return (new Array(state.chartData.data.length)).fill(100); }) const getSymbolData=(data)=>{ let arr = []; for (var i = 0; i < data.length; i++) { arr.push({ value: data[i], symbolPosition: 'end' }) } return arr; } const processData=()=>{ let legend=state.chartData.legend, colors=state.chartData.colors, yAxis=state.chartData.yAxis, data=state.chartData.data, processedData=[]; state.chartOption.yAxis.data=state.chartData.yAxis; state.chartOption.series[0].data=state.chartData.data; state.chartOption.series[1].data=fillArr; state.chartOption.series[2].data=getSymbolData(state.chartData.data); dataScroll(); } const processOption=()=>{ state.chartOption={ update:false, title: { show:false, // text: '实时流速图2', textStyle:{ color:$c.cbl5, fontSize:16, fontWeight:"normal" }, }, grid: { top: '15%', left: '18%', right: '12%', bottom: '5%' }, tooltip: {show: false}, xAxis: { type: 'value', min: 0, max: 100, axisLine: {show: false}, splitLine: {show: false}, axisLabel: {show: false}, axisTick: {show: false} }, dataZoom: { yAxisIndex: 0, show: false, type: "slider", startValue: 0, endValue: 5, }, yAxis: { //show: false, type: 'category', inverse: true, splitLine: {show: false,}, axisLine: {show: false}, axisLabel: { show: true, interval: 0, margin: 10, color:fontColor, fontSize: 12, width:50, lineHeight:14, overflow:"break", fontWeight: 'normal', }, axisTick: {show: false}, data:[] }, series: [ { type: 'bar', barWidth: '40%', animationDuration:2000, itemStyle: { borderWidth:0, borderRadius:10, color: { type: 'linear', x: 0, y: 0, x2: 1, y2: 0, colorStops: [{ offset: 0, color: $c.cyl4, }, { offset: 1, color: $c.cyl6, }] } }, label: { show: false, }, data: [], z: 0 }, { type: 'bar', barWidth: '40%', barGap: '-100%', animation: false, itemStyle: { borderWidth: 0, borderRadius:5, color: 'rgba(0,202,255,0.2)' }, label: { color:fontColor, show: true, position: ['101%', '20%'], fontSize: 14, fontWeight: 'normal', formatter: (params)=>{ return ' ' + (state.chartData.data[params.dataIndex] ) + '%'; } }, data: [], z: 0 }, { type: 'pictorialBar', animation: true, // animationThreshold: 3000 , animationDuration: 3000 , // animationDurationUpdate:500, symbol: base64Img, symbolSize: [50, 50], symbolOffset: [20, 0], z: 12, itemStyle: { color: '#fff' }, data: [] }, ] } processData(); } const { proxy } = getCtx(); const dataScroll=()=>{ proxy.$timer("dataScrollBarHorizD",()=>{ let {data}=state.chartData let {dataZoom}=state.chartOption if (dataZoom.endValue == data.length ) { dataZoom.endValue = 5; dataZoom.startValue = 0; }else{ dataZoom.endValue ++; dataZoom.startValue ++; } state.chartOption.update=true dataScroll() },5000) } onMounted(() => { processOption(); }) onBeforeMount(() => { proxy.$timer("dataScrollBarHorizD") }) </script> <template> <echartsInit :chartOption="state.chartOption"></echartsInit> </template> <style lang="less"> </style>