Scalable Vector Graphics
テンプレート:WikipediaPage テンプレート:Infobox file format Scalable Vector Graphics(スケーラブル・ベクター・グラフィックス、SVG)は、XMLをベースとした、2次元ベクターイメージ用の画像形式の1つである。アニメーションやユーザインタラクションもサポートしている。SVGの仕様はW3Cによって開発され、オープン標準として勧告されている。
目次
沿革
1998年に発足した W3C SVG ワーキンググループにより開発された。しかし、その時点でマクロメディアとマイクロソフトが VML 、アドビシステムズとサン・マイクロシステムズが PGML として知られる競合形式を提案していた。
- 2001年9月4日 - SVG 1.0 が W3C 勧告となる
- 2003年1月14日 - SVG 1.1 が W3C 勧告となる
- 2003年1月14日 - SVG Tiny と SVG Basic (モバイル SVG プロファイル)が W3C 勧告となる
- 2008年12月22日 - SVG Tiny 1.2 が W3C 勧告となる
- 2011年8月16日 - SVG 1.1 (Second Edition) が W3C 勧告となる
特徴
XML で記述する為、ブラウザ上で閲覧でき、テキストエディタ等で編集することができる。また、ハイパーリンクを画像中に埋め込んだり、JavaScript 等と連携させることもできる。ベクターイメージであるため、ベクターデータによる画面表示では拡大や縮小をしても描写の劣化が起きない。画像データの画面表示はブラウザのプラグインによって色調補完を行ないドット落ちを補正する機能を持つものがある。
編集
SVG は、拡張の自由度が高い XML (テンプレート:En) で記述されており、XML ならではの各種機能を定義した要素を持つ。SVG ではそれ自身に回転・拡大・移動などの表現を定義しているため、単体で多様な表現をすることが可能である。
従来のウェブサイトでは、いわゆるインタラクティブな双方性のある画面変化を伴う表示を JavaScript や FLASH を用いてきた。HTML/XHTML に SVG を組み合わせることにより、JavaScript や FLASH を導入せずとも同様の効果が発揮されることが期待される。
XML なので、原理的には専用のアプリケーションを用いることなく通常の文章として作製・編集できる。
レイヤー
SVG の特筆すべき点としてレイヤー機能がある。SVG では写真や挿絵などのビットマップデータ部分と座標値で指定された円・線分等を組み合わせた図形をベクターデータ部分として個々に指定でき、互いの苦手とする部分を補完しながら共存して画面表示できる。
- ビットマップデータ: 写真・挿絵・統計グラフ
- ベクターデータ: 円弧・線分・点・文字・統計グラフ
SVG では文字をベクター情報の領域に有することで拡大縮小した際にはアウトラインフォントで表現する。この機能により、拡大するとジャギーと呼ばれる文字外延部のギザギザが生じて見にくくなる点が解決されている。具体的には Adobe Acrobat による PDF 形式の文字とほぼ同じ機能を有する。
これらのレイヤー機能により、背景に写真などの画像を置き、ベクターデータによる線画や文字を配置させることが可能である。具体的には等高線を表示した地図画像(ビットマップ)の上に鉄道路線や道路網(ベクターデータ)を重ね、電車や自動車等の移動体を配置して同時表示が可能になる。更に、ベクターデータのみで表現した塗りつぶしでは色の重ね合わせが可能であり、塗りつぶしの透過度の指定により集合論で用いるベン図のような形を必要最低限度の色数で表現できる。
ファイル形式
基本的に SVG は MIME 形式指定では image/svg+xml で指定された画像フォーマットである。ファイルの拡張子は .svg と gzip 圧縮された .svgz がある。拡張子 .svg はテキストファイルであるため、大きなデータではネット間の通信トラフィックにおいてのデメリットが大きいが、圧縮した .svgz では数分の一のファイルサイズになる。展開機能はWebブラウザ側が受け持つ。
親和性
SVG は基本的に文章で構成されており、ブラウザの利用者が入力した情報を CGI や Javascript を介して SVG データに組み入れることが可能である。これにより、ベクターデータを用いた統計グラフでは可変性のある表示が可能になる。
長所
文書で制作できるため、独自タグを用いることで高品質な表現が可能である。文字情報は文字データのみを明示的にグループ化しているため、文字のグループのみを抽出することで多言語化が比較的容易にできる。
欠点
ビットマップデータの大きさは各形式によってある程度左右されるが、ほぼ面積比によってある程度のサイズに納まることが多い。それに対し、ベクターデータは画面表示サイズに関わらず全ての情報を常に保持し続けるため、表示情報が多い場合はビットマップデータよりもサイズが大きくなる傾向がある(ただし、これはベクターデータ形式全般に言えるものであり、SVG のみの欠点ではない)。
規格の概要
- SVG 1.1
- SVG Tiny
- SVG Basic
現状
SVG は版を重ねるごとに高度な機能を盛り込んでいる。1.1 版以降から、格納しようとする描画情報に当該情報が使用している座標参照系をメタデータとして記述することが可能となった。これにより、SVG を地図として利活用できる道ができ、国土地理院ではその保有する電子国土基幹情報を SVG で配信し、PC のみならず様々な媒体で活用する方法を提案して広く社会実験に供する試みを実施している。
一方で、SVG の高度な機能を用いるものでは、それに対応した編集ツールや、データを忠実に再現してくれるビューアやブラウザのプラグイン等が必須となる。高度な機能を持ちつつも、それを活かせるインフラが追いついていないのが現状である。
これとは別に、比較的利用頻度の高い重要な機能に絞り込み、小型機器にも搭載可能な軽量な規格も登場している。
SVG 編集ソフト
SVG は XML を用いているのでテキストエディタによるデータの作成も一応可能であるが、記述は非常に複雑なため実用的には GUI を前提にした編集ソフトが必須となる。
用途により、高度なグラフィクス作成に主眼を置いた描画ソフトから図、表、フローチャートなどの作成に主眼を置いたソフトまで幅がある。
- SVG を標準データとして扱い、読み書きが可能なもの
- SVG Cats - SVG Cats 製品紹介ページ
- Inkscape - Inkscape ホームページ
- SVG の読み書きが可能なもの
- 一部制限があるもの
- GIMP - 読み込みに対応。書き出しはパスの書き出しのみ。
- SVG の出力が可能なもの
- 花子2006は、SVG (Ver.1.0 に準拠) の書き出しに対応。
- OpenOffice Draw - 1.1 までは日本語出力が一部乱れるなど難あり。2.0 から書き出しに対応。SVG Import Filterを導入すれば読み込みも可能。
- Omni GroupのOmniGraffle Professional 4 は、SVG 書き出しに対応。
- R はデータ解析結果のグラフ出力形式として SVG に対応。
- Gnuplot および GNU Plotutils は、プロットの出力形式として SVG に対応。
この他、CAD ソフトウエアには読み書きともに対応しているものが多く存在する。
ブラウザによる SVG 画像の表示
2011年現在、パソコン用の主要ブラウザでネイティブサポートされている。しかし、Internet Explorer 8 以前のマイクロソフト製のレンダリングエンジンを用いているブラウザでは対応していない。これに対し、Internet Explorer 9 以上に移行するか、第三者製のプラグインを用いることで、SVG 画像を表示させることができる。
ネイティブサポート
- Internet Explorer 9 は、SVG 1.1 に標準対応している[1]。
- Firefox (Gecko) では、Firefox 1.5 から対応している。
- Google Chrome は最初のバージョンから対応。
- Android ブラウザは Android 3.0 から対応
- Safari は、Safari 3.0 から SVG 1.1 に完全ではないが対応した[2]。対応状況は環境毎に異なる。
- OS X - バージョン 3.1.2 の時点で、カラープロファイルなど一部機能を未実装。現状の対応状況は、WebKit SVG Status。
- Mobile - iPhone OS 2.1 の Mobile Safari で SVG に対応した。
- Windows - Safari 3.1.2 現在、フィルタなど一部の機能を除いて、実装している。
- Opera および Opera Mobile は2005年4月に発表された Opera v8.0 で SVG Tiny に、2006年発表の v9.0 で SVG Basic に対応した。
- Opera Mini は 5 から対応。
- NetFront Browser - 未対応
- KDE の Konqueror は KSVG を使って表示させることができる。
- W3C の Amaya が標準対応している。
プラグインサポート
- Adobe - Adobe SVG Viewer。Internet Explorer や Netscape 向け。
- Adobe SVG Viewer は2009年1月1日にサポートを終了と発表した。配布の終了は未定である[1]。
- Corel - Corel SVG Viewer
- GNOME - Mozilla 向けにプラグインの librsvg
- Examotion(開発元が Emia Systems から移った) - Renesis Player
- SVG MAP コンソーシアム - 2007年9月6日に地図表示のための拡張機能を備えた SVG Viewer であるSVG Map Toolkitの提供を開始した。
デスクトップ
GNU/Linux 系などの Unix 系 OSでは、Freedesktop.org の標準に採用されるなど、様々な利用がされている。GNOME は librsvg を使いアイコンや壁紙に SVG を利用でき、また、KDE では KSVG を利用してアイコンを表示できるほか 3.4 からは SVG を使った壁紙に対応した。
Windows 系では2007年現在では特に動きはない。
脚注
関連項目
- Adobe Flash (Macromedia Flash)
- Apache Batik
- テンプレート:仮リンク
- Commons:SVG変換
- テンプレート:仮リンク
- Computer Graphics Metafile (CGM)
- Direct2D
- Extensible Markup Language (XML)
- テンプレート:仮リンク
- テンプレート:仮リンク
- テンプレート:仮リンク
- PostScript (PS)- ベクタ形式の画像フォーマット
- Encapsulated PostScript (EPS) - ベクタ形式の画像フォーマット
- テンプレート:仮リンク
- テンプレート:仮リンク
- テンプレート:仮リンク
- テンプレート:仮リンク
- テンプレート:仮リンク
- WYSIWYG
- Windows Metafile (WMF, EMF) - ベクタ形式の画像フォーマット
- ビットマップ画像(ラスターグラフィック)
- ベクターイメージ
外部リンク
- W3C の SVG 公式サイト
- Adobe to Discontinue Adobe SVG Viewer
- Open Clip Art Library -パブリックドメインの SVG グラフィック配布サイト
- SVG MAP コンソーシアム
- SVG 実習マニュアル (PDF)
テンプレート:W3C標準 テンプレート:Graphics file formats
テンプレート:Web interfacesテンプレート:Link GA