关系图、拓扑图

描述:当前是关于Echarts图表中的 示例。
 
            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');
                }
            }
        }*/