ホームページ >ウェブフロントエンド >CSSチュートリアル >文字数制限のあるD3でテキストを折り返すにはどうすればよいですか?

文字数制限のあるD3でテキストを折り返すにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-10-25 07:04:02833ブラウズ

How to Wrap Text in D3 with a Character Limit?

D3 でテキストを折り返す

D3 でテキストを折り返すには、複数の を動的に追加する関数を実装できます。 の要素特定の文字制限内のノード:

<code class="javascript">function wrap(text, width) {
  text.each(function () {
    var words = d3.select(this)
      .text()
      .split(/\s+/);

    words = words.reverse();

    var line = [];
    var lineNumber = 0;
    var lineHeight = 1.1; // ems
    var x = text.attr("x");
    var y = text.attr("y");
    var dy = 0; // parseFloat(text.attr("dy"));

    var tspan = text
      .text(null)
      .append("tspan")
      .attr("x", x)
      .attr("y", y)
      .attr("dy", dy + "em");

    while (word = words.pop()) {
      line.push(word);
      tspan.text(line.join(" "));
      if (tspan.node().getComputedTextLength() > width) {
        line.pop();
        tspan.text(line.join(" "));
        line = [word];
        tspan = text
          .append("tspan")
          .attr("x", x)
          .attr("y", y)
          .attr("dy", ++lineNumber * lineHeight + dy + "em")
          .text(word);
      }
    }
  });
}</code>

次に、各ノードのテキストを直接設定する代わりに、ラップ関数を呼び出す必要があります:

<code class="javascript">// Add entering nodes in the parent’s old position.
node.enter()
  .append("text")
  .attr("class", "node")
  .attr("x", function (d) { return d.parent.px; })
  .attr("y", function (d) { return d.parent.py; })
  .text("Foo is not a long word")
  .call(wrap, 30); // wrap the text in <= 30 pixels</code>

これにより、ノードがラップされます。 の範囲内で指定された文字制限に基づいたテキスト。ノードを配置し、提供された例のように自然にフローできるようにします。

以上が文字数制限のあるD3でテキストを折り返すにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。