let icon_Map = { "大雪": '', "大雨": '', "多云": '', "雨加雪": '' } let zh_en = { "大雪": 'MajorSnow', "大雨": "heavyRain", "多云": "cloudy", "雨加雪": "sleet" } let data = [ { time: '2023\11\12 09:00', quality: '优', grade: '1级', weather: '大雪', value: -8 }, { time: '2023\11\12 10:00', quality: '优', grade: '1级', weather: '大雨', value: -7 }, { time: '2023\11\12 11:00', quality: '优', grade: '1级', weather: '多云', value: -8 }, { time: '2023\11\12 12:00', quality: '优', grade: '1级', weather: '大雪', value: -8 }, { time: '2023\11\12 13:00', quality: '优', grade: '1级', weather: '雨加雪', value: -5 }, { time: '2023\11\12 14:00', quality: '优', grade: '1级', weather: '大雪', value: -5 }, { time: '2023\11\12 15:00', quality: '优', grade: '1级', weather: '大雪', value: -5 }, { time: '2023\11\12 16:00', quality: '优', grade: '1级', weather: '大雪', value: -8 }, { time: '2023\11\12 17:00', quality: '优', grade: '1级', weather: '多云', value: 1 }, { time: '2023\11\12 18:00', quality: '优', grade: '1级', weather: '多云', value: -1 }, { time: '2023\11\12 19:01', quality: '优', grade: '1级', weather: '多云', value: -5 }, ] let maxArr = []; maxArr.length = data.length; maxArr.fill(1); console.log(maxArr) let rich_weathers = {}; let rich_img_w = 39; for (let k in icon_Map) { let rich_key = zh_en[k] rich_weathers[rich_key] = { width: rich_img_w, height: 32, backgroundColor: { image: icon_Map[k], }, } } let lineSymbol = ``; let xdata = [1, 2, 3] option = { backgroundColor: '#5d87bb', grid: [ { containLabel: true, left: '5%', top: '10%', right: '5%', backgroundColor: '#5d87bb', }, { containLabel: true, left: '3%', top: '10%', right: '3%', backgroundColor: '#5d87bb', } ], title: { text: '鼠标按下拖拽试试' }, dataZoom: [ { show: false, // 为true 滚动条出现 realtime: true, type: 'slider', // 有type这个属性,滚动条在最下面,也可以不行,写y:36,这表示距离顶端36px,一般就是在图上面。 right: "3%", left: "3%", height: '10', xAxisIndex: [0], //关联多个y轴 moveHandleStyle: { color: "rgba(89, 202, 241,.5)", }, moveHandleSize: "6", emphasis: { moveHandleStyle: { color: "rgba(89, 202, 241,.5)", } }, textStyle: { color: "rgba(255,255,255,0)", }, backgroundColor: 'rgba(255,255,255,.1)', borderColor: "rgba(255,255,255,0)", fillerColor: "rgba(0,0,0,0)", handleSize: "6", handleStyle: { color: "rgba(255,255,255,0)" }, brushStyle: { color: "rgba(129, 243, 253)" }, start: 0, end: 80, }, { type: 'inside', xAxisIndex: [0], //关联多个y轴 zoomOnMouseWheel: false, //滚轮是否触发缩放 moveOnMouseMove: true } ], xAxis: [ { type: 'time', triggerEvent: true, boundaryGap: false, axisLabel: { margin: 14, show: true, formatter: (v) => { let newDate = new Date(v); let newDate_h = newDate.getHours(); let filter_ = data.filter((o) => { let _date = new Date(o.time); let _date_h = _date.getHours(); if (_date_h == newDate_h) return o; })[0]; console.log(filter_, newDate_h) let rich_key = zh_en[filter_.weather]; let grade = filter_.grade; let quality = filter_.quality; let str = `{${rich_key}| }\n{text|${grade}}\n{text2|${quality}}\n{h|${newDate_h}}` let sh = new Date().getHours(); if (newDate_h == sh) { str = `{${rich_key}| }\n{text|${grade}}\n{text2|${quality}}\n{sh|当前}` } return str; }, rich: { ...rich_weathers, text: { color: "#ffffff9a", height: 30, lineHeight: 30, fontSize: 14, align: 'center', padding: [1, 3, 0, 0], width: rich_img_w }, text2: { color: "#ffffff9a", height: 20, fontSize: 12, align: 'center', width: rich_img_w, borderRadius: 4, padding: [1.5, 3, 0, 0], backgroundColor: '#ffffff1a' }, h: { color: "#ffffff9a", height: 26, fontSize: 12, align: 'center', width: rich_img_w, borderRadius: 4, padding: [1, 3, 0, 0], }, sh: { color: "#ffffff", height: 26, fontSize: 12, align: 'center', width: rich_img_w, borderRadius: 4, padding: [1, 3, 0, 0], } } }, gridIndex: 0, axisLine: { show: false, }, axisTick: { show: false, }, splitLine: { show: false, }, }, ], yAxis: [ { type: 'value', gridIndex: 0, axisLabel: { show: false }, axisLine: { show: false, }, axisTick: { show: false, }, splitLine: { show: false, }, }, ], color: ['#00e529'], series: [ { type: 'line', symbolSize: 10, symbol: 'image://' + lineSymbol, data: data.map((v) => { return [ new Date(v.time), v.value ] }), yAxisIndex: 0, xAxisIndex: 0, smooth: true, label: { show: true, position: 'top', distance: 5, formatter: (v) => { return v.value[1] + '°' }, color: "#fff", fontSize: 18, fontWeight: 600 }, }, ] };