let xdata = [], datas = []; //阀值定义 let max = 120,min = 60; for (var i = 0; i < 10; i++) { if (xdata[0]) { xdata.push(getOneMonthAgoDate(new Date(xdata[i - 1]))); } else xdata.push(dateFormat(new Date(), 'YYYY-MM-DD')); datas[i] = { value:Math.round(Math.random() * 150 + 10), itemStyle: { borderWidth: 2, borderColor: "rgba(24, 70, 145, 0.66)" } }; } function getOneMonthAgoDate(date) { var time = date.getTime() - 1000 * 60 * 60 * 24 * 30; var lastDate = new Date(time); return dateFormat(lastDate, 'YYYY-MM-DD'); //getFormatDate(lastDate) + " 00:00:00"; } function dateFormat(date, fmt) { let ret; const opt = { 'Y+': date.getFullYear().toString(), // 年 'M+': (date.getMonth() + 1).toString(), // 月 'D+': date.getDate().toString(), // 日 'h+': date.getHours().toString(), // 时 'm+': date.getMinutes().toString(), // 分 's+': date.getSeconds().toString(), // 秒 // 有其他格式化字符需求可以继续添加,必须转化成字符串 }; for (let k in opt) { ret = new RegExp('(' + k + ')').exec(fmt); if (ret) { fmt = fmt.replace(ret[1], ret[1].length == 1 ? opt[k] : opt[k].padStart(ret[1].length, '0')); } } return fmt; } getSymbolData = (data) => { let arr = []; for (var i = 0; i < data.length; i++) { arr.push({ value: data[i], symbolPosition: 'end', }); } return arr; }; option = { backgroundColor: '#060f20', grid: { top: '15%', right: '3%', left: '8%', bottom: '16%', }, xAxis: [ { type: 'category', color: '#cef7fd', data: xdata, axisPointer: { type: 'line', }, axisTick: { show: false, }, axisLine: { lineStyle: { color: '#eaeae8', }, }, axisLabel: { margin: 20, color: '#cef6fe', textStyle: { color: '#cbf7ff', fontSize: 14, fontWeight: 200, }, }, inverse: true, }, ], yAxis: [ { type: 'value', color: '#cef7fd', axisLine: { lineStyle: { color: '#eaeae8', }, }, axisTick: { show: false, }, axisLabel: { formatter: function (value) { var texts = []; if (value == 30) { texts.push('超低'); } else if (value == 60) { texts.push('低'); } else if (value == 90) { texts.push('中'); } else if (value == 120) { texts.push('高'); } else if (value == 150) { texts.push('超高'); } return texts; }, textStyle: { color: '#cbf7ff', fontSize: 14, fontWeight: 200, }, }, splitLine: { lineStyle: { color: '#272456', }, }, }, ], dataZoom: [ { show: true, height: 20, xAxisIndex: [0], bottom: 50, start: 20, end: 150, handleIcon: 'path://M306.1,413c0,2.2-1.8,4-4,4h-59.8c-2.2,0-4-1.8-4-4V200.8c0-2.2,1.8-4,4-4h59.8c2.2,0,4,1.8,4,4V413z', handleSize: '120%', handleStyle: { color: '#00b4ff', }, textStyle: { color: '#cef6fe', }, fillerColor: 'rgba(40,82,106,0.8)', borderColor: 'rgba(49,65,80,0.5)', }, { type: 'inside', show: true, height: 15, width: 20, start: 1, end: 35, }, ], series: [ { type: 'pictorialBar', symbol: 'image://', symbolSize: [50, 50], symbolOffset: [0, -20], z: 12, itemStyle: { normal: { color: '#14b1eb', }, }, data: getSymbolData(datas), }, { type: 'bar', data: datas, barWidth: 15, itemStyle: { normal: { color: { //图形颜色 type: 'linear', x: 0, y: 0, x2: 0, y2: 1, colorStops: [ { offset: 0, color: '#4fa5e2', // 0% 处的颜色 }, { offset: 0.5, color: '#c2bc1c', // 50% 处的颜色 }, { offset: 1, color: '#5EDEE5', // 50% 处的颜色 }, ], global: false, // 缺省为 false }, barBorderRadius: [30, 30, 0, 0], shadowColor: 'rgba(0,255,225,1)', shadowBlur: 4, }, }, markLine: { symbol: 'none', label: { show: true, position: 'start', formatter: '阀值\n{c}', fontSize: 14, fontWeight: 'bold', }, lineStyle: { type: 'solid', }, data: [ { yAxis: min, lineStyle: { color: 'rgba(188, 27, 65, 1)', }, label: { color: 'rgba(188, 27, 65, 1)', }, }, { yAxis: max, lineStyle: { color: 'rgba(255, 182, 54, 1)', }, label: { color: 'rgba(255, 182, 54, 1)', }, }, ], }, label: { normal: { show: true, lineHeight: 20, width: 80, height: 40, padding: 5, backgroundColor: '#fff', borderRadius: 5, position: 'top', align: 'center', formatter: '{b|{b}\n}{c|{c}}', fontSize: 15, rich: { b: { align: 'center', color: '#fff', fontSize: 15, textShadowBlur: 2, textShadowColor: '#000', textShadowOffsetX: 0, textShadowOffsetY: 1, textBorderColor: '#333', textBorderWidth: 2, }, c: { color: '#999', fontSize: 14, lineHeight: 22, align: 'center', }, }, }, }, }, ], }; var count = 0; setInterval(function () { if (count % 2 === 0) { option.series[1].barWidth = 15; option.series[0].symbolSize = [50, 50]; myChart.setOption(option); //交替setOption } else { option.series[1].barWidth = 18; option.series[0].symbolSize = [53, 53]; myChart.setOption(option); } count += 1; }, 600);