D3:改变节点样式

首先在<body>添加图片对象

复制代码
       
       <svg id="mySvg_ac" width="0" height="0" >
        <defs id="mdef">
            <!-- 图片1  -->
            <pattern id="img_ac" x="0" y="0" height="128" width="128">
            <image x="0" y="0" width="128" height="128" xlink:href="/static/images/ac.png"></image>
            </pattern>

            <!-- 图片2  -->
            <pattern id="img_de" x="0" y="0" height="128" width="128">
            <image x="0" y="0" width="128" height="128" xlink:href="/static/images/de.png"></image>
            </pattern>
        </defs>
       </svg>
复制代码

然后在需要的节点中引用图片对象

复制代码
        var nodes = svg.selectAll("circle")
            .data(nodes_data)
            .enter()
            .append("circle")
            .attr("fill", function(d){
                if(d.type == 'ac'){
                    return "url(#img_ac)";
                }else{
                    return "url(#img_de)";
                }})
复制代码

 

posted @   徐钏  阅读(203)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek “源神”启动!「GitHub 热点速览」
· 微软正式发布.NET 10 Preview 1:开启下一代开发框架新篇章
· 我与微信审核的“相爱相杀”看个人小程序副业
· C# 集成 DeepSeek 模型实现 AI 私有化(本地部署与 API 调用教程)
· spring官宣接入deepseek,真的太香了~
点击右上角即可分享
微信分享提示