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

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

新規登録して質問してみよう
ただいま回答率
85.48%
SVG

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

CSS

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

font

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

Q&A

解決済

1回答

5720閲覧

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

solight

総合スコア13

SVG

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

CSS

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

font

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

0グッド

0クリップ

投稿2016/09/06 21:35

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

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

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

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

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

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

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

1<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 -256 1792 1792"> 2<!-- 3This image uses the font glyph of the following library . 4Font Awesome 4.6.3 by @davegandy - http://fontawesome.io - @fontawesome 5License - http://fontawesome.io/license (Font: SIL OFL 1.1, CSS: MIT License) 6--> 7<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" /> 8</svg>

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

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

投稿2016/09/06 22:45

raccy

総合スコア21735

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問