var zData = [ "北", //348.75 ~ 11.25; "北北东", //11.25 ~ 33.75; "东北", //33.75 ~ 56.25; "东东北", //56.25 ~ 78.75; "东", //78.75 ~ 101.25; "东东南", //101.25 ~ 123.75; "东南", //123.75 ~ 146.25; "南南东", //146.25 ~ 168.75; "南", //168.75 ~ 191.25; "南南西", //191.25 ~ 213.75; "西南", //213.75 ~ 236.25; "西西南", //236.25 ~ 258.75; "西", //258.75 ~ 281.25; "西西北", //281.25 ~ 303.75; "西北", //303.75 ~ 326.25; "北北西" //326.25 ~ 348.75; ]; let { yUnit, yUnit2, xUnit, interval, showSymbol, xMaxVal, xInterval, showDataZoom, dataZoomEndVlaue, yInterval, yMax, yMin, yData, yData2, yData3 } = { "xUnit": "时间(小时)", "yUnit": "水\n位\n\n(m)", "yUnit2": "水\n速\n\n(m/s)", "yData": [ [0, "0.218", "10-11 00"], [1, "0.361", "10-11 01"], [2, "0.405", "10-11 02"], [3, "0.339", "10-11 03"], [4, "0.180", "10-11 04"], [5, "-0.032", "10-11 05"], [6, "-0.242", "10-11 06"], [7, "-0.395", "10-11 07"], [8, "-0.451", "10-11 08"], [9, "-0.394", "10-11 09"], [10, "-0.238", "10-11 10"], [11, "-0.020", "10-11 11"], [12, "0.206", "10-11 12"], [13, "0.382", "10-11 13"], [14, "0.467", "10-11 14"], [15, "0.440", "10-11 15"], [16, "0.309", "10-11 16"], [17, "0.109", "10-11 17"], [18, "-0.110", "10-11 18"], [19, "-0.291", "10-11 19"], [20, "-0.391", "10-11 20"], [21, "-0.386", "10-11 21"], [22, "-0.282", "10-11 22"], [23, "-0.107", "10-11 23"] ], "yData2": [ [-0.016666666666666666, "0.047", "10-10 23", true, "最大"], [2.9833333333333334, "0.007", "10-11 02", true, "最小"], [5.983333333333333, "0.050", "10-11 05", true, "最大"], [8.983333333333333, "0.002", "10-11 08", true, "最小"], [11.983333333333333, "0.050", "10-11 11", true, "最大"], [14.983333333333333, "0.005", "10-11 14", true, "最小"], [17.983333333333334, "0.046", "10-11 17", true, "最大"], [20.983333333333334, "0.008", "10-11 20", true, "最小"] ], "yData3": [ [0, "0.047", "10-11 00", null, "11.4"], [1, "0.038", "10-11 01", null, "14.5"], [2, "0.019", "10-11 02", null, "22.6"], [3, "0.007", "10-11 03", null, "152.4"], [4, "0.029", "10-11 04", null, "182.1"], [5, "0.045", "10-11 05", null, "186.3"], [6, "0.050", "10-11 06", null, "188.3"], [7, "0.042", "10-11 07", null, "190.0"], [8, "0.023", "10-11 08", null, "192.4"], [9, "0.002", "10-11 09", null, "318.4"], [10, "0.025", "10-11 10", null, "7.1"], [11, "0.043", "10-11 11", null, "9.1"], [12, "0.050", "10-11 12", null, "10.2"], [13, "0.045", "10-11 13", null, "11.0"], [14, "0.029", "10-11 14", null, "12.0"], [15, "0.005", "10-11 15", null, "16.9"], [16, "0.019", "10-11 16", null, "190.8"], [17, "0.037", "10-11 17", null, "192.3"], [18, "0.046", "10-11 18", null, "193.5"], [19, "0.043", "10-11 19", null, "195.2"], [20, "0.028", "10-11 20", null, "198.6"], [21, "0.008", "10-11 21", null, "220.5"], [22, "0.016", "10-11 22", null, "359.9"], [23, "0.034", "10-11 23", null, "7.9"] ], "xMaxVal": 24, "xInterval": 6, "showSymbol": true, "showDataZoom": false, "dataZoomEndVlaue": 100 }; var max_speed = 0, min_speed = 0; if (yData) { var sData = yData.map((el) => el[1]); var max_speed = Math.max(...sData); var min_speed = Math.min(...sData); } var ynames = yUnit ? yUnit.split("\n") : []; var ynames2 = yUnit2 ? yUnit2.split("\n") : []; // if (myChart.getAttribute("_echarts_instance_")) { // myChart.removeAttribute("_echarts_instance_"); // } // 绘制图表 let option = { backgroundColor: '#081736', grid: { left: 80, right: 25, top: 45, bottom: 65 }, toolbox: { iconStyle: { borderColor: "#ffffff" }, right: "18", feature: { saveAsImage: { show: true, backgroundColor: "#010313" } } }, tooltip: { show: true, trigger: "axis", // item formatter: (params) => { let name = yUnit; name = name.replace(/\n/g, ""); let i = name.indexOf("("); let str = ""; if (yUnit2) { str = params[0].data[2] + "<br/>"; params.forEach((el) => { var { seriesName, data, marker } = el; // marker = ""; var current = seriesName == "水位"; var unit = current ? ynames[3] : ynames2[3]; var strC = marker + seriesName + ":" + data[current ? 1 : data.length - 1] + " " + unit; if (seriesName == "峰值") { strC = marker + data[data.length - 2] + seriesName; } if (seriesName == "流速") { var angle = data[4]; var NewAng = 11.25 + Number(angle); var Angle = 360 / zData.length; var count = Math.floor(NewAng / Angle); var residue = angle % Angle; var dirction = zData[count > zData.length - 1 ? 0 : count]; strC += "<br/>" + marker + "流向:" + dirction + angle + " °"; } str += strC + "<br/>"; }); return str; } else { str = params[0].marker + params[0].data[2] + "<br/>" + name + ":" + params[0].data[1]; } if (i != -1) { str = params[0].marker + params[0].data[2] + "<br/>" + name.slice(0, i) + ": " + params[0].data[1] + name.slice(i); } if (showSymbol && params[0].data[4]) { str += "<br/>" + "流向:" + params[0].data[4] + "(°)"; } return str; } }, xAxis: { type: "value", name: xUnit, nameGap: 22, min: 0, nameLocation: "center", boundaryGap: false, nameTextStyle: { fontSize: 14, color: "#ffffff" }, axisLabel: { fontSize: 14, color: "#ffffff", interval: interval ? interval : "auto" }, splitLine: { show: true, lineStyle: { color: "#707070" } }, max: xMaxVal, interval: xInterval }, dataZoom: [ { type: "inside", zoomLock: true, start: 0, show: showDataZoom ? showDataZoom : false, end: dataZoomEndVlaue ? dataZoomEndVlaue : 100 }, { show: showDataZoom ? showDataZoom : false, start: 0, end: dataZoomEndVlaue ? dataZoomEndVlaue : 100, height: 12, bottom: 10, zoomLock: true, moveHandleSize: 0, brushSelect: false, textStyle: { fontSize: 0 } } ], yAxis: [ { type: "value", name: yUnit, nameGap: 58, nameRotate: 360, nameLocation: "middle", nameTextStyle: { fontSize: 14, color: "#ffffff", align: "center" }, axisTick: { show: false }, axisLabel: { fontSize: 14, color: "#ffffff" }, splitLine: { show: true, lineStyle: { color: "#707070" } }, axisLine: { lineStyle: { color: "#707070" } }, scale: true } ], series: [ { dimensions: ["distanceX", "valueY", "time", "showSymbol"], encode: { x: "distanceX", // 默认 x轴 y: "valueY", // 默认 y 轴 unit: "unit", // 单位 自定义的数据, 可用于 formatter time: "time", tooltip: ["time"] }, data: yData, // data: [ // [0, '0.48', '2021-08-23 13:56'], // [1, '0.42', '2021-08-23 13:56'], // [1.5, '0.42', '2021-08-23 13:32'], // [2.5, '0.38582', '2021-08-23 13:56'], // [3, '0.36861', '2021-08-23 13:57'], // [4, '0.35983', '2021-08-23 13:57'], // [5, '0.49812', '2021-08-23 13:57'], // [6, '0.49812', '2021-08-23 13:57'], // [7, '0.41282', '2021-08-23 13:57'], // [8, '0.42099', '2021-08-23 13:57'], // ], type: "line", smooth: true, showSymbol: true, symbol: !showSymbol ? "image://" : "image://", symbolKeepAspect: true, symbolSize: showSymbol ? ["56", "40"] : ["20", "20"], showAllSymbol: true, symbolRotate: (value, params) => 360 - value[4], lineStyle: { color: "#63f206", width: 3.5 }, emphasis: { lineStyle: { width: 3.5 } } } ], color: ["#63f206"] }; if (yMax && yMax == 360) { option.yAxis["interval"] = yInterval; option.yAxis["max"] = yMax; option.yAxis["min"] = yMin; } if (yData3 && yData3.length > 0) { option.series[0] = { dimensions: ["distanceX", "valueY", "time", "showSymbol"], encode: { x: "distanceX", // 默认 x轴 y: "valueY", // 默认 y 轴 unit: "unit", // 单位 自定义的数据, 可用于 formatter time: "time", tooltip: ["time"] }, name: ynames[0] + ynames[1], unit: ynames[3], data: yData, type: "line", smooth: true, lineStyle: { width: 3.5 }, emphasis: { lineStyle: { width: 3.5 } } }; option.visualMap = { // yInterval: 0, show: false, type: "piecewise", // continuous dimension: 1, calculable: true, realtime: false, inRange: { color: ["#313695", "#a50026"] }, pieces: [ { gt: min_speed, lt: 0, color: "#F53137" }, { gte: 0, lte: 0, color: "#409EFF" }, { gt: 0, lt: max_speed, color: "#1E7EFB" } ] }; option.yAxis.push({ show: false, type: "value", name: yUnit2, nameGap: 58, nameRotate: 360, nameLocation: "middle", nameTextStyle: { fontSize: 14, color: "#ffffff", align: "left", padding: [0, 0, 0, 10] }, axisTick: { show: false }, axisLabel: { fontSize: 14, color: "#ffffff" }, splitLine: { show: false }, axisLine: { show: true } }); option.series.push({ name: ynames2[0] + ynames2[1], unit: ynames2[3], dimensions: ["distanceX", "valueY", "time", "showSymbol"], encode: { x: "distanceX", // 默认 x轴 y: "valueY", // 默认 y 轴 unit: "unit", // 单位 自定义的数据, 可用于 formatter time: "time", tooltip: ["time"] }, data: yData3.map((el) => { var val = [...el]; val.push(el[1]); val[1] = 0; return val; }), lineStyle: { width: 0 }, itemStyle: { color: "#ff7e4f" }, emphasis: { lineStyle: { width: 0 } }, type: "line", smooth: true, showSymbol: true, symbolKeepAspect: true, symbolSize: (value, params) => { var sData = yData3.map((el) => el[1]); var max = Math.max(...sData); var idx = params.dataIndex; // var val = yData3[idx][1]; var val = value[value.length - 1]; var pre = val / max; var w = pre * 30, h = pre * 30; // return [50 + w, 40 + h]; return [40, 40 + h]; }, showAllSymbol: true, symbolRotate: (value, params) => 360 - value[value.length - 2], symbol: "image://" // symbol: img }); } if (yData2 && yData2.length > 0) { //水速-单点信息-时段信息--最大最小值加点 option.series.push({ dimensions: ["distanceX", "valueY", "time", "showSymbol"], encode: { x: "distanceX", // 默认 x轴 y: "valueY", // 默认 y 轴 unit: "unit", // 单位 自定义的数据, 可用于 formatter time: "time", tooltip: ["time"] }, name: "峰值", // yAxisIndex: yUnit2 ? 1 : 0, unit: yUnit2 ? ynames2[3] : ynames[3], data: yUnit2 ? yData2.map((el) => { var val = [...el]; val.push(el[1]); val[1] = 0; return val; }) : yData2, type: "line", smooth: true, showSymbol: true, // symbolSize: function (value, params) { // let size = 0; // if (value[3]) { // size = 4; // } // return size; // }, symbolSize: (value, params) => { var sData = yData3.map((el) => el[1]); var max = Math.max(...sData); var min = Math.min(...sData); var idx = params.dataIndex; var val = yData3[idx][1]; let size = 0; var pre = val / max; var w = pre * 20, h = pre * 20; // return [50 + w, 40 + h]; if (value[3]) { size = 5; } return size; }, itemStyle: { color: "#409EFF" }, lineStyle: { color: "transparent", width: 0 }, emphasis: { lineStyle: { color: "transparent", width: 0 } } }); }