(2023年11月追記)AfterEffectsよりシンプルで簡単に作れるLottielabのバージョンの記事も書きました。
data:image/s3,"s3://crabby-images/c81a1/c81a15f50156ed899f93d4369919ef6d8e5e02b5" alt=""
STEP 1. Illustratorで描いた絵をAfterEffectsで動かす
参考:https://helpx.adobe.com/jp/after-effects/how-to/jp-for-designers-1.html
動かしたいオブジェクトごとにレイヤーに分ける
AfterEffectsで読み込むと、Illustratorのレイヤー=AfterEffectsのレイヤーになるので、動かしたいオブジェクトごとにレイヤーを分けます。
★デモのページを見るとわかるのですが、クリッピングマスクがかかっているレイヤーはLottie書き出し時にうまく動作しないようです★
data:image/s3,"s3://crabby-images/e9e5d/e9e5d9c1c6f8f1494ce5f27639588bf0ea9f7983" alt=""
AfterEffects で動きを付ける
AfterEffectsの詳細な説明は省きます!
今回は位置のアニメーションのみを行ったのでシェイプレイヤーに変換する前に動きを付けていますが、シェイプレイヤーに変換→アニメーションを付けるほうがよいかも。
data:image/s3,"s3://crabby-images/29609/29609f5b9afb07b733dd36be8c66db5c823d5dd8" alt=""
Illustrator レイヤーをシェイプレイヤーに変換する
シェイプレイヤーに変換しないとLottie化した時に画像がpngとして出力されてしまいます。
参考:https://helpx.adobe.com/jp/after-effects/how-to/convert-illustrator-layers-to-shape-layers.html
STEP 2. LottieJSONとして書き出す
参考: https://necco.co/note/7370
bodymovinを入れる
まずはAfterEffectsからLottieJSONを書き出すためのスクリプトをインストールします。
ZXP Installer https://aescripts.com/learn/zxp-installer/
bodymovin.zxp https://github.com/airbnb/lottie-web/blob/master/build/extension/bodymovin.zxp
data:image/s3,"s3://crabby-images/3a3b7/3a3b78561848022a45826c8ce1fce76d2b048d2e" alt=""
環境設定の「スクリプトとエクスプレッション」にある「スクリプトによるファイルへの書き込みとネットワークアクセスを許可」のチェックを入れておきましょう(入れないと Windows環境ではRender Failedになる )
ウィンドウ → エクステンション → にBodymovinが入れば準備完了。
data:image/s3,"s3://crabby-images/f2915/f29159625d37eb1989487b24cbba0b5e4d76622d" alt=""
Bodymovin でエクスポートする
書き出したいコンポジションをSelected にしたら、Settingsで書き出しの設定を確認しましょう。
data:image/s3,"s3://crabby-images/80ece/80ece7a46f95be7dfa64e32d9b8ab1091e311881" alt=""
Standard、またはStandardとDemoの両方にチェックをしておきます。
data:image/s3,"s3://crabby-images/ce743/ce7432f799beaecb9c377c6dcfb6bc1803f3ea8c" alt=""
続いて書き出したいコンポジション名の右端の … をクリックして、JSONファイルの保存先を設定します。
設定し終わるとこんな感じ。「Render」ボタンが押せるようになるので、「Render」ボタンをクリックします。
data:image/s3,"s3://crabby-images/251cb/251cb61a5be001b3c4b59b92a3c08808c0929658" alt=""
すると指定した保存先に、lottieのJSONファイルが保存されます。
data:image/s3,"s3://crabby-images/6be2f/6be2f0eb97e266e56abc260b00832d2b9d1bd0af" alt=""
STEP 3. Webページで簡単に動かす
デモです。
lottie-player(単に再生するだけ)
下記のlottie-playerのコードのsrc=””の部分で、bodymovinで書き出したJSONファイルを指定するだけ!
<script src="https://unpkg.com/@lottiefiles/lottie-player@latest/dist/lottie-player.js"></script>
<lottie-player
src="data.json"
background="transparent"
speed="1"
style="width: 300px; height: 300px"
loop
autoplay
></lottie-player>
lottie.js(JavaScriptでいろいろしたいとき)
bodymovin.loadAnimationをつかってpathに書き出したJSONファイルを指定します。
<script src="https://cdnjs.cloudflare.com/ajax/libs/bodymovin/5.9.1/lottie.min.js"></script>
<div class="lottie-animation"></div>
<script>
bodymovin.loadAnimation({
container: document.querySelector(".lottie-animation"),
path: "data.json",
renderer: "svg"
})
</script>
(おまけ)GSAPで全力で動かす
GSAPのScrollTriggerで、スクロール量に応じてLottieをコマ送りすることもできます!
参考:https://codepen.io/GreenSock/full/QWdjEbx
デモ:https://deep-space.blue/testing/lottie-testing/lottie-gsap/index.html
<div class="lottie-animation" id="animationWindow"></div>
<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/3.9.1/gsap.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/gsap/3.9.1/ScrollTrigger.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/lottie-web/5.8.1/lottie.min.js"></script>
<script>
// https://codepen.io/GreenSock/full/QWdjEbx
LottieScrollTrigger({
target: "#animationWindow",
path: "data.json",
speed: "medium",
scrub: 0
});
function LottieScrollTrigger(vars) {
let playhead = {frame: 0},
target = gsap.utils.toArray(vars.target)[0],
speeds = {slow: "+=2000", medium: "+=1000", fast: "+=500"},
st = {trigger: target, pin: true, start: "top top", end: speeds[vars.speed] || "+=1000", scrub: 1},
animation = lottie.loadAnimation({
container: target,
renderer: vars.renderer || "svg",
loop: false,
autoplay: false,
path: vars.path
});
for (let p in vars) {
st[p] = vars[p];
}
animation.addEventListener("DOMLoaded", function() {
gsap.to(playhead, {
frame: animation.totalFrames - 1,
ease: "none",
onUpdate: () => animation.goToAndStop(playhead.frame, true),
scrollTrigger: st
});
ScrollTrigger.sort();
ScrollTrigger.refresh();
});
return animation;
}
</script>
コメント