强制在节点下绘制的链接 [英] Forcing Links to Draw Under Nodes

查看:105
本文介绍了强制在节点下绘制的链接的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个D3树形图

http://jsfiddle.net/bGR8N/9/

在运行时创建节点(因此它有点不同于其他示例)。我有一个显示在node.on(mouseover ...)的文本。问题是节点有时被链路重叠。现在,我知道我应该能够解决这个问题,首先创建链接和节点,然后我得到:

that creates nodes at runtime (so its a bit different than the other examples). I have text that displays on a node.on("mouseover..."). The problem is that the nodes are sometimes overlapped by the links. Now, I know that I should be able to fix this by creating the links first and the nodes afterwards but then I get:

Error: Invalid value for <path> attribute d="M,C,NaN ,NaN ,"

Javascript代码:

Javascript code:

var width = 960,
        height = 500;

var tree = d3.layout.tree()
        .size([width - 20, height - 20]);

var root = {},
        nodes = tree(root);

root.parent = root;
root.px = root.x;
root.py = root.y;

var diagonal = d3.svg.diagonal();

var svg = d3.select("body").append("svg")
        .attr("width", width)
        .attr("height", height)
        .append("g")
        .attr("transform", "translate(10,10)");

var node = svg.selectAll(".node"),
        link = svg.selectAll(".link");

var duration = 750;

$("#submit_button").click(function() {
    update();
});
    function update() {
        if (nodes.length >= 500) return clearInterval(timer);

        // Add a new node to a random parent.
        var n = {id: nodes.length},
                p = nodes[Math.random() * nodes.length | 0];
        if (p.children) p.children.push(n); else p.children = [n];
        nodes.push(n);

        // Recompute the layout and data join.
        node = node.data(tree.nodes(root), function (d) {
            return d.id;
        });
        link = link.data(tree.links(nodes), function (d) {
            return d.source.id + "-" + d.target.id;
        });

        // Add entering nodes in the parent’s old position.

        // Add entering links in the parent’s old position.
        link.enter().insert("path", ".g.node")
                .attr("class", "link")
                .attr("d", function (d) {
                    var o = {x: d.source.px, y: d.source.py};
                    return diagonal({source: o, target: o});
                });

                    var gelement = node.enter().append("g");

        gelement.append("circle")
                .attr("class", "node")
                .attr("r", 10)
                .attr("cx", function (d) {
                    return d.parent.px;
                })
                .attr("cy", function (d) {
                    return d.parent.py;
                });

        node.on("mouseover", function (d) {
            var g = d3.select(this); // The node
            // The class is used to remove the additional text later
            //debugger;
            var info = g.insert('text')
                    .attr("x", function (d) {
                        //return (d.parent.px);
                        return (d.x + 10);
                    })
                    .attr("y", function (d) {
                        //return (d.parent.py);
                        return (d.y + 10);
                    })
                    .text(function (d) {
                        return "Info on FOO";
                    });

            console.log("FOO");

        });

        node.on("mouseout", function (d) {
            d3.select(this).select('text').remove();

        });


        // Transition nodes and links to their new positions.
        var t = svg.transition()
                .duration(duration);

        t.selectAll(".link")
                .attr("d", diagonal);

        t.selectAll(".node")
                .attr("cx", function (d) {
                    return d.px = d.x;
                })
                .attr("cy", function (d) {
                    return d.py = d.y;
                });
    }


推荐答案

肯定是为什么,但改变

link.enter().insert("path", ".g.node")

link.enter().insert("path", "g")

问题

这篇关于强制在节点下绘制的链接的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆