SVGのテキストの背景色


101

CSSでのtextようにsvgの背景に色を付けたいbackground-color

fillテキスト自体に色を付けるに関するドキュメントのみを見つけることができました

それも可能ですか?


これまでにコードを共有できますか?
gotohales 2013年


stackoverflow.com/questions/12260370/…は、フィルターを使用してこれを行う方法も示しています。
ErikDahlström2013年

1
@RobertLongsonこの質問を2年前に尋ねられたときに重複して閉じるのは間違っているようです。
Balthazar

@Aperçu:重複するターゲットを選択する場合、質問の年齢は主な要因ではありません。たとえば、こちらを参照してください
2016

回答:


93

いいえ、これは不可能です。SVG要素にはbackground-... プレゼンテーション属性がありません。

この効果をシミュレートするために、テキスト属性の後ろに、fill="green"またはそれと類似したもの(フィルター)の長方形を描画できます。JavaScriptを使用すると、次のことができます。

var ctx = document.getElementById("the-svg"),
textElm = ctx.getElementById("the-text"),
SVGRect = textElm.getBBox();

var rect = document.createElementNS("http://www.w3.org/2000/svg", "rect");
    rect.setAttribute("x", SVGRect.x);
    rect.setAttribute("y", SVGRect.y);
    rect.setAttribute("width", SVGRect.width);
    rect.setAttribute("height", SVGRect.height);
    rect.setAttribute("fill", "yellow");
    ctx.insertBefore(rect, textElm);

8
または、テキストでsvgフィルター(feFlood + feComposite)を使用します。少し似た質問stackoverflow.com/questions/12260370/…を参照してください。
ErikDahlström2013年

3
getBBox()を使用したこのソリューションは、正常に機能しますが、多数の計算を実行する必要がある場合は非常に遅くなる可能性があります。svgフィルター(feFlood + feComposite)の使用に関する問題は、テキストが少しギザギザになることです。以下のシンプルだがハッキーなソリューションを提供しています。
dbarton_uk 2017年

textElm = ctx.getElementById( "the-text")の代わりにtextElm = document.getElementById( "the-text")を使用する方が良いですか?
Simon Hi

nodeJSで同じgetBBox関数を使用する方法
Ali

77

フィルターを使用して背景を生成できます。

<svg width="100%" height="100%">
  <defs>
    <filter x="0" y="0" width="1" height="1" id="solid">
      <feFlood flood-color="yellow"/>
      <feComposite in="SourceGraphic" operator="xor" />
    </filter>
  </defs>
<text filter="url(#solid)" x="20" y="50" font-size="50">solid background</text>
</svg>


1
ここで「SourceGraphic」とはどういう意味ですか?「url(#solid)」は実際に余分なWebアクセスを引き起こしますか?
Ben Slade、

7
ここではテキストがぼやけています:(
teran

5
背景のパディングはできますか?
vsync '19

2
理論的にはこのソリューションが大好きですが、テキストがぼやけていることが確認できます。フィルターがアンチエイリアスを壊すようです。
paulmelnikow

2
ぼやけたテキストを防ぐために追加operator="xor"feCompositeます。@RobertLongson @teran @paulmelnikow @bill
Saeid Zebardast

20

私が使用したソリューションは次のとおりです。

<svg>
  <line x1="100" y1="100" x2="500" y2="100" style="stroke:black; stroke-width: 2"/>    
  <text x="150" y="105" style="stroke:white; stroke-width:0.6em">Hello World!</text>
  <text x="150" y="105" style="fill:black">Hello World!</text>  
</svg>

重複するテキストアイテムが配置され、stroke属性とstroke-width属性が設定されています。ストロークは背景色と一致している必要があり、ストローク幅は実際のテキストを書き込む「しみ」を作成するのに十分な大きさである必要があります。

少しハックして潜在的な問題がありますが、私にとってはうまくいきます!


1
この解決策が最も簡単であることがわかりました。
モーガンワイルド

これが最も簡単な解決策であることが確認されました
scipper '

また、印刷時にフィルターソリューションが非常にぼやけていたため、きれいに印刷されます。
デビッドハント

17

いいえ、SVG要素に背景色を追加することはできません。プログラムでd3を使用して実行できます。

var text = d3.select("text");
var bbox = text.node().getBBox();
var padding = 2;
var rect = self.svg.insert("rect", "text")
    .attr("x", bbox.x - padding)
    .attr("y", bbox.y - padding)
    .attr("width", bbox.width + (padding*2))
    .attr("height", bbox.height + (padding*2))
    .style("fill", "red");

3
これは動作しません; テキストの色を変更するだけで、背景色は変更しません。
David J.

テキストdivまたはspanで囲み、最後に使用した2つのうちのいずれかにスタイルを適用します。
Arif Burhan 2016年

この投稿は、それをうまく説明:cambridge-intelligence.com/...
為替


4

ロバート・ロングソン(@RobertLongson)による回答と修正:

<svg width="100%" height="100%">
  <defs>
    <filter x="0" y="0" width="1" height="1" id="solid">
      <feFlood flood-color="yellow"/>
      <feComposite in="SourceGraphic" operator="xor"/>
    </filter>
  </defs>
  <text filter="url(#solid)" x="20" y="50" font-size="50"> solid background </text>
  <text x="20" y="50" font-size="50">solid background</text>
</svg>

ぼやけや重い「getBBox」はありません:)パディングは、フィルター付きのテキスト要素の空白によって提供されます。それは私のために働いた


2

これは私のお気に入りのハックです(動作するかどうかはわかりません)。まだ表示されていない要素を参照しており、かなりうまく機能している

<svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 620 40" preserveAspectRatio="xMidYMid meet">
    <defs>
        <filter x="-0.02" y="0" width="1.04" height="1.1" id="removebackground">
            <feFlood flood-color="#00ffff"/>
        </filter>
    </defs>

    <!--Draw the text--> 
    <use xlink:href="#mygroup" filter="url(#removebackground)" />
    <g id="mygroup">
        <text id="text1" x="9" y="20" style="text-anchor:start;font-size:14px;">custom text with background</text>  
        <line x1="200" y1="18" x2="200" y2="36" stroke="#000" stroke-width="5"/> 
        <line x1="120" y1="27" x2="203" y2="27" stroke="#000" stroke-width="5"/> 
    </g>
</svg>


2

フィルターとテキストを組み合わせることができます。

<!DOCTYPE html>
<html>
  <head>
    <meta charset=utf-8 />
    <title>SVG colored patterns via mask</title>
  </head>
  <body>
    <svg viewBox="0 0 300 300" xmlns="http://www.w3.org/2000/svg">
      <defs>
        <filter x="0" y="0" width="1" height="1" id="bg-text">
          <feFlood flood-color="white"/>
          <feComposite in="SourceGraphic" operator="xor" />
        </filter>
      </defs>
	  <!-- something has already existed -->
    <rect fill="red" x="150" y="20" width="100" height="50" />
    <circle cx="50"  cy="50" r="50" fill="blue"/>
      
      <!-- Text render here -->
      <text filter="url(#bg-text)" fill="black" x="20" y="50" font-size="30">text with color</text>
      <text fill="black" x="20" y="50" font-size="30">text with color</text>
    </svg>
  </body>
</html> 


1

Robertの回答のように背景がある場合にテキスト要素にパディングを適用する方法を知りたい場合は、次のようにします。

  <svg>
    <defs>
      <filter x="-0.1" y="-0.1" width="1.2" height="1.2" id="solid">
        <feFlood flood-color="#171717"/>
        <feComposite in="SourceGraphic" operator="xor" />
      </filter>
    </defs>
    <text filter="url(#solid)" x="20" y="50" font-size="50">Hello</text>
  </svg>

上記の例では、フィルターのxyの位置をそのまま使用できtransform: translate(-10%, -10%)高さの値は120%およびとして読み取ることができます120%。したがって、背景を20%大きくし、-10%オフセットしました。これで、テキストの両側で背景が10%大きくなりました。


0

以前の回答はテキストを2倍にすることに依存しており、十分な空白がありませんでした。

使用することatop&nbsp;、私は私が望んでいた結果を得ることができました。

この例には、SVGテキストラベルの一般的な使用例である矢印も含まれています。

<svg viewBox="-105 -40 210 234">
<title>Size Guide</title>
<defs>
    <filter x="0" y="0" width="1" height="1" id="solid">
        <feFlood flood-color="white"></feFlood>
        <feComposite in="SourceGraphic" operator="atop"></feComposite>
    </filter>
    <marker id="arrow" viewBox="0 0 10 10" refX="5" refY="5" markerWidth="6" markerHeight="6" orient="auto-start-reverse">
        <path d="M 0 0 L 10 5 L 0 10 z"></path>
    </marker>
</defs>
<g id="garment">
    <path id="right-body" fill="none" stroke="black" stroke-width="1" stroke-linejoin="round" d="M0 0 l30 0 l0 154 l-30 0"></path>
    <path id="right-sleeve" d="M30 0 l35 0 l0 120 l-35 0" fill="none" stroke-linejoin="round" stroke="black" stroke-width="1"></path>
    <use id="left-body" href="#right-body" transform="scale(-1,1)"></use>
    <use id="left-sleeve" href="#right-sleeve" transform="scale(-1,1)"></use>
    <path id="collar-right-top" fill="none" stroke="black" stroke-width="1" stroke-linejoin="round" d="M0 -6.5 l11.75 0 l6.5 6.5"></path>
    <use id="collar-left-top" href="#collar-right-top" transform="scale(-1,1)"></use>
    <path id="collar-left" fill="white" stroke="black" stroke-width="1" stroke-linejoin="round" d="M-11.75 -6.5 l-6.5 6.5 l30 77 l6.5 -6.5 Z"></path>
    <path id="front-right" fill="white" stroke="black" stroke-width="1" d="M18.25 0 L30 0 l0 154 l-41.75 0 l0 -77 Z"></path>
    <line x1="0" y1="0" x2="0" y2="154" stroke="black" stroke-width="1" stroke-dasharray="1 3"></line>
    <use id="collar-right" href="#collar-left" transform="scale(-1,1)"></use>
</g>
<g id="dimension-labels">
    <g id="dimension-sleeve-length">
        <line marker-start="url(#arrow)" marker-end="url(#arrow)" x1="85" y1="0" x2="85" y2="120" stroke="black" stroke-width="1"></line>
        <text font-size="10" filter="url(#solid)" fill="black" x="85" y="60" class="dimension" text-anchor="middle" dominant-baseline="middle"> 120 cm</text>
    </g>
    <g id="dimension-length">
        <line marker-start="url(#arrow)" marker-end="url(#arrow)" x1="-85" y1="0" x2="-85" y2="154" stroke="black" stroke-width="1"></line>
        <text font-size="10" filter="url(#solid)" fill="black" x="-85" y="77" text-anchor="middle" dominant-baseline="middle" class="dimension"> 154 cm</text>
    </g>
    <g id="dimension-sleeve-to-sleeve">
        <line marker-start="url(#arrow)" marker-end="url(#arrow)" x1="-65" y1="-20" x2="65" y2="-20" stroke="black" stroke-width="1"></line>
        <text font-size="10" filter="url(#solid)" fill="black" x="0" y="-20" text-anchor="middle" dominant-baseline="middle" class="dimension">&nbsp;130 cm&nbsp;</text>
    </g>
    <g title="Back Width" id="dimension-back-width">
        <line marker-start="url(#arrow)" marker-end="url(#arrow)" x1="-30" y1="174" x2="30" y2="174" stroke="black" stroke-width="1"></line>
        <text font-size="10" filter="url(#solid)" fill="black" x="0" y="174" text-anchor="middle" dominant-baseline="middle" class="dimension">&nbsp;60 cm&nbsp;</text>
    </g>
</g>
</svg>

-1

テキストにスタイルを追加できます。

  style="-webkit-tap-highlight-color: rgba(0, 0, 0, 0); 
    text-shadow: rgb(255, 255, 255) -2px -2px 0px, rgb(255, 255, 255) -2px 2px 0px, 
     rgb(255, 255, 255) 2px -2px 0px, rgb(255, 255, 255) 2px 2px 0px;"

この例では白です。IEでは機能しません:)

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.