これは何
- SVGはベクター形式の画像を表現するためのマークアップ言語です
- 実際は1からコードを書いてグラフィックを作ることはなく、ベクターグラフィックのソフトから出力したものをそのまま使うことがほとんどです
- そんなSVG、ソフトによって書き出されるコードに違いはあるのかを調べてみました
検証ソフト一覧
ソフト名 | バージョン |
---|---|
Illustrator | 25.3.1 |
XD | 42.0.22.11 |
Sketch | 74.1 |
Figma | 99.0 |
Affinity Designer | 1.9.3 |
この検証のためだけに一度全てのソフトをアップデートしたので、2021/8/1現在での最新バージョン同士の比較のはずです。
比較する画像
こんな画像をそれぞれのソフトで作成してみます。
Qiitaにアップする都合上PNGに変換していますが、まぎれもなくベクターで作成しています。
四角、円、多角形、線と、SVGの基本的な要素をひとしきり確認できるように作成しました。
Illustrator
Illustratorは別名で保存したときとスクリーン用に書き出ししたときで結構コードが変わっていたので両方を掲載します。
aiファイルを別名で保存して生成されたコード
<?xml version="1.0" encoding="utf-8"?>
<!-- Generator: Adobe Illustrator 25.3.1, SVG Export Plug-In . SVG Version: 6.00 Build 0) -->
<svg version="1.1" id="レイヤー_1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" x="0px"
y="0px" viewBox="0 0 200 200" style="enable-background:new 0 0 200 200;" xml:space="preserve">
<style type="text/css">
.st0{fill:#FF0000;}
.st1{fill:#00FF00;}
.st2{fill:#0000FF;}
.st3{fill:none;stroke:#000000;stroke-width:2;stroke-miterlimit:10;}
.st4{fill:none;stroke:#CCCCCC;stroke-miterlimit:10;}
</style>
<g>
<rect class="st0" width="100" height="100"/>
</g>
<circle class="st1" cx="125" cy="125" r="75"/>
<g>
<polygon class="st2" points="166,155 80,155 123,80 "/>
</g>
<line class="st3" x1="20" y1="200" x2="20" y2="80"/>
<path class="st4" d="M30,50c27.6,0,50,22.4,50,50s-22.4,50-50,50"/>
</svg>
- xml宣言がされている
-
Illustratorによって生成されたファイルである
という旨のコメントが入っている -
xmlns
だけでなくxmlns:xlink
の指定もされている- これがあると無いとでどう違うのか正直分かっていません
- どなたかご存じの方がいたら是非教えてください
- レイヤー名がidとして指定されている
- 色や線の太さなどが
style
の中でまとめて宣言されている -
path
での座標指定が相対指定
スクリーン用に書き出し
<svg id="レイヤー_1" data-name="レイヤー 1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 200 200"><defs><style>.cls-1{fill:red;}.cls-2{fill:lime;}.cls-3{fill:blue;}.cls-4,.cls-5{fill:none;stroke-miterlimit:10;}.cls-4{stroke:#000;stroke-width:2px;}.cls-5{stroke:#ccc;}</style></defs><rect class="cls-1" width="100" height="100"/><circle class="cls-2" cx="125" cy="125" r="75"/><polygon class="cls-3" points="166 155 80 155 123 80 166 155"/><line class="cls-4" x1="20" y1="200" x2="20" y2="80"/><path class="cls-5" d="M30,50a50,50,0,0,1,0,100"/></svg>
- minifyされている
- しかしその割にはレイヤー名がidとして指定されている
- 半円のパスが
c
ではなくa
を使っている-
c
がベジェ曲線の指定 -
a
は円弧のときだけ使える指定 - 別名保存時は
c
が使われていた
-
XD
XDもexport時設定でminifyするかしないかを選べたので両方試してみました
minifyなし
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200" viewBox="0 0 200 200">
<defs>
<clipPath id="clip-Artboard">
<rect width="200" height="200"/>
</clipPath>
</defs>
<g id="Artboard" clip-path="url(#clip-Artboard)">
<rect width="200" height="200" fill="#fff"/>
<rect id="Rectangle_1" data-name="Rectangle 1" width="100" height="100" fill="red"/>
<circle id="Ellipse_1" data-name="Ellipse 1" cx="75" cy="75" r="75" transform="translate(50 50)" fill="lime"/>
<path id="Polygon_1" data-name="Polygon 1" d="M43,0,86,75H0Z" transform="translate(80 80)" fill="blue"/>
<line id="Line_1" data-name="Line 1" y2="120" transform="translate(20 80)" fill="none" stroke="#000" stroke-width="2"/>
<path id="Path_1" data-name="Path 1" d="M30,50a50,50,0,0,1,0,100" fill="none" stroke="#ccc" stroke-miterlimit="10" stroke-width="1"/>
</g>
</svg>
- clipPathが指定されている
- width, height, viewBoxあたりで幅と高さを指定している以上、あってもなくても描画は変わらない気がするものの、何か意図がある?
- アートボード自体の色(
#fff
)を出力している- 他のソフトではアートボードごと書き出してもアートボードの色は無視していた
- 全ての要素に
id
とdata-name
が付与されている-
id
はともかくdata-name
はなぜ必要なのか
-
- 座標指定 + transformで位置を制御している
- 直接描画に影響することはないと思うものの、なんだか怖い指定の仕方ではある
minifyあり
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="200" height="200" viewBox="0 0 200 200"><defs><clipPath id="b"><rect width="200" height="200"/></clipPath></defs><g id="a" clip-path="url(#b)"><rect width="200" height="200" fill="#fff"/><rect width="100" height="100" fill="red"/><circle cx="75" cy="75" r="75" transform="translate(50 50)" fill="lime"/><path d="M43,0,86,75H0Z" transform="translate(80 80)" fill="blue"/><line y2="120" transform="translate(20 80)" fill="none" stroke="#000" stroke-width="2"/><path d="M30,50a50,50,0,0,1,0,100" fill="none" stroke="#ccc" stroke-miterlimit="10" stroke-width="1"/></g></svg>
- minifyされている
- その割に相変わらず
clipPath
やtransform
が使われている
- その割に相変わらず
- idが
a
とかb
とかに置き換えられている- サンプルで作った画像がかなり簡易なものなので、このまま
c
,d
...と増えていくのか、z
以降はどうなるのかなどは謎
- サンプルで作った画像がかなり簡易なものなので、このまま
Sketch
<?xml version="1.0" encoding="UTF-8"?>
<svg width="200px" height="200px" viewBox="0 0 200 200" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
<title>Artboard</title>
<g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
<g id="Artboard">
<rect id="Rectangle" fill="#FF0000" x="0" y="0" width="100" height="100"></rect>
<circle id="Oval" fill="#00FF00" cx="125" cy="125" r="75"></circle>
<polygon id="Triangle" fill="#0000FF" points="123 80 166 155 80 155"></polygon>
<line x1="20" y1="80" x2="20" y2="200" id="Line" stroke="#000000" stroke-width="2" stroke-linecap="square"></line>
<path d="M30,150 C57.6142375,150 80,127.614237 80,100 C80,72.3857625 57.6142375,50 30,50" id="Path" stroke="#CCCCCC"></path>
</g>
</g>
</svg>
- xml宣言がある
-
xmlns
だけでなくxmlns:xlink
の指定もされている -
title
が指定されている- アートボード名がtitleになっている様子
- ページとアートボード、両方の単位で
g
が生成されている
Figma
<svg width="200" height="200" viewBox="0 0 200 200" fill="none" xmlns="http://www.w3.org/2000/svg">
<rect width="100" height="100" fill="#FF0000"/>
<circle cx="125" cy="125" r="75" fill="#00FF00"/>
<path d="M123 80L166 155H80L123 80Z" fill="#0000FF"/>
<line x1="21" y1="80" x2="21" y2="200" stroke="black" stroke-width="2"/>
<path d="M30 150C57.6142 150 80 127.614 80 100C80 72.3858 57.6142 50 30 50" stroke="#CCCCCC"/>
</svg>
- インデントがない
-
g
でまとまっていない - 多角形を
polygon
でなくpath
で描画している - かなりさっぱりしていて、個人的には1番好きなコード
Affinity Designer
エクスポート設定が4種類あったので、それぞれを比較してみました。
for export
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg width="100%" height="100%" viewBox="0 0 200 200" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:1.5;">
<rect id="Artboard" x="0" y="0" width="200" height="200" style="fill:none;"/>
<clipPath id="_clip1">
<rect id="Artboard1" serif:id="Artboard" x="0" y="0" width="200" height="200"/>
</clipPath>
<g clip-path="url(#_clip1)">
<g transform="matrix(1.13106,0,0,1.13106,-42.9822,-36.1368)">
<rect x="38.002" y="31.95" width="88.413" height="88.413" style="fill:rgb(255,0,0);"/>
</g>
<g transform="matrix(1.65719,0,0,1.65719,-55.9655,-45.3328)">
<circle cx="109.2" cy="102.784" r="45.257" style="fill:rgb(0,255,0);"/>
</g>
<g transform="matrix(1.60005,0,0,1.39539,-43.8979,-59.5392)">
<path d="M104.308,100L131.182,153.748L77.434,153.748L104.308,100Z" style="fill:rgb(0,0,255);"/>
</g>
<g transform="matrix(1,0,0,1.07417,-3.46616,-14.8334)">
<path d="M23.466,88.286L23.466,200" style="fill:none;stroke:black;stroke-width:1.93px;"/>
</g>
<g transform="matrix(1.10479,0,0,1.10479,-90.6436,-13.5552)">
<path d="M109.2,57.527C134.178,57.527 154.457,77.806 154.457,102.784C154.457,127.762 134.178,148.041 109.2,148.041" style="fill:none;stroke:rgb(204,204,204);stroke-width:0.91px;stroke-linecap:round;"/>
</g>
</g>
</svg>
- 非推奨である
DOCTYPE
宣言がされている - 各要素が全て
g
で括られている - 幅や高さ、座標指定がなんだかおかしなことになっている
- 要素を括っている
g
にtransform
がついていて、それで調整している - 少し怖い設定である
- 要素を括っている
small size
<?xml version="1.0" encoding="UTF-8" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg width="100%" height="100%" viewBox="0 0 200 200" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:1.5;"><rect id="Artboard" x="0" y="0" width="200" height="200" style="fill:none;"/><clipPath id="_clip1"><rect id="Artboard1" serif:id="Artboard" x="0" y="0" width="200" height="200"/></clipPath><g clip-path="url(#_clip1)"><rect x="0" y="0" width="100" height="100" style="fill:#f00;"/><circle cx="125" cy="125" r="75" style="fill:#0f0;"/><path d="M123,80l43,75l-86,-0l43,-75Z" style="fill:#00f;"/><path d="M20,80l0,120" style="fill:none;stroke:#000;stroke-width:2px;"/><path d="M30,50c27.596,0 50,22.404 50,50c0,27.596 -22.404,50 -50,50" style="fill:none;stroke:#ccc;stroke-width:1px;stroke-linecap:round;"/></g></svg>
- 非推奨である
DOCTYPE
宣言がされている - 各要素を囲う
g
要素が消えている- おかげで(?)座標やサイズも自然になっている
- 多角形を
polygon
でなくpath
で描画している
high quality
<?xml version="1.0" encoding="UTF-8" standalone="no"?><!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd"><svg width="100%" height="100%" viewBox="0 0 834 834" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:1.5;"><rect id="Artboard" x="0" y="0" width="833.333" height="833.333" style="fill:none;"/><clipPath id="_clip1"><rect id="Artboard1" serif:id="Artboard" x="0" y="0" width="833.333" height="833.333"/></clipPath><g clip-path="url(#_clip1)"><rect x="0" y="0" width="416.667" height="416.667" style="fill:#f00;"/><circle cx="520.833" cy="520.833" r="312.5" style="fill:#0f0;"/><path d="M512.5,333.333l179.167,312.5l-358.334,0l179.167,-312.5Z" style="fill:#00f;"/><path d="M83.333,333.333l0,500" style="fill:none;stroke:#000;stroke-width:8.33px;"/><path d="M125,208.333c114.982,0 208.333,93.351 208.333,208.334c0,114.982 -93.351,208.333 -208.333,208.333" style="fill:none;stroke:#ccc;stroke-width:4.17px;stroke-linecap:round;"/></g></svg>
- 非推奨である
DOCTYPE
宣言がされている - どういうわけか、
viewBox
の値が834
になっている- もともとは
200
で作っていて、他のデータは全て200
のまま - すべてのサイズが約4.17倍になっているもよう
- 理由がよく分からないので、分かる方がいたら是非教えてください
- もともとは
flatten
<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd">
<svg width="100%" height="100%" viewBox="0 0 200 200" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" xml:space="preserve" xmlns:serif="http://www.serif.com/" style="fill-rule:evenodd;clip-rule:evenodd;stroke-linejoin:round;stroke-miterlimit:1.5;">
<use xlink:href="#_Image1" x="0" y="0" width="200px" height="200px"/>
<defs>
<image id="_Image1" width="200px" height="200px" xlink:href=""/>
</defs>
</svg>
- 非推奨である
DOCTYPE
宣言がされている - base64に変換されている
- 初めて見た形式
-
use
が使用されている
まとめ
- ちょっとした内容の書き出しでも、ソフトによって結構差がある
- 微妙に意図しない表示になったり、拡大したらわずかな隙間が空くんじゃ無いか……?と思えるものもあった
-
transform
が多用されているデータが怪しく感じている
-
- 1番すっきりしているのはFigma
- 1番内容が多いのはAffinity Designerのflatten
- なんと今回の画像で容量が8KB