Import from After Effects
If you are a After Effects user, you might find it useful to convert your After Effects compositions to Remotion compositions. You can use the @remotion/lottie
package for this.
Remotion compositions got their name because After Effects coined this term!
Install the Bodymovin plugin
- Make sure After Effects is closed.
- Go to this site and download the ZXP installer for your platform.
- Click here to download the latest Bodymovin plugin.
- Open the ZXP installer and drag the bodymovin file into it.
Create a composition
Open After Effects and create a new project and then click New composition
.
data:image/s3,"s3://crabby-images/4c2a3/4c2a35a547fb76c017afde20bb5e7d5187c5f6e4" alt=""
Create your animation
Design your animation in After Effects. In this basic example, we used the rounded rectangle tool to draw a blue rounded square and then opened the transform menu and clicked the stopwatch icon to set keyframes for position and rotation to create a simple entrance effect.
data:image/s3,"s3://crabby-images/f06ca/f06cac90633c1d04bfc496cf3686f3e5f03c7cd2" alt=""
Allow export as JSON
In the After Effects menu, go to Preferences -> Scripting & Expressions...
. Enable the first option: Allow Scripts to Write Files and Access Network
. You only need to do this once.
data:image/s3,"s3://crabby-images/6d80a/6d80a9db5639fbba42473042781602684bbc75b3" alt=""
Open the Bodymovin plugin
In the After Effects menu, go to Window -> Extensions -> Bodymovin
.
data:image/s3,"s3://crabby-images/efcd1/efcd1cec7eb20fdd86ab99a267e1ea4a8211e246" alt=""
Export the animation as JSON
First, select the composition
data:image/s3,"s3://crabby-images/66aca/66aca8d1d632e6a8865134a07b6265b9dce895e1" alt=""
Import the file into Remotion
Copy the file into the Remotion project. The recommended way is to put the JSON inside the public/
folder of Remotion (create it if necessary) and then load it using staticFile()
:
Animation.tsxtsx
import {Lottie ,LottieAnimationData } from "@remotion/lottie";import {useEffect ,useState } from "react";import {cancelRender ,continueRender ,delayRender ,staticFile ,} from "remotion";constBalloons = () => {const [handle ] =useState (() =>delayRender ("Loading Lottie animation"));const [animationData ,setAnimationData ] =useState <LottieAnimationData | null>(null);useEffect (() => {fetch (staticFile ("animation.json")).then ((data ) =>data .json ()).then ((json ) => {setAnimationData (json );continueRender (handle );}).catch ((err ) => {cancelRender (err );console .log ("Animation failed to load",err );});}, [handle ]);if (!animationData ) {return null;}return <Lottie animationData ={animationData } />;};
Animation.tsxtsx
import {Lottie ,LottieAnimationData } from "@remotion/lottie";import {useEffect ,useState } from "react";import {cancelRender ,continueRender ,delayRender ,staticFile ,} from "remotion";constBalloons = () => {const [handle ] =useState (() =>delayRender ("Loading Lottie animation"));const [animationData ,setAnimationData ] =useState <LottieAnimationData | null>(null);useEffect (() => {fetch (staticFile ("animation.json")).then ((data ) =>data .json ()).then ((json ) => {setAnimationData (json );continueRender (handle );}).catch ((err ) => {cancelRender (err );console .log ("Animation failed to load",err );});}, [handle ]);if (!animationData ) {return null;}return <Lottie animationData ={animationData } />;};
Finetuning
It is advised to make your composition the same size and duration as the original composition in After Effects. Congrats, you're playing an After Effects animation in Remotion! 🎉
data:image/s3,"s3://crabby-images/fc91d/fc91d256812bfff75cc0f3980f3be4bb7e10804f" alt=""