关系图、拓扑图
var data = { "children": [{ "children": [{ "ifend": "1", "name": "节点二1", "number": ".18" }], "name": "节点一1", "number": "0" }, { "ifend": "1", "name": "节点一2", "number": ".87" }, { "ifend": "1", "name": "节点一3", "number": ".92" }, { "ifend": "1", "name": "节点一4", "number": "1.68" }, { "children": [{ "code": "2", "ifend": "1", "name": "节点二10", "number": "10.01" }, { "ifend": "1", "name": "节点二11", "number": "0.31" }, { "code": "2", "ifend": "1", "name": "节点二12", "number": "-.92" }, { "code": "2", "name": "节点二2", "number": "100" }, { "ifend": "1", "name": "节点二3", "number": ".05" }, { "ifend": "1", "name": "节点二4", "number": "1.53" }, { "ifend": "1", "name": "节点二5", "number": "1.14" }, { "ifend": "1", "name": "节点二6", "number": "1.98" }, { "ifend": "1", "name": "节点二7", "number": ".02" }, { "ifend": "1", "name": "节点二8", "number": "1.03" }, { "ifend": "1", "name": "节点二9", "number": "3.05" }], "name": "节点一5", "number": ".16" }, { "ifend": "1", "name": "节点一6", "number": "2.33" }], "name": "节点", "number": ".46" }; function format(data) { data.x = 0; data.y = 0; if (!data.hasOwnProperty("children")) { data.len = [1, -1]; data.leny = [1, 9]; return data; } var l2 = data.children; var hi = parseInt(l2.length / 2); var xi = l2.length - hi; var his = getSum(l2, 0, hi); var xis = getSum(l2, xi - 1, l2.length); l2 = sortData(l2, hi, xi); data.children = l2; var jhi = (hi > 9 || his === 0) ? 300 : 200; var jxi = (xi > 9 || xis === 0) ? 300 : 200; var maxmin = [-100000, 100000]; var maxminy = [-100000, 100000]; for (var i = 0; i < l2.length; i++) { if (i < hi) { l2[i].x = getLoction(hi, data.x, i + 1); l2[i].y = data.y + jhi; l2[i].fx = getFX(hi, i, false); } else { l2[i].x = getLoction(xi, data.x, i - hi + 1); l2[i].y = data.y - jxi; l2[i].fx = getFX(xi, i - hi, true); } getMaxMin(maxmin, l2[i].x); getMaxMin(maxminy, l2[i].y); if (!l2[i].hasOwnProperty("children")) { continue; } var l3 = l2[i].children; for (var j = 0; j < l3.length; j++) { if (i < hi) { l3[j].x = getLoction(l3.length, l2[i].x, j + 1); l3[j].y = l2[i].y + 200; l3[j].fx = getFX(l3.length, j, false); } else { l3[j].x = getLoction(l3.length, l2[i].x, j + 1); l3[j].y = l2[i].y - 200; l3[j].fx = getFX(l3.length, j, true); } getMaxMin(maxmin, l3[j].x); getMaxMin(maxminy, l3[j].y); } } var c; if (hi % 2 === 0) { c = hi / 2; if (l2[c].hasOwnProperty("children")) { if (l2[c - 1].hasOwnProperty("children") && l2[c].children[0].x < l2[c].x - 50) { var tem = 50 - l2[c].children[0].x; for (var j = 0; j < l2[c].children.length; j++) { l2[c].children[j].x = l2[c].children[j].x + tem; getMaxMin(maxmin, l2[c].children[j].x); } l2[c].x = getLoction2(l2[c].children); } } } else { c = parseInt(hi / 2); } for (var i = c + 1; i < hi; i++) { if (l2[i].hasOwnProperty("children")) { if (l2[i - 1].hasOwnProperty("children") && l2[i - 1].children[l2[i - 1].children.length - 1].x - l2[i].children[0].x > -100) { var tem = l2[i - 1].children[l2[i - 1].children.length - 1].x + 100 - l2[i].children[0].x; for (var j = 0; j < l2[i].children.length; j++) { l2[i].children[j].x = l2[i].children[j].x + tem; getMaxMin(maxmin, l2[i].children[j].x); } l2[i].x = getLoction2(l2[i].children); } } } for (var i = c - 1; i >= 0; i--) { if (l2[i].hasOwnProperty("children")) { if (l2[i + 1].hasOwnProperty("children") && l2[i + 1].children[0].x - l2[i].children[l2[i].children.length - 1].x < 100) { var tem = l2[i].children[l2[i].children.length - 1].x - (l2[i + 1].children[0].x - 100); for (var j = 0; j < l2[i].children.length; j++) { l2[i].children[j].x = l2[i].children[j].x - tem; getMaxMin(maxmin, l2[i].children[j].x); } l2[i].x = getLoction2(l2[i].children); } } } if (xi % 2 === 0) { c = xi / 2 + hi; if (l2[c].hasOwnProperty("children")) { if (l2[c - 1].hasOwnProperty("children") && l2[c].children[0].x < l2[c].x - 50) { var tem = 50 - l2[c].children[0].x; for (var j = 0; j < l2[c].children.length; j++) { l2[c].children[j].x = l2[c].children[j].x + tem; getMaxMin(maxmin, l2[c].children[j].x); } l2[c].x = getLoction2(l2[c].children); } } } else { c = parseInt(xi / 2) + hi; } for (var i = c + 1; i < l2.length; i++) { if (l2[i].hasOwnProperty("children")) { if (l2[i - 1].hasOwnProperty("children") && l2[i - 1].children[l2[i - 1].children.length - 1].x - l2[i].children[0].x > -100) { var tem = l2[i - 1].children[l2[i - 1].children.length - 1].x + 100 - l2[i].children[0].x; for (var j = 0; j < l2[i].children.length; j++) { l2[i].children[j].x = l2[i].children[j].x + tem; getMaxMin(maxmin, l2[i].children[j].x); } l2[i].x = getLoction2(l2[i].children); } } } for (var i = c - 1; i >= hi; i--) { if (l2[i].hasOwnProperty("children")) { if (l2[i + 1].hasOwnProperty("children") && l2[i + 1].children[0].x - l2[i].children[l2[i].children.length - 1].x < 100) { var tem = l2[i].children[l2[i].children.length - 1].x - (l2[i + 1].children[0].x - 100); for (var j = 0; j < l2[i].children.length; j++) { l2[i].children[j].x = l2[i].children[j].x - tem; getMaxMin(maxmin, l2[i].children[j].x); } l2[i].x = getLoction2(l2[i].children); } } } // data.x = (maxmin[0] - maxmin[1]) / 2 + maxmin[1]; if (maxmin[0] - maxmin[1] <= 400) { maxmin[0] = maxmin[0] + 100; maxmin[1] = maxmin[1] - 100; } data.len = maxmin; data.leny = maxminy; return data; } function format2(data) { if (!data.hasOwnProperty("children")) { return data; } var l2 = data.children; var hi = parseInt(l2.length / 2); var xi = l2.length - hi; var maxmin = data.len; for (var i = 0; i < l2.length; i++) { if (!l2[i].hasOwnProperty("children")) { if (i > 0 && (i != hi) && l2[i - 1].hasOwnProperty("children") && l2[i - 1].children.length > 5) { var tem = (l2[i - 1].children.length - 5) / 2; l2[i].x = l2[i].x + 100 * tem; var len, flag = false; if (i < hi) { len = hi; } else { len = l2.length; } for (var j = i + 1; j < len; j++) { flag = true; l2[j].x = l2[j].x + 100 * tem; if (l2[j].hasOwnProperty("children")) { var children = l2[j].children; for (var k = 0; k < children.length; k++) { children[k].x = children[k].x + 100 * tem; getMaxMin(maxmin, children[k].x); } } getMaxMin(maxmin, l2[j].x); } if (flag) { l2[i].x = l2[i].x > maxmin[0] ? maxmin[0] : l2[i].x; } } else if (i < l2.length - 1 && l2[i + 1].hasOwnProperty("children") && l2[i + 1].children.length > 5) { var tem = (l2[i + 1].children.length - 5) / 2; l2[i].x = l2[i].x - 100 * tem; var len, flag = false; if (i < hi) { len = 0; } else { len = hi; } for (var j = i - 1; j >= len; j--) { flag = true; l2[j].x = l2[j].x - 100 * tem; if (l2[j].hasOwnProperty("children")) { var children = l2[j].children; for (var k = 0; k < children.length; k++) { children[k].x = children[k].x - 100 * tem; getMaxMin(maxmin, children[k].x); } } getMaxMin(maxmin, l2[j].x); } if (flag) { l2[i].x = l2[i].x < maxmin[1] ? maxmin[1] : l2[i].x; } } } } // data.x = (maxmin[0] - maxmin[1]) / 2 + maxmin[1]; if (maxmin[0] - maxmin[1] <= 400) { maxmin[0] = maxmin[0] + 100; maxmin[1] = maxmin[1] - 100; } data.len = maxmin; return data; } function getLoction(num, x, index) { if (num % 2 === 0) { var c = num / 2 - index; x = x - 50 - 100 * c; } else { var c = parseInt(num / 2 + 1) - index; x = x - 100 * c; } return x; } /*function getLoction2(data) { var len = data.length; var x; if (len % 2 === 0) { var c = len / 2; x = data[c - 1].x + 50; } else { var c = parseInt(len / 2 + 1); x = data[c - 1].x; } return x; }*/ function getFX(len, index, fx) { var x, c; if (len < 1) { return 1; } c = (len % 2 === 0) ? len / 2 : (parseInt(len / 2) + 1); x = (index < c) ? 1 : -1; if (fx) { x = -x; } return x; } function getSum(data, st, ed) { if (ed > data.length) { ed = data.length; } var count = 0; for (var i = st; i < ed; i++) { if (!data[i].hasOwnProperty("children")) { continue; } var l3 = data[i].children; count = count + l3.length; } return count; } function sortData(data, hi, xi) { var res = []; var len = hi - 1; var pos = 0; for (var i = 0; i < hi - 1; i++) { var flag = 1; for (var j = 0; j < len; j++) { var dx = !data[j].hasOwnProperty("children") ? 0 : data[j].children.length, dx1 = !data[j + 1].hasOwnProperty("children") ? 0 : data[j + 1].children.length; if (dx > dx1) { var tem = data[j]; data[j] = data[j + 1]; data[j + 1] = tem; flag = 0; pos = j; } } len = pos; if (flag === 1) { break; } } for (var i = 0; i < hi; i++) { if (i % 2 === 0) { res[i / 2] = data[i]; } else { res[hi - (i + 1) / 2] = data[i]; } } len = data.length - 1; pos = 0; for (var i = hi; i < data.length - 1; i++) { var flag = 1; for (var j = hi; j < len; j++) { var dx = !data[j].hasOwnProperty("children") ? 0 : data[j].children.length, dx1 = !data[j + 1].hasOwnProperty("children") ? 0 : data[j + 1].children.length; if (dx > dx1) { var tem = data[j]; data[j] = data[j + 1]; data[j + 1] = tem; flag = 0; pos = j; } } len = pos; if (flag === 1) { break; } } for (var i = 0; i < xi; i++) { if (i % 2 === 0) { res[i / 2 + hi] = data[i + hi]; } else { res[xi - (i + 1) / 2 + hi] = data[i + hi]; } } return res; } function getMaxMin(maxmin, x) { if (maxmin[0] < x) { maxmin[0] = x; } if (maxmin[1] > x) { maxmin[1] = x; } return maxmin; } function initCharts(returninfo) { var res = {}; var links = []; var lines = []; var yiji = 'image://'; var erji = yiji; var sanji = erji; returninfo.number = (returninfo.number === undefined) ? '--' : returninfo.number + '%'; returninfo.number = (returninfo.number.startsWith('.')) ? '0' + returninfo.number : returninfo.number; returninfo.number = (returninfo.number.startsWith('-.')) ? returninfo.number.replace('-.', '-0.') : returninfo.number; var url = '${pageContext.request.requestURL}'.replace('${pageContext.request.requestURI}', ''); var data = [{ name: returninfo.name + ":" + returninfo.number, tooltip: { formatter: "{b}" }, symbol: yiji, symbolSize: [60, 40], value: [returninfo.x, returninfo.y], datadate: returninfo.datadate, spid: returninfo.id }]; if ("children" in returninfo) { var l2 = returninfo.children; var curveness, colork, colorn, xs; for (var i = 0; i < l2.length; i++) { curveness = l2[i].fx === 1 ? 0.1 : -0.1; l2[i].number = (l2[i].number === undefined) ? '--' : l2[i].number + '%'; l2[i].number = (l2[i].number.startsWith('.')) ? '0' + l2[i].number : l2[i].number; l2[i].number = (l2[i].number.startsWith('-.')) ? l2[i].number.replace('-.', '-0.') : l2[i].number; colork = (l2[i].code === '2' || l2[i].code === 2) ? '#C75050' : '#53B5EA'; var link = { source: returninfo.name + ":" + returninfo.number, target: l2[i].name + ":\n" + l2[i].number, lineStyle: { curveness: curveness, color: colork } }; links.push(link); colorn = (l2[i].code === '2' || l2[i].code === 2) ? 'rgba(199,80,80,0.5)' : 'rgba(55,155,255,0.5)'; var line = { coords: [ [returninfo.x, returninfo.y], [l2[i].x, l2[i].y] ], lineStyle: { curveness: curveness, color: colorn } }; lines.push(line); var node = { name: l2[i].name + ":\n" + l2[i].number, tooltip: { formatter: "{b}" }, symbol: erji, symbolSize: [60, 40], value: [l2[i].x, l2[i].y], datadate: l2[i].datadate, ifend: l2[i].ifend, spid: l2[i].id }; data.push(node); if ("children" in l2[i]) { var l3 = l2[i].children; for (var j = 0; j < l3.length; j++) { curveness = l3[j].fx === 1 ? 0.1 : -0.1; l3[j].number = (l3[j].number === undefined) ? '--' : l3[j].number + '%'; l3[j].number = (l3[j].number.startsWith('.')) ? '0' + l3[j].number : l3[j].number; l3[j].number = (l3[j].number.startsWith('-.')) ? l3[j].number.replace('-.', '-0.') : l3[j].number; colork = (l3[j].code === '2' || l3[j].code === 2) ? '#C75050' : '#53B5EA'; var link = { source: l2[i].name + ":\n" + l2[i].number, target: l3[j].name + ":\n" + l3[j].number, lineStyle: { curveness: curveness, color: colork } }; links.push(link); colorn = (l3[j].code === '2' || l3[j].code === 2) ? 'rgba(199,80,80,0.5)' : 'rgba(55,155,255,0.5)'; var line = { coords: [ [l2[i].x, l2[i].y], [l3[j].x, l3[j].y] ], lineStyle: { curveness: curveness, color: colorn } }; lines.push(line); node = { name: l3[j].name + ":\n" + l3[j].number, tooltip: { formatter: "{b}" }, symbol: sanji, symbolSize: [60, 40], value: [l3[j].x, l3[j].y], datadate: l3[j].datadate, ifend: l3[j].ifend, spid: l3[j].id }; data.push(node); } } } } res.data = data; res.links = links; res.lines = lines; res.len = returninfo.len; res.leny = returninfo.leny; return res; } var jsons = format(data); debugger; jsons = format2(jsons); var returninfo = initCharts(jsons); option = { backgroundColor: "#f5f5f5", grid: { left: '5%', right: '5%' }, xAxis: { show: false, type: "value", max: returninfo.len[0], min: returninfo.len[1] }, yAxis: { show: false, type: "value", max: returninfo.leny[0], min: returninfo.leny[1] - 10 }, tooltip: {}, series: [{ type: "graph", zlevel: 5, draggable: false, coordinateSystem: "cartesian2d", //使用二维的直角坐标系(也称笛卡尔坐标系) label: { show: true, color: "#000", position: 'bottom', }, data: returninfo.data, links: returninfo.links, lineStyle: { opacity: 1, width: 2 } }, { type: "lines", coordinateSystem: "cartesian2d", zlevel: 1, animation: false, effect: { show: true, period: 5, trailLength: 0.01, symbolSize: 12, symbol: "pin", loop: true }, data: returninfo.lines, lineStyle: { width: 0 } }, { type: "lines", coordinateSystem: "cartesian2d", zlevel: 1, animation: false, effect: { show: true, period: 6, trailLength: 0.01, symbolSize: 12, symbol: "pin", loop: true }, data: returninfo.lines, lineStyle: { width: 0 } }, { type: "lines", coordinateSystem: "cartesian2d", zlevel: 1, animation: false, effect: { show: true, period: 8, trailLength: 0.01, symbolSize: 12, symbol: "pin", loop: true }, data: returninfo.lines, lineStyle: { width: 0 } }] }; /*myChart.on('click', function(params) { if (params.dataType === 'node') { var data = params.data; if (data.ifend === '1' || data.ifend === 1) { var sp_id = data.spid; var data_date = data.datadate; var url = getUrlByParams("/branchLineLoss/getMeterJson?sp_id=" + sp_id + "&data_date=" + data_date, null); createRespone('楼层结构', url, null, null, '650px', '600px'); } } }*/
echarts版本号:4.8.0