data:image/s3,"s3://crabby-images/fd007/fd007a7de9671941ce52c2069f3509e5971e3afa" alt="見出し画像"
【保存版】SVG徹底解説!アニメーション・フルオンチェーンNFTを作ろう!
こんにちは、CryptoGamesの高橋です。
クリスペの会社で働いています。
本日は、アニメーション・フルオンチェーンNFTを作成するためにSVGについて学んでいきます。
なお、こちらの記事は無料で公開していますので、ご自由にご利用いただけます。
また、記事の作成にあたり、次の2つの記事を大いに参考にしました。
また、フルオンチェーンNFTの作成については、こちらの記事をご参照ください。
0 SVGとは?
svgとはXY座標で描画されたファイルです。
例えばこんな画像です。
data:image/s3,"s3://crabby-images/5356c/5356c5756c2c88c75f0b696166f208f54d00c158" alt="スクリーンショット 2021-12-19 9.30.40"
一見、pngファイルと同じようですが、実はこの中身は下のようなコードで書かれています。
<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'>
<path stroke="black" stroke-width="1" fill="none" d="M 0 0 L25 50" />
</svg>
data:image/s3,"s3://crabby-images/65445/654459aad9973f5ac7ff62aa1d7199088eaeb08a" alt="スクリーンショット 2021-12-19 9.33.23"
では、具体的にどのように描かれているのかを見てみましょう。ぜひ、ご自身でも「.svg」のsvgファイルを作ってみてください。
1 pathタグについて
図形を描く時には「path」タグを用います。「d=」以降で、どんな図形を描くのかを指定していきます。
なお、四角形、丸などの決まった形には別のタグを使う方が便利です。
data:image/s3,"s3://crabby-images/fd4a7/fd4a7ad9a1339770f56fb73f46294eb0b8e74eee" alt="スクリーンショット 2021-12-19 9.37.27"
ちなみに、上のように
① stroke > 線の色
② stroke-width > 線の太さ
③ fill > 塗りつぶしの色
を表します。
2 M(大文字)について(スタート位置)
大文字のMはスタートの位置を表します。
data:image/s3,"s3://crabby-images/56623/56623e5a4af0dc543fef24490ed1df9f3cce8adf" alt="スクリーンショット 2021-12-19 9.41.59"
つまり、この位置が(0,0)であることがわかりました。
data:image/s3,"s3://crabby-images/b1a71/b1a71702535665f1fa04b137301f78a443199036" alt="スクリーンショット 2021-12-19 9.43.50"
3 L(大文字)について(直線を引く)
大文字のLは直線を引くという意味です。
data:image/s3,"s3://crabby-images/f9308/f9308ec569fb2db9ec903cd400cad5c7f4c53eeb" alt="スクリーンショット 2021-12-19 9.46.33"
つまり、こんな感じだったのですね。
data:image/s3,"s3://crabby-images/b036b/b036bb5b3a3d929f16fd92157a19e05cafdde8fc" alt="スクリーンショット 2021-12-19 9.49.41"
4 l(小文字)について(直線を引く)
では、この下のように小文字のlにした場合、どうなるでしょうか。
data:image/s3,"s3://crabby-images/b80e3/b80e31247543976b644bae012874f028a1d79acf" alt="スクリーンショット 2021-12-19 9.54.45"
大文字 ⇨ 絶対参照
小文字 ⇨ 相対参照
になります。難しそうですが、言っていることは簡単です。
① L(50,0)
⇨(50,0)の場所に向かって線を引く
② l(50,0)
⇨今の場所から (50,0)の場所に向かって線を引く
data:image/s3,"s3://crabby-images/6d198/6d19868ce681658c71f6195cffc099467bdb79dd" alt="スクリーンショット 2021-12-19 10.02.30"
こんな風になりました。予想はあっていましたか??
5 m(小文字)について(スタート位置)
下についてはどのようになりますでしょうか。
data:image/s3,"s3://crabby-images/c9e0d/c9e0d7c6dbe6922ab60b8fa1aef642fcbdf24c26" alt="スクリーンショット 2021-12-19 10.03.09"
やはり小文字は相対参照なので、今の位置から(10,0)の位置がスタート位置になります。
data:image/s3,"s3://crabby-images/3dc41/3dc4166ba923111202158e4c88ba2e633dad4176" alt="スクリーンショット 2021-12-19 10.06.08"
6 Vについて(垂直線を引く)
大文字と小文字の関係については他も同じです。
ここからはわかりやすいように基本小文字でやっていきます。
data:image/s3,"s3://crabby-images/f70fe/f70fe8d893887e09b0b9b1915c21ce52ceb3ad67" alt="スクリーンショット 2021-12-19 10.09.54"
垂直に引くので、下のようになりました。
data:image/s3,"s3://crabby-images/6565b/6565bbfb96f02f4ccdfd1ca6ba9d6b4bf2bb8fca" alt="スクリーンショット 2021-12-19 10.11.09"
7 Hについて(水平線を引く)
Hは水平に引きます。
なお、こんな感じでマイナスの指定も可能です。
data:image/s3,"s3://crabby-images/5b147/5b147ddd0c8ac867719b9dc3e3e2730990f4bf03" alt="スクリーンショット 2021-12-19 10.13.02"
こんな感じで引けました。
data:image/s3,"s3://crabby-images/a4df9/a4df95d03375fa7cb6e3b049d096a3b0ead5a5b7" alt="スクリーンショット 2021-12-19 10.15.36"
8 Zについて(スタート位置に結ぶ)
zは直近のスタート位置(M,m)に直線で結びつけます。
data:image/s3,"s3://crabby-images/fb232/fb2324cbfb2fbf9fa6a0fb3e30b578d0b80b237c" alt="スクリーンショット 2021-12-19 10.18.46"
こんな感じですね。
data:image/s3,"s3://crabby-images/2a9b2/2a9b2ee5a9a471db6444bf949e2f0b287cdd6c6b" alt="スクリーンショット 2021-12-19 10.20.55"
9 fillについて(塗りつぶし)
図形が囲まれたので、第一章で出てきたfillについても見ていきましょう。
こんな風に指定すると
data:image/s3,"s3://crabby-images/cb702/cb702b41f635c0f9d0a96e909eeec917482f3a62" alt="スクリーンショット 2021-12-19 10.24.31"
こんな風に、囲まれた部分が赤くなりました。
data:image/s3,"s3://crabby-images/1ecae/1ecaec6a49077dbaf061f2c82eef13ded0922049" alt="スクリーンショット 2021-12-19 10.25.55"
10 stroke,stroke-widthについて
せっかくなのでstroke,stroke-widthも見てみましょう。
下のように設定してみました。
data:image/s3,"s3://crabby-images/7ba9f/7ba9f11fe6c2f68eaabb02cc13eb3f546e9e4457" alt="スクリーンショット 2021-12-19 10.28.08"
こんな感じになりました。予想通りでしたでしょうか?
data:image/s3,"s3://crabby-images/e9369/e9369849dbec214af5a66339f68c989ca9f5943a" alt="スクリーンショット 2021-12-19 10.30.00"
11 Qについて(曲線をひく)(2次ベジェ曲線)
少し見にくくなってきましたので、先ほどまでのコードを消しました。
data:image/s3,"s3://crabby-images/b6f89/b6f89014e78c82e53a4e0f34a9e207ca0cab5340" alt="スクリーンショット 2021-12-19 10.33.59"
Qは曲線を引きます。
ポイントは座標が二つ必要ということです。
例 Q 50 0 50 50
しかも上のように、空白でしか区切られていないのでわかりにくいです。
上の場合、スタート位置はMの(0,0)であり、それに対する二つの座標は
1つ目 (50,0) ⇨制御点と言います。
2つ目 (50,50) ⇨端点と言います。
おそらく、実際の画像をみる方がわかりやすいかもしれません。
data:image/s3,"s3://crabby-images/90982/9098211be052d09379441f75fdbd0db9dbb3515f" alt="スクリーンショット 2021-12-19 10.41.44"
こんな感じになりました。
イメージが湧きましたでしょうか。
こんな風に2つの点を元に曲線を引くので、2次ベジェ曲線と言います。
12 Cについて(曲線をひく)(3次ベジェ曲線)
11章の応用です。
結局、制御点がもう一つ増えただけですね。
data:image/s3,"s3://crabby-images/5a196/5a1969f0cd1bb99f84637cf0dbd9ee2f365e82e9" alt="スクリーンショット 2021-12-19 11.02.18"
こんな感じになりました。
イメージ通りでしょうか。
data:image/s3,"s3://crabby-images/8f95b/8f95baf4c80b377d9fe2e8669b9e30d0e40c364e" alt="スクリーンショット 2021-12-19 11.05.41"
13 定型技法(直線 lineタグ)
ここからは定型的な図形の書き方を見ていきましょう。
まずは直線です。
<line x1="10" y1="10" x2="100" y2="100" stroke="blue" stroke-width="2"/>
data:image/s3,"s3://crabby-images/b7e3c/b7e3c2db6d3aed9d6c5ebd50e066762f3a96c12a" alt="スクリーンショット 2021-12-19 11.16.54"
こんな感じでlineタグで囲むと直線を引くことができます。
こんな感じですね。
data:image/s3,"s3://crabby-images/1947d/1947dc66b094d977572bf59a7c8d4d61fd9bb8b4" alt="スクリーンショット 2021-12-19 11.20.07"
14 定型技法(四角形 rectタグ)
次は四角形です。
四角形は最初の点と幅、高さがわかれば描画できますね。
data:image/s3,"s3://crabby-images/f139a/f139ac20db1b96dac5320c74484bbdcdce90bdfb" alt="スクリーンショット 2021-12-19 11.21.28"
こんな感じになりました。
data:image/s3,"s3://crabby-images/5fdf3/5fdf3a830727ab22b6427245b262c0648f1928cd" alt="スクリーンショット 2021-12-19 11.24.35"
15 定型技法(円 circleタグ)
次は円です。
コンパスの要領で、中心と半径がわかれば描けますね。
<circle cx="100" cy="70" r="50" stroke="blue" stroke-width="2" fill="none"/>
data:image/s3,"s3://crabby-images/33cdd/33cdd74333e77493a9ec1e286a9411b9fe9fd32e" alt="スクリーンショット 2021-12-19 11.26.18"
こんな風になりました。
data:image/s3,"s3://crabby-images/e9521/e9521d0929efa52de4c22ca5ef73b492f650acc8" alt="スクリーンショット 2021-12-19 11.29.05"
16 定型技法(楕円 ellipseタグ)
次は楕円です。
楕円は次の3つで決まるようです。
①中心
②X方向の半径
③Y方向の半径
<ellipse cx="100" cy="80" rx="80" ry="30" stroke="blue" stroke-width="2" fill="none"/>
data:image/s3,"s3://crabby-images/eb65e/eb65eef957531a57265ae508c515c13201fb6e39" alt="スクリーンショット 2021-12-19 11.30.55"
こんな感じになりました。
data:image/s3,"s3://crabby-images/2fb44/2fb44338ef0f40f6b31e781713b1587e0ed360f8" alt="スクリーンショット 2021-12-19 11.37.34"
17 定型技法(折線 polylineタグ)
次は折線です。折れる箇所を指定しましょう。
<polyline points="50 50 100 25 150 75 200 65" stroke="blue" stroke-width="2" fill="none"/>
data:image/s3,"s3://crabby-images/bd6ba/bd6bacfa928a2073c4db326d04330b95cd9c3f08" alt="スクリーンショット 2021-12-19 11.41.31"
こんな風になりました。
data:image/s3,"s3://crabby-images/c115a/c115a5212d5d9bf66201e3946cde6816b00a8719" alt="スクリーンショット 2021-12-19 11.43.30"
18 定型技法(多角形 polygonタグ)
次は多角形です。折れる箇所を指定しましょう。
<polygon points="50 50 100 200 50 150 0 200" stroke="blue" stroke-width="2" fill="none"/>
data:image/s3,"s3://crabby-images/ef95a/ef95aab352e23712d76e3e1972c36c52e227f615" alt="スクリーンショット 2021-12-19 11.46.22"
こんな感じになりました。
data:image/s3,"s3://crabby-images/1589d/1589da82c6551d8bb25d4d412b2057e8b66d77ee" alt="スクリーンショット 2021-12-19 11.48.17"
19 点線の描写(stroke-dasharray)
点線も描いてみましょう。
下のようにstroke-dasharrayを用いると描けます。
<polygon points="50 50 100 200 50 150 0 200" stroke="blue" stroke-width="2" fill="none" stroke-dasharray="10 5"/>
data:image/s3,"s3://crabby-images/3cefb/3cefbdc08dcbf005e2ef2ff515a5a8ce45eeace6" alt="スクリーンショット 2021-12-19 11.53.25"
こんな風になりました。
data:image/s3,"s3://crabby-images/2e18c/2e18c8ba4b22ee6f7716fd237a0fec11466b072c" alt="スクリーンショット 2021-12-19 11.56.36"
もちろん、下のように曲線などでも行けますね。
data:image/s3,"s3://crabby-images/93d15/93d1543c96c5a08f5a7f5f9870fefd32a44b396e" alt="スクリーンショット 2021-12-19 11.58.19"
20 線の一部の色を変える(重ね合わせ)
svgでは描画箇所が同じであれば、下の行に描かれているものが上の行を上書きします。
data:image/s3,"s3://crabby-images/8f462/8f4621f298816cf2b1d673312c7aca0f424bb15b" alt="スクリーンショット 2021-12-19 12.02.44"
<polygon points="50 50 100 200 50 150 0 200" stroke="blue" stroke-width="2" fill="lightpink" stroke-dasharray="10 5"/>
<ellipse cx="100" cy="80" rx="80" ry="30" stroke="blue" stroke-width="2" fill="lightgreen"/>
上のように描いた場合、X座標が100~150の範囲で赤色が上書きされます。
こんな感じです。
data:image/s3,"s3://crabby-images/11471/114719eeed99142f7a8e0a0dc25c09c77efbdc3d" alt="スクリーンショット 2021-12-19 12.05.49"
21 Animationの基礎を学ぼう。(animateタグ)
では、ここからは動きを加えていきましょう。
下のような「animate」タグで囲むことになります。
<circle cx = "30" cy="30" r="20" fill="blue">
<animate attributeName="cx" dur="5s" from="30" to="270" repeatCount="indefinite"/>
</circle>
data:image/s3,"s3://crabby-images/9554b/9554b94bfc9ee8489886faa4b5e585c17e9b3e37" alt="スクリーンショット 2021-12-19 12.23.36"
うまく動画が載せられず残念でしたが、下のように右まで進み、また左に戻って進むようなものができました。
data:image/s3,"s3://crabby-images/8ca3b/8ca3bc55c174b23dd46a6df3bb69170ac9a6b692" alt="スクリーンショット 2021-12-19 12.36.53"
22 animateタグの構成を確認しよう
では構成を確認しましょう。
data:image/s3,"s3://crabby-images/7e237/7e237219bc74a3a377c5f88398337d69ccb2663a" alt="スクリーンショット 2021-12-19 12.23.36"
① attributeName
たぶんこれが一番大事です。これは「何を動かすのか」というものです。
今回は「cx」です。
「cx」は上の「circle」タグで円の中心(X軸)を表しています。
つまり、今回のアニメーションは円の中心(X軸)を右に動かすことによって、円自体を動かすアニメーションです。
② dur
これはそのままの意味で、「duration」(継続時間)です。今回は5秒かけてアニメーションを動かすという設定になっています。
③ from to
これは今回動かす円のX座標をどこからどこまで動かすのかという設定です。
今回はX=30からX=270まで動かすという指定をしています。
④ repeatCount
これは何回繰り返すかです。
今回は「indefinite」(無限)で設定していますが、回数を指定することで、何回かという設定も可能です。
23 いろんなアニメーションを作ろう(大きくなる円)
では、いろんなアニメーションを作ってみましょう。
例えば、円が大きくなるようにするなら、半径を動かせばいいですね。
data:image/s3,"s3://crabby-images/bbeae/bbeaed2ada1d0dd30770fb33efd9e27ec972f3a7" alt="スクリーンショット 2021-12-19 12.52.06"
ちなみに
begin="click"
とすることで、クリックすることでアニメーションが動き出す仕様になります。
下のような感じです。
data:image/s3,"s3://crabby-images/f331b/f331b841dd964882153a586cb95f37d99513c7b9" alt="スクリーンショット 2021-12-19 13.07.28"
data:image/s3,"s3://crabby-images/33657/336573c5eeff02d200e312ffac893bb956cfd10e" alt="スクリーンショット 2021-12-19 13.07.14"
24 いろんなアニメーションを作ろう(色を変えよう)
色を変える場合も塗りつぶしである「fill」を属性に指定すればいいですね。
data:image/s3,"s3://crabby-images/fe7dd/fe7dd3be6dfe5d24ae27bcf992b73f991ed06143" alt="スクリーンショット 2021-12-19 13.52.00"
このように青からピンクに変わるものができました。
data:image/s3,"s3://crabby-images/e3afe/e3afe28d49bbab14dcfeb14b5b84982cc1d94e1c" alt="スクリーンショット 2021-12-19 13.55.33"
data:image/s3,"s3://crabby-images/50e0d/50e0dfc2ad272b444adcd7cd3cd400045a9507c8" alt="スクリーンショット 2021-12-19 13.55.47"
25 いろんなアニメーションを作ろう(透明度を変えよう)
透明にする場合はopacityを設定すれば良いですね。
<animate attributeType="CSS" attributeName="opacity" dur="3s" from="1" to="0" repeatCount="indefinite"/>
data:image/s3,"s3://crabby-images/29373/29373fe3ba37ec341d0760a9aaebe93d893900a5" alt="スクリーンショット 2021-12-19 14.15.07"
ちなみに今まで「attributeType」を設定していなかったのですが、こちらも設定をしたほうが良さそうでした。
こちらは図形要素自体の属性かCSSの属性かによって「XML」か「CSS」に設定します。
今回はコードの中にある属性ではありませんので、「CSS」の設定になりました。
data:image/s3,"s3://crabby-images/bf7e5/bf7e51cba2146e80ca2631defe30cbcfd02d5804" alt="スクリーンショット 2021-12-19 14.24.22"
番外編
<svg width="500" height="500" xmlns="http://www.w3.org/2000/svg">
<path d="M 25,100 A 75,75 0 1,1 175,100 A 75,75 0 1,1 25,100 z" stroke="black" fill="lightblue"/>
<circle fill="red" r="5">
<animateMotion path="M 25,100 A 75,75 0 1,1 175,100 A 75,75 0 1,1 25,100 z" begin="0s" dur="6s" calcMode="linear" repeatCount="indefinite"/>
</circle>
</svg>
data:image/s3,"s3://crabby-images/3c611/3c61145e8417ad0041f29d7c02062a548ab5aecc" alt=""
今回は以上です。
これで色々なsvgを作ることができ、結果色々なフルオンチェーンNFTを作ることができると思います。
ぜひやってみてくださいね。
いいなと思ったら応援しよう!
data:image/s3,"s3://crabby-images/5f0d9/5f0d9679767578b8ade975217b090e519482803a" alt="ユウキ"