5

Mike Bostock によるこのコード ダイアグラムを適応させようとしています。

このコード ダイアグラムのように、テキスト ラベルを外側に回転させたい:

http://bost.ocks.org/mike/uberdata/

ここに画像の説明を入力

ここに例があります

http://bl.ocks.org/mbostock/910126

ここに画像の説明を入力

ただし、変換は svg:text を使用して行われます。

  g.append("svg:text")
      .each(function(d) { d.angle = (d.startAngle + d.endAngle) / 2; })
      .attr("dy", ".35em")
      .attr("text-anchor", function(d) { return d.angle > Math.PI ? "end" : null; })
      .attr("transform", function(d) {
        return "rotate(" + (d.angle * 180 / Math.PI - 90) + ")"
            + "translate(" + (r0 + 26) + ")"
            + (d.angle > Math.PI ? "rotate(180)" : "");
      })
      .text(function(d) { return nameByIndex[d.index]; });

私が適応しようとしているのは「テキスト」と「テキストパス」を使用しており、単純に変換/回転属性を追加できないようです。この行を追加する

.attr("transform",function(d,i){return "rotate(90)";})

以下のコードでは何もしません:

   // Add a text label.
        var groupText = group.append("text")
            .attr("x", 6)
            .attr("dy", 15);

            groupText.append("textPath")
            .attr("xlink:href",  function(d, i) { return "#group" + i; })

           .text(function(d, i) { return cities[i].country; });

テキストを外側に回転させて、小さなコードグループのテキストラベルを束ねたり(元のソリューションのように)完全にオフにしたりせずに表示できるようにする方法はありますか?

4

1 に答える 1

5

マイク・ボストックによるこの例を探していると思います

最初のコードコードを変更する限り、次の変更はあなたが望むことをするはずです:

// Add a text label.
// var groupText = group.append("text")
//     .attr("x", 6)
//     .attr("dy", 15);

//groupText.append("textPath")
//    .attr("xlink:href", function(d, i) { return "#group" + i; })
//    .text(function(d, i) { return cities[i].name; });

// Remove the labels that don't fit. :(
//groupText.filter(function(d, i) { return groupPath[0][i].getTotalLength() / 2 - 16 < this.getComputedTextLength(); })
//    .remove();

group.append("text")
  .each(function(d) { d.angle = (d.startAngle + d.endAngle) / 2; })
  .attr("dy", ".35em")
  .attr("transform", function(d) {
    return "rotate(" + (d.angle * 180 / Math.PI - 90) + ")"
        + "translate(" + (innerRadius + 26) + ")"
        + (d.angle > Math.PI ? "rotate(180)" : "");
  })
  .style("text-anchor", function(d) { return d.angle > Math.PI ? "end" : null; })
  .text(function(d, i) { return cities[i].name; });
于 2015-02-12T14:57:02.810 に答える