AfterFX-Based Eko UI

AfterFX/Lottie-based Eko components with animated states and transitions

The example above shows how to use EkoLottieDecisionButton and EkoLottieTimer, which are components that are animated using LottieWeb (previously known as BodyMovin) using animations exported directly from AfterEffects using the BodyMovin AE Extension.

AfterFX composition set-up

Each button should be a single afterFX composition, including composition labels reflecting the following Eko button states:

  • Appear-Start
  • Appear-End
  • Idle-Start
  • Idle-End
  • Selected-Start
  • Selected-End
  • NotSelected-Start
  • NotSelected-End
  • Disappear-Selected-Start
  • Disappear-Selected-End
  • Disappear-NotSelected-Start
  • Disappear-NotSelected-End

Each timer should be a single afterFX composition, including composition labels reflecting the following Eko timer states:

  • Appear-Start
  • Appear-End
  • Progress-Start
  • Progress-End
  • Disappear-Start
  • Disappear-End

AfterFX Animation Considerations/Limitations

  • The animation has to work and be legible on various backgrounds, since it plays on top of video
  • The animation has to be vector, and can’t include Bitmap effects, Motion-blurs, Expressions / script-based animated properties

Animation Quality

  • The animation export for each component from BodyMovin has to end up small (up to 30kb), meaning animation needs to be optimized in terms of amount of vectors / keyframes used, and can’t be too detail-heavy
  • Prior to delivery - the animation has to be tested and validated that is suitable for Eko’s platform:

Animation Usage in code

JSON files (each component should be a separate file) should be referenced in the lottieData options of the EkoLottieDecisionButton or EkoLottieTimer

Sample Resources

Sample project for a Lottie-based Eko Components, including :

  • Renders Folder
  • Reference to see how it should look (showing just 1 path)
  • Lottie JSON for each component - “abstain”, and “chug” buttons + “timer”
  • AfterFX source project
Rate this page: X
Tell us more!