2012-02-08 2 views
1

これは、graph paperを生成するsvgの解釈を助ける必要があります。svgを生成するグラフ紙を解釈するには?

私は、コードの後ろに一般的な考え方を理解すると思う:

  • が、元の長方形を持っているそのうちの一つに作成されている3層/グループ、
  • 翻訳があると操作を変換するために使用されるように見えますこの矩形をキャンバス全体に複製します。

しかし、私はsvgコードの背後にいくつかの詳細を理解するのは難しいです。

また、どのようにレイヤーが相互に作用するのかわかりません。

質問

  • どのようにtransform="matrix(0,1,-1,0,400,0)"操作を解釈するのですか?
  • 長方形をコピーするこのsvgコードに含まれる暗黙のfor-loopについて説明できますか?
  • pathタグはこのコードのコンテキストで何をしますか?

私はこのsvgコードを十分に理解しようとしていますので、私自身の用途のために変更することができます。 ありがとうございます。

<?xml version="1.0" encoding="UTF-8" standalone="no"?> 
<!-- Created with Inkscape (http://www.inkscape.org/) --> 
<svg 
    xmlns:svg="http://www.w3.org/2000/svg" 
    xmlns="http://www.w3.org/2000/svg" 
    xmlns:xlink="http://www.w3.org/1999/xlink" 
    version="1.0" 
    width="400" 
    height="400" 
    id="svg2180"> 
    <defs 
    id="defs2182" /> 
    <g 
    style="opacity:1;display:inline" 
    id="layer1"> 
    <g 
     style="stroke:#a9a9a9;stroke-opacity:1" 
     id="g8191"> 
     <path 
     d="M 20,0 L 20,400" 
     style="fill:none;fill-rule:evenodd;stroke:#a9a9a9;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" 
     id="path1872" /> 
     <use 
     transform="translate(20,0)" 
     style="stroke:#a9a9a9;stroke-opacity:1" 
     id="use8185" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#path1872" /> 
     <use 
     transform="translate(40,0)" 
     style="stroke:#a9a9a9;stroke-opacity:1" 
     id="use8187" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#path1872" /> 
     <use 
     transform="translate(60,0)" 
     style="stroke:#a9a9a9;stroke-opacity:1" 
     id="use8189" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#path1872" /> 
    </g> 
    <use 
     transform="translate(100,0)" 
     id="use8197" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#g8191" /> 
    <use 
     transform="translate(200,0)" 
     id="use8199" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#g8191" /> 
    <use 
     transform="translate(300,0)" 
     id="use8201" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#g8191" /> 
    <use 
     transform="matrix(0,1,-1,0,400,0)" 
     id="use8203" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#g8191" /> 
    <use 
     transform="translate(0,100)" 
     id="use8205" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#use8203" /> 
    <use 
     transform="translate(0,200)" 
     id="use8207" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#use8203" /> 
    <use 
     transform="translate(0,300)" 
     id="use8209" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#use8203" /> 
    </g> 
    <g 
    style="display:inline" 
    id="layer2"> 
    <g 
     style="stroke:#366;stroke-opacity:1" 
     id="g8225"> 
     <path 
     d="M 100,0 L 100,400" 
     style="fill:none;fill-rule:evenodd;stroke:#366;stroke-width:1px;stroke-linecap:butt;stroke-linejoin:miter;stroke-opacity:1" 
     id="path8215" /> 
     <use 
     transform="translate(100,0)" 
     style="stroke:#366;stroke-opacity:1" 
     id="use8217" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#path8215" /> 
     <use 
     transform="translate(200,0)" 
     style="stroke:#366;stroke-opacity:1" 
     id="use8219" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#path8215" /> 
    </g> 
    <use 
     transform="matrix(0,1,-1,0,400,0)" 
     id="use8232" 
     x="0" 
     y="0" 
     width="400" 
     height="400" 
     xlink:href="#g8225" /> 
    </g> 
    <g 
    id="layer3"> 
    <rect 
     width="399" 
     height="399" 
     x="0.5" 
     y="0.5" 
     style="fill:none;stroke:#366;stroke-opacity:1" 
     id="rect10078" /> 
    </g> 
</svg> 

答えて

3

このドキュメントの「レイヤー」を間違って解釈しないでください。彼らは本当にレイヤリングについてではなく、グループ化についてです。

transform="matrix(0,1,-1,0,400,0)"の操作をどのように解釈しますか?

これはアフィン変換のためのtransformation matrixです。これは、回転、スキュー、および変換を1つの機能に組み合わせるファンシーな方法です。しかし、私は通常、それらを描画アプリケーションによって生成されたコードでのみ使用しています。

矩形をコピーするこのsvgコードに含まれる暗黙のfor-loopについて説明できますか?

SVGでは、<use .../>タグを使用して、IDを指定したオブジェクトをすべて再利用できます。これはDRYの一種として使用することができ、コードの繰り返しを低く抑えることができます。この場合、横線のグループが作成され、コピーはuseタグで参照されます。各useには、それを適切な場所に移動するための変換属性があります。リストの途中で、ライングループは(変換マトリックスを使用して)90度回転し、画像全体にコピーされます。

このコードではpathタグは何をしていますか?

ちょうど太い線を描くだけです。これはline要素で実行されている可能性がありますが、描画ソフトウェア出力はそれを置き換えるのに十分スマートではありませんでした。通常、円弧とベジェ曲線をサポートしているため、より複雑な図形には、path要素が使用されます。

+0

+1 - v.helpful - tyvm – kfmfe04

関連する問題