1

私の質問は、 JS D3 textPath が表示されないのと非常によく似ています

1つの違いは、ノードだけでなくリンクに戻るjsonを添付したいことです(親にリンクするすべてのノードについて、そのリンクに同じjsonを持たせたい)...そして理想的には、実際にはルートノードから左に行を追加したいだけでなく、どこにも行きません。

それから、私は基本的にリンクの途中にテキストを入れたいと思っています。リンク行をたどるのはいいことですが、絶対に必要というわけではありません。

私の現在の非動作コードは(よくわかりませんが、各リンクにid要素を追加する必要がありますか?しかし、そのためにはjsonが必要です!!!!さらに、テキストを取得するにはjsonが必要です各リンクについても)、間違っていなければパスを参照するために textPath の id を使用すると思いますよね?

var width = $("#graph").width(),
    height = 200;

var cluster = d3.layout.cluster()
    .size([height, width - 160]);

var diagonal = d3.svg.diagonal()
    .projection(function(d) { return [d.y, d.x]; });
var myDiv = document.getElementById('graph');

var svg = d3.select(myDiv).append("svg")
    .attr("width", width)
    .attr("height", height)
  .append("g")
    .attr("transform", "translate(40,0)");

d3.json("/datastreams/json/${_encoded}", function(error, root) {
  var nodes = cluster.nodes(root),
      links = cluster.links(nodes);

  var link = svg.selectAll(".link")
      .data(links)
    .enter().append("path")
      .attr("class", "link")
      .attr("d", diagonal);

  var node = svg.selectAll(".node")
      .data(nodes)
    .enter().append("g")
      .attr("class", "node")
      .attr("transform", function(d) { return "translate(" + d.y + "," + d.x + ")"; })

  link.append("text")
     .style("font-size", function(d) { return d.selected ? "16px" : "10px"; })
     .style("font-weight", function(d) { return d.selected ? "bold" : ""; })
     .text(function(d) { return "SSSS="+d.name; });

  node.append("circle")
      .attr("r", function(d) { return d.selected ? 10 : 4.5; });

  var refs = node.append("a")
    .attr("xlink:href", function(d) { return d.root ? "start" : "end"; });

  var text = refs.append("text")
  .attr("dx", function(d) { return d.root ? 8 : -8; })
  .attr("dy", -4)
  .style("text-anchor", function(d) { return d.root ? "start" : "end"; });

  text.append("tspan")
     .style("font-size", function(d) { return d.selected ? "16px" : "10px"; })
     .style("font-weight", function(d) { return d.selected ? "bold" : ""; })
     .style("fill", function(d) { return "blue"; })
     .text(function(d) { return d.name; });

});

d3.select(self.frameElement).style("height", height + "px");

</script>
4

1 に答える 1

1

ああ、これはうまくいっているようです(まあ、私は完全には終わっていませんが、私が望むものに非常に近いです)。

  var textPath = path.each(function(l){
    var aref = theG.append("a")
        .attr("xlink:href", function(d) { return "http://databus.nrel.gov" });
    var text = aref.append("text")
          .style("fill", function(d) { return "blue"; });
    var textPath = text.append("textPath")
            .attr("startOffset", "50%")
            .attr("xlink:href", "#path"+l.target.name)
            .text("insert");

    var aref2 = theG.append("a")
    .attr("xlink:href", function(d) { return "http://databus.nrel.gov" });
  var text2 = aref2.append("text")
    .style("fill", function(d) { return "blue"; });
  var textPath2 = text2.append("textPath")
    .attr("startOffset", "60%")
    .attr("xlink:href", "#path"+l.target.name)
    .text("delete");
  });
于 2013-10-07T19:40:35.267 に答える