当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


d3.js linkRadial()用法及代码示例


这个d3.linkRadial()方法 r返回一个带有径向切线的新链接生成器。现在是通常在根居中且子项从根向外展开时使用。

用法:

var link = d3.linkRadial()
    .angle(function(d) { return d.x; })
    .radius(function(d) { return d.y; });

参数:此函数不带任何参数。

返回值:此方法返回一个新的链接生成器。

例:



HTML

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
 
    <script src=
        "https://d3js.org/d3.v5.min.js">
    </script>
</head>
 
<body>
 
    <h1 style="text-align:center; color:green;">
        GeeksforGeeks
    </h1>
 
    <h3 style="text-align:center;">
        D3.js | linkRadial() Method
    </h3>
 
    <center>
    <svg id="gfg" width="200" height="200"></svg>
    </center>
 
    <script>
 
        var data = [
            {source:[100,25], target:[175,175]}, 
            {source:[100,25], target:[25,175]},
            {source:[100,25], target:[125,175]},
            {source:[100,25], target:[75,175]},
            {source:[100,25], target:[225,175]},
            {source:[100,25], target:[275,175]},
            {source:[100,25], target:[125,175]}]; 
       
        // Radial link generator
        var link = d3.linkRadial()
                    .angle(d => xAngleScale(d[0]))
                    .radius(d => yRadiusScale(d[1]));
 
        var xAngleScale = 
        d3.scaleLinear().domain([25,175]).range([Math.PI, Math.PI *2 ]);
        var yRadiusScale = 
        d3.scaleLinear().domain([25,175]).range([0, 80]);
       
        //Adding the link paths
        d3.select("#gfg")
        .selectAll("path")
        .data(data)
        .join("path")
        .attr("d", link)
        .classed("link", true)
        .attr("transform", "translate(100,100)");
 
    </script>
</body>
 
</html>

输出:




相关用法


注:本文由纯净天空筛选整理自taran910大神的英文原创作品 D3.js linkRadial() Method。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。