質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
SVG

SVGは、XMLを基盤とした2Dベクター画像記述言語。画像を線・面といった図形の集合体として扱うベクター画像のため、環境に適した表示が可能です。アニメーション機能もサポートされており、簡単なインタラクティブコンテンツ作成もできます。

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Illustrator

Illustratorは、アドビシステムズ(株)が開発した描画ツールソフトです。 イラスト製作やロゴタイプ、広告作成時などのデザインツールとして、さまざまな分野のクリエーターに愛用されています。 プラグインの中にCADや3DCG機能の拡張ができるものがあります。 特に広告作成などの印刷業界では、トップクラスのシェアを誇っているソフトです。

Q&A

解決済

1回答

2272閲覧

SVGを使用したアニメーション

nyako_prog

総合スコア13

SVG

SVGは、XMLを基盤とした2Dベクター画像記述言語。画像を線・面といった図形の集合体として扱うベクター画像のため、環境に適した表示が可能です。アニメーション機能もサポートされており、簡単なインタラクティブコンテンツ作成もできます。

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

Illustrator

Illustratorは、アドビシステムズ(株)が開発した描画ツールソフトです。 イラスト製作やロゴタイプ、広告作成時などのデザインツールとして、さまざまな分野のクリエーターに愛用されています。 プラグインの中にCADや3DCG機能の拡張ができるものがあります。 特に広告作成などの印刷業界では、トップクラスのシェアを誇っているソフトです。

0グッド

0クリップ

投稿2018/06/20 16:21

実現したいこと

Illustratorで書き出したSVGを使ってアニメーションを作成したいです。
最終的には文字を手書き風に書き出したいです。

発生している問題

↓Illustratorで作ったSVG
イメージ説明
左上から右下にかけてパスを通しています。このパス通りにアニメーションして欲しいです。
Illustratorの線幅ツールを使って線を太くしています。

↓HTMLにPATHを貼ってCSSを設定、実行
左上から上を通って右下、右下から下を通って左上へとアウトラインをなぞるようにアニメーションしてしまいます。
左上から右下へとアニメーションして欲しい...!!

イメージ説明

コード

HTML

1<svg viewBox="0 0 305.65 259.76"><line x1="0.32" y1="0.38" x2="305.32" y2="259.38"/> 2<path class="path" d="M144.82,253.12a191.9,191.9,0,0,1,28.55,5c9,2.23,17.76,4.84,26.21,7.77s16.65,6.14,24.62,9.64c2,.84,4,1.78,5.94,2.67S234.08,280,236,281q5.82,2.81,11.5,5.77A423,423,0,0,1,330.2,343.9a479.72,479.72,0,0,1,68.71,73.64c2.54,3.44,5.08,6.88,7.53,10.44s4.89,7.13,7.29,10.74q7.11,10.93,13.65,22.55c4.34,7.77,8.46,15.81,12.27,24.19a209,209,0,0,1,10.17,26.66l-.64.76a207.53,207.53,0,0,1-28-5.72c-8.89-2.4-17.48-5.16-25.85-8.18s-16.51-6.32-24.47-9.82c-3.95-1.79-7.91-3.57-11.78-5.46s-7.72-3.78-11.53-5.74A479.09,479.09,0,0,1,263.8,422.1,423.7,423.7,0,0,1,194,349.78c-2.58-3.41-5.09-6.9-7.56-10.42q-1.86-2.64-3.65-5.36c-1.2-1.81-2.44-3.57-3.59-5.43q-7.12-10.94-13.51-22.73t-11.91-24.6a189.8,189.8,0,0,1-9.58-27.36Z" transform="translate(-144.18 -253.12)"/> 3</svg>

CSS

1.path{ 2 stroke:black; 3 fill:transparent; 4 stroke-width:5; 5 stroke-dasharray: 5000; 6 stroke-dashoffset:5000; 7 animation: DASH 3.4s ease-in-out alternate forwards; 8 -webkit-animation:DASH 3.4s ease-in-out 0s forwards; 9 animation:DASH 3.4s ease-in-out 0s forwards; 10} 11 12@keyframes DASH{ 13 0%{ 14 stroke-dashoffset:5000; 15 fill:transparent; 16 } 17 100%{stroke-dashoffset:0; 18 fill:black; 19 } 20} 21@-moz-keyframes DASH{ 22 0%{stroke-dashoffset:5000;} 23 100%{stroke-dashoffset:0;} 24} 25@-webkit-keyframes DASH{ 26 0%{stroke-dashoffset:5000;} 27 100%{stroke-dashoffset:0;} 28}

CSSはこちらを参考にしました。

補足情報

お力添えください...!!

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

今回のような場合には、徐々に塗っていくということは実現が難しいです。
(この画像の上に画像を重ね、それを消していくというようにすれば、擬似的に塗っているよう見せることができそうです。)

最終的には文字を手書き風に書き出したいとのことであれば、今回の件はスルーされたほうがよいように思います。

SVGでアニメーションを実現する際には、太さ・色が同じパスを線画していくようなイメージの方が簡単です。
(参考にされているサイトで、最初に筆記体の文字をトレースしているのは、筆記体フォントはそれぞれの部分で太さが違うためです。最終的に実現している筆記体はパスの太さが同じですよね?)

太さが違うものを実現したい場合には、下記サイトのように、フォントのアウトラインを徐々に書いていって、最後に塗る、という方法で実現が可能です。
http://ascii.jp/elem/000/000/901/901319/

うまく伝わったかわかりませんが、質問があれば気軽にどうぞ。

投稿2018/06/21 02:16

macaron_xxx

総合スコア3191

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

nyako_prog

2018/06/21 10:11

回答ありがとうございます。 アウトラインを表示→塗るの方法に変更しました! 画像の上にマスクを作成する方法も試したのですが、画像サイズ、あるいはSVGのviewboxの設定がうまくいかずズレが生じてしまいました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問