D3 力导向图 固定某个节点

毕设有一个需求是根据展示药物和蛋白质之间的联系,所以药物是中心节点。很快的可以利用d3的力导向图做出以下效果:
在这里插入图片描述
不过,我们应该要固定药物所在的节点。
查一下相关的API,传送门:https://github.com/xswei/d3-force/blob/master/README.md#simulation_nodes
在这里插入图片描述

由于D3最后会修改我们传入的节点信息数据,因此我们可以直接对数据进行如下修改:

      graph.nodes[0].fx = width / 2
      graph.nodes[0].fy = height / 2

最后效果如图:
在这里插入图片描述

d3.js 中,要隐藏节点和连线,可以通过修改它们的 CSS 属性来实现。具体来说,可以设置节点和连线的 `display` 属性为 `none`,这样它们就不会被显示出来了。 以下是一个简单的示例代码,演示如何隐藏节点和连线: ```javascript // 定义节点和连线的数据 var nodes = [{id: 1}, {id: 2}, {id: 3}]; var links = [{source: 1, target: 2}, {source: 2, target: 3}]; // 创建导向 var svg = d3.select("svg"); var simulation = d3.forceSimulation(nodes) .force("link", d3.forceLink(links)) .force("charge", d3.forceManyBody()); // 绘制节点和连线 var link = svg.selectAll(".link") .data(links) .enter().append("line") .attr("class", "link"); var node = svg.selectAll(".node") .data(nodes) .enter().append("circle") .attr("class", "node"); // 定义隐藏节点和连线的函数 function hide() { node.style("display", "none"); link.style("display", "none"); } // 定义显示节点和连线的函数 function show() { node.style("display", null); link.style("display", null); } // 在点击按钮时隐藏节点和连线 d3.select("#hide-button").on("click", hide); // 在点击按钮时显示节点和连线 d3.select("#show-button").on("click", show); ``` 在上面的代码中,我们定义了两个函数 `hide()` 和 `show()`,分别用于隐藏和显示节点和连线。在点击按钮时,我们调用这些函数来隐藏或显示节点和连线。节点和连线的 CSS 样式可以在 CSS 文件中定义。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值