ウェブへのベクターグラフィックの追加
ベクターグラフィックは多くの状況でとても便利です。ファイルサイズは小さく、スケーラビリティが高いため、ズームインしたり、大きなサイズに拡大したりしてもモザイクになりません。この記事では、ウェブページにそれを組み込む方法を説明します。
前提条件: | HTML の基本と、 画像を文書に挿入する方法を理解しておく必要があります。 |
---|---|
目的: | SVG (ベクター)画像をウェブページに埋め込む方法を学びます。 |
メモ: この記事は SVG を教えるためのものではありません。 SVG が何であるかと、ウェブページに追加する方法について説明します。
ベクターグラフィックとは何か?
ウェブ上では、ラスター画像とベクター画像の 2 種類の画像を扱います。
- ラスター画像は、ピクセルのグリッド (格子) を使用して定義されます。 — ラスター画像ファイルには、各ピクセルの配置場所を正確に示す情報と、その色を正確に示す情報が含まれています。一般的なウェブのラスター形式には、ビットマップ (
.bmp
)、 PNG (.png
)、 JPEG (.jpg
)、 GIF (.gif
) などがあります。 - ベクター画像はアルゴリズムを使用して定義されます。 — ベクター画像ファイルにはシェイプ (形状) とパス (経路) の定義が含まれており、画面に描画されるときに画像がどのような外見になるかを、コンピューターが理解するために利用することができます。 SVG 形式では、ウェブ上で使用するための強力なベクターグラフィックを作成することができます。
両者の違いを知るために、例を見てみましょう。この例は、 GitHub のリポジトリーで vector-versus-raster.html として公開されています。 — これは、2 つの一見同一の黒い影付きの赤い星の画像を並べて表示しています。違いは、左のものが PNG 画像であり、右のものが SVG 画像であるということです。
この違いは、ページをズームインすると明らかになります。 PNG 画像には、各ピクセルの位置(と色)に関する情報が含まれているため、ズームインするとピクセル化されます。 ズームインすると、各ピクセルのサイズが単純に拡大され、画面上の複数のピクセルが塗りつぶされるので、画像がギザギサに見えるようになります。 しかし、ベクター画像は大きさにかかわらず、アルゴリズムが画像内のシェイプを処理するために使用され、値が大きくなるにつれて単純に縮尺が変更されるため、きれいにくっきりと見えます。
メモ: 上の画像は実際には全て PNG です — いずれの場合も、左の星はラスター画像を表し、右の星はベクター画像を表します。 実際の例については、vector-versus-raster.html デモを参照してください!
さらに、ベクター画像ファイルは、画像内のすべてのピクセルの情報ではなく、一握りのアルゴリズムを保持するだけで済むので、ラスター同等物よりもはるかに軽くなります。
SVG とは何か?
SVG は、ベクター画像を記述するための XML ベースの言語です。これは基本的に HTML のようなマークアップですが、画像に表示するシェイプを定義するためのさまざまな要素と、それらのシェイプに適用する効果があります。 SVG は、コンテンツではなくグラフィックをマークアップするためのものです。SVG は <circle>
や <rect>
のような基本図形を作成する要素と、 <path>
や <polygon>
のようなより複雑な図形を作成する要素を定義します。 <feColorMatrix>
(変換行列を使用して色を変換)、 <animate>
(ベクターグラフィックの一部をアニメーション化)、 <mask>
(画像の上にマスクを適用する) など、より高度な SVG の機能もあります。
基本的な例として、次のコードは円形と長方形を作成します。
<svg
version="1.1"
baseProfile="full"
width="300"
height="200"
xmlns="http://www.w3.org/2000/svg">
<rect width="100%" height="100%" fill="black" />
<circle cx="150" cy="100" r="90" fill="blue" />
</svg>
これにより、次の出力が生成されます。
上記の例から、 SVG が手作業で簡単に書けるという印象を受けるかもしれません。実際、単純な SVG ならばテキストエディターで手作業で記述することはできますが、複雑な画像では、すぐにとても困難になり始めます。 SVG 画像を作成するには、ほとんどの人が Inkscape や Illustrator のようなベクターグラフィックエディターを使用します。これらのパッケージでは、さまざまなグラフィックツールを使用してさまざまなイラストを作成したり、写真に近似したもの(たとえば、 Inkscape のトレースビットマップ機能)を作成したりすることができます。
SVG にはこれまで説明したもの以外にも、いくつかの長所があります。
- ベクター画像のテキストはアクセス可能です。(SEO にも役立ちます)。
- SVG はスタイル設定やスクリプティングに適しています。 これは、画像の各コンポーネントが、 CSS を使用してスタイルを設定したり、 JavaScript を使用してスクリプトを作成できるためです。
では、なぜ誰もが SVG よりもラスターグラフィックを使いたがるのでしょうか?実際、SVG にはいくつかの短所があります。
- SVG はとてもすぐに複雑になり、ファイルサイズが大きくなる可能性があります。複雑な SVG もブラウザーでかなりの処理時間を要する可能性があります。
- SVG は、作成しようとしている画像の種類によっては、ラスター画像よりも作成するのが難しい場合があります。
ラスターグラフィックは、前述の理由から、写真などの複雑な高精度画像に対しては、ほぼ間違いなく優れています。
メモ: Inkscape では、スペースを節約するためにファイルを Plain SVG として保存してください。 また、ウェブ用の SVG を作成する方法について説明しているこの記事 (英語) を参照してください。
ページへの SVG の追加
この節では、SVG ベクターグラフィックをウェブページに追加するさまざまな方法を説明します。
簡単な方法: img
要素
<img>
要素を介して SVG を埋め込むには、予想通り、 src
属性で参照する必要があります。 height
属性または width
属性 (または SVG に固有のアスペクト比がない場合は両方) が必要です。まだHTML の画像を終了していない人は、こちらをお読みください。
<img
src="equilateral.svg"
alt="triangle with all three sides equal"
height="87"
width="100" />
長所
- すばやく、使い慣れた画像構文で、
alt
属性で利用することができる組み込みのテキストと等価です。 <a>
要素の中に<img>
を入れることで、画像を簡単にハイパーリンクにすることができます。- SVG ファイルはブラウザーにキャッシュされるため、将来その画像を使用するページが読み込まれた場合、読み込み時間が短縮されます。
短所
- JavaScript で画像を操作することはできません。
- CSS で SVG コンテンツを制御する場合は、SVG コードにインライン CSS スタイルを含める必要があります。(SVG ファイルから呼び出された外部スタイルシートは効果がありません。)
- CSS の擬似クラス(
:focus
など)で画像のスタイルを変更することはできません。
トラブルシューティングと複数ブラウザーの対応
SVG に対応していないブラウザー(IE 8 以前、Android 2.3 以前)では、 src
属性から PNG または JPG を参照し、 srcset
属性(最近のブラウザーのみが認識する)を使用して SVG を参照するようにすることができます。 この場合、対応しているブラウザーのみが SVG を読み込みます。古いブラウザーは代わりに PNG を読み込みます。
<img src="equilateral.png" alt="辺が等しい三角形" srcset="equilateral.svg" />
以下に示すように、 SVG を CSS の背景画像として使用することもできます。 以下のコードでは、古いブラウザーでは理解できる PNG を使用しますが、新しいブラウザーでは SVG を読み込みます。
background: url("fallback.png") no-repeat center;
background-image: url("image.svg");
background-size: contain;
上記の <img>
方式と同様に、 CSS 背景画像を使用して SVG を挿入すると、 SVG を JavaScript で操作することができず、同じ CSS の制限が適用されます。
SVG がまったく表示されない場合は、サーバーが正しく設定されていない可能性があります。それが問題なら、この記事が正しい方向へ導いてくれます。
HTML の中に SVG コードを組み込む方法
テキストエディターで SVG ファイルを開き、 SVG コードをコピーして HTML 文書に貼り付けることもできます。 これは、SVG をインラインにする、または SVG をインライン化するとも呼ばれます。 SVG コードスニペットは、 <svg>
開始タグで始まり、 </svg>
終了タグで終わることを確認してください。文書に貼り付けることのできる簡単な例を次に示します。
<svg width="300" height="200">
<rect width="100%" height="100%" fill="green" />
</svg>
長所
- SVG をインラインで配置すると、 HTTP リクエストが節約されるので、読み込み時間が少し短縮されます。
class
とid
を SVG 要素に割り当て、 SVG 内または HTML 文書の CSS スタイル規則を置く場所で、CSS でスタイルを設定することができます。 実際には、任意の SVG プレゼンテーション属性を CSS プロパティとして使用できます。- SVG のインライン化は、CSS の相互作用(
:focus
など)と CSS アニメーションを(通常のスタイルシートでも) SVG 画像に使用できる唯一のアプローチです。 - SVG マークアップを
<a>
要素で囲むことでハイパーリンクにすることができます。
短所
- この方法は、SVG を 1 か所だけで使用している場合にのみ適しています。重複させると、メンテナンスにリソースがかかるようになります。
- 余分な SVG コードは HTML ファイルのサイズを増加させます。
- ブラウザーは、通常の画像をキャッシュするようにインライン SVG をキャッシュすることはできません。
<foreignObject>
要素に代替コンテンツを含めることはできますが、 SVG に対応するブラウザーでは代替画像が引き続きダウンロードされます。余分なオーバーヘッドが本当に価値があるかどうかは、陳腐化したブラウザーに対応するかどうかで判断する必要があります。
SVG を iframe
で埋め込む方法
SVG 画像は、ウェブページのようにブラウザーで開くことができます。 したがって、SVG 文書を <iframe>
に埋め込むことは、<object> から <iframe> まで — その他の埋め込み技術で学んだように行われます。
ここで簡単なレビューです。
<iframe src="triangle.svg" width="500" height="500" sandbox>
<img src="triangle.png" alt="3つの不等辺の三角形" />
</iframe>
これは間違いなく選択するには最良の方法ではありません。
短所
- ご覧のとおり、
iframe
には代替メカニズムがありますが、iframe
に完全に対応していない場合にのみ、ブラウザーに代替コンテンツが表示されます。 - さらに、 SVG と現在のウェブページが同じオリジンを持っていない限り、メインウェブページで JavaScript を使用して SVG を操作することはできません。
アクティブラーニング: SVG で遊ぶ
このアクティブラーニングの節では、 SVG をとても楽しく遊ぶことができます。 下の入力セクションでは、始めるためのサンプルをすでに提供していることがわかります。 また、SVG 要素のリファレンスにアクセスして、SVG で使用できる他のおもちゃの詳細を調べて、それらを試してみることもできます。 このセクションでは、あなたの研究スキルを鍛え、楽しく学びましょう。
コードが機能しなくなった場合は、 [リセット] ボタンを使用していつでもリセットすることができます。
まとめ
この記事では、ベクターグラフィックと SVG の概要、それらをなぜ知っておくと便利なのか、そして SVG をウェブページに組み込む方法について簡単に説明しました。 SVG を学ぶ上での完全なガイドとなることは決して考えられていませんでしたが、ウェブ上の旅行でそれに会っていれば、SVG が何であるかを知ることができます。 あなたがまだ SVG のエキスパートではないと感じたら心配しないでください。 もしそれがどう動くかについて詳しく知りたいなら助けになる以下のリンクを参考にしてください。
このモジュールの最後の記事では、レスポンシブ画像を詳細に調査し、さまざまな端末間で画像をより良く動作させるための HTML ツールについて説明します。
関連項目
- MDN の SVG チュートリアル
- Sara Soueidan のレスポンシブ SVG 画像に関するチュートリアル (英語)
- SVG のアクセシビリティ上の長所 (英語)
- SVG を縮尺変更する方法 (ラスターグラフィックほど簡単ではありません!) (英語)