質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.51%

  • CSS

    7542questions

    CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

  • SVG

    124questions

    SVGは、XMLを基盤とした2Dベクター画像記述言語。画像を線・面といった図形の集合体として扱うベクター画像のため、環境に適した表示が可能です。アニメーション機能もサポートされており、簡単なインタラクティブコンテンツ作成もできます。

  • font

    115questions

    近年は、コンピュータ上、紙面上で利用できる書体データのことをfontといいます。数える時の単位は「書体」で、データとしてのフォントは、デジタルフォントと呼ばれる場合があります。 HTML/CSSでは要素を指定し、フォント情報を調整することができます。

Font Awesomeのsvgファイルから1画像だけ抜き出して利用したい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 1,996

solight

score 7

Font Awesomeを利用して、アイコンを表示しようとしています。

クライアントの都合で、<input type="button">にアイコンを出す必要があり、かつinputのvalueにはシステムのサニタイズのためか、\f061や&#xf061;は使用できないため、inputのbackgroundにsvgを表示する方法を検討しています。

Font Awesomeが配布しているfontawesome-webfont.svgはAdobe Illustratorで確認できるような画像群ではなく、svgのコードが列挙されているようなのですが、ここから単品だけを抜き出してinputのbackgroundとして利用することは可能でしょうか?

それともfontawesome-webfont.svgはこちらでわざわざツールなどで1アイコンずつに分離しないと利用できないファイルなんでしょうか。

詳しい方いらっしゃいましたら、よろしくお願いいたします。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

+1

SVGはただのテキストファイル(XMLファイル)ですので、適当なテキストエディタで編集することが可能です。できそうな方法を二つ紹介します。

  1. <glyph unicode="&#xf061;" .../>の部分以外の<missing-glyph .../><glyph .../>を削除し、適当な<text ...>&#xf061;</text>を追加する。
    もともと<font>...</font>はSVG内で使うフォントの設定であるため、その本来の使い方をします。ただ、何かが足りないのか私はうまく作れませんでした。下記の参考ページによると旧Opera以外では動かないようですので、この方法は難しいかも知れません。
    参考: 16.フォント定義 - svg要素の基本的な使い方まとめ
  2. <glyph unicode="&#xf061;" .../><path .../>に変えて使う。
    文字(glyph)もただの線(path)です。線の定義であるd属性の書き方も同じです。ですので、そのまま<path .../>にしてしまいます。
    一応chromeでSVG単体はうまく表示できました。

ということで、するのであれば2.の方法でしょうか。とりあえずサンプルを下に載せます。

<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 -256 1792 1792">
<!--
This image uses the font glyph of the following library .
Font Awesome 4.6.3 by @davegandy - http://fontawesome.io - @fontawesome
License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License)
-->
<path d="M1472 576q0 -54 -37 -91l-651 -651q-39 -37 -91 -37q-51 0 -90 37l-75 75q-38 38 -38 91t38 91l293 293h-704q-52 0 -84.5 37.5t-32.5 90.5v128q0 53 32.5 90.5t84.5 37.5h704l-293 294q-38 36 -38 90t38 90l75 75q38 38 90 38q53 0 91 -38l651 -651q37 -35 37 -90z" />
</svg>


実寸大ははかなり大きいですので、大きさ等は適当に変更してください。ベクトル画像のため、SVG上で縮小しても綺麗なままです。カスタマイズにはSVGの知識はそれなりに必要になりますが、ここまで来ればAdobe Illustratorでも直接編集できると思います。

なお、フォントの一つ一つの文字も著作権で保護されています。FontAwesome Licenseを参照の上、どこかでライセンス提示を行うこと(通常のFontAwesomeではCSS内で提示している)、作られたSVGもコピーレフトの制限を受ける場合があることに注意してください。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

同じタグがついた質問を見る

  • CSS

    7542questions

    CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

  • SVG

    124questions

    SVGは、XMLを基盤とした2Dベクター画像記述言語。画像を線・面といった図形の集合体として扱うベクター画像のため、環境に適した表示が可能です。アニメーション機能もサポートされており、簡単なインタラクティブコンテンツ作成もできます。

  • font

    115questions

    近年は、コンピュータ上、紙面上で利用できる書体データのことをfontといいます。数える時の単位は「書体」で、データとしてのフォントは、デジタルフォントと呼ばれる場合があります。 HTML/CSSでは要素を指定し、フォント情報を調整することができます。