6
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

ベクターグラフィックソフトから書き出されるSVGのコードを比較してみた

Last updated at Posted at 2021-08-01

これは何

  • 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)を出力している
    • 他のソフトではアートボードごと書き出してもアートボードの色は無視していた
  • 全ての要素にiddata-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されている
    • その割に相変わらずclipPathtransformが使われている
  • 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で括られている
  • 幅や高さ、座標指定がなんだかおかしなことになっている
    • 要素を括っているgtransformがついていて、それで調整している
    • 少し怖い設定である

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
6
6
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
6
6

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?