How to create a slick CSS animation from The Fall Guy

Rob OLeary - Jul 19 - - Dev Community

The Fall Guy (2024) is an action comedy movie about a down-and-out stuntman. The title sequence involves a simple animation of a man falling -- a very literal depiction of the title! Let's see how we can make it with CSS.

TLDR

You can see the brief title sequence in the official trailer (2m 41s timestamp) on YouTube.

Here is the finished animation.

About the title sequence

The title card has the name of the movie in large, tall yellow text with a black background. The first word -- 'THE' -- has a smaller font size than the other 2 words. It is tucked into the space between the arms of the letter 'F' of the second word.

The animation involves a yellow silhouette of a man tumbling downwards through the letter A. As he passes into the letter, the fill colour changes progressively transitions from yellow to black as moves inside the letter.

a yellow silhouette of a man, literally a falling guy, tumbling downwards through the letter A.

The letter A has the counter (enclosed area) filled in. The falling man stops close to the spot where the counter should be. This creates an interesting figure-ground impression.

a black silhouette of a man filling the counter of the letter A.

This is reminiscent of the poster for the movie A.I. Artificial Intelligence. Both use a silhouette of the main character to kind of knock out the letter A!


the poster for the movie AI.

Sourced from Wikimedia. Copyright held by the film company or the artist. Used under fair use to provide critical commentary.

The typeface used in the title is a san serif font family. It is probably Solido Compressed Bold.

Implementation tidbits

To reference each of the words and the letter A of the second word, we need to use some inline elements.

<h1>
    <span class="word">The</span>
    <span class="word">F<i>a</i>ll</span>
    <span class="word">Guy</span>
    <img src="img/guy.svg" class="guy"
     alt="silhouette of a falling man" />
</h1>
Enter fullscreen mode Exit fullscreen mode

Since Solido Compressed Bold has a commercial license, I opted for a similar font family in Bebas Neue. Solido Compressed Bold has a bigger x-height than Bebas Nueue. In the implementation I compensated for this, I stretched the text through the scale CSS property.

.word {
  display: block;
  scale: 100% 130%;

  &:nth-of-type(3) {
    scale: 125% 130%;
    margin-inline-start: 10%;
  }
}
Enter fullscreen mode Exit fullscreen mode

I fill in the enclosed area of the letter A by using a pseudo-element. The pseudo-element needs to be placed over the area. To prevent it overflowing the letter, it is cut down in size using the clip-path CSS property.

outline of the clip path for pseudo-element that is covering the counter of the letter A

i::before {
  clip-path: polygon(48% 17%, 15% 100%, 79.25% 100%);
}
Enter fullscreen mode Exit fullscreen mode

To create the fill colour transition of the guy, I use the mix-blend-mode CSS property.

.guy {
  mix-blend-mode: difference;
}
Enter fullscreen mode Exit fullscreen mode

The animation

Ninety percent of the work is in the styling. The falling guy image is positioned above the letter A with the translate property with a negative number on the Y axis. The @keyframes animates the value of the property to zero to place the guy in his final resting position (don't worry he survives 😉).

.guy {
  translate: 0 -500%;

  animation: fall 2s;
  animation-fill-mode: forwards;
  animation-timing-function: cubic-bezier(0.2, 0.5, 0.47, 1.06);

  /* other styles */
}

@keyframes fall {
  to {
    translate: 0;
  }
}
Enter fullscreen mode Exit fullscreen mode

The easing of the animation (animation-timing-function) is in the ballpark of the ease-out keyword. I choose to use cubic-bezier() for more precise control.

Final thoughts

If you make strong choices with typography, a simple animation can shine. I quite like this one. It is not hard to pull off.

Source code

The source code is available in this github repo.

You can check out all of the animations of this series in this codepen collection.

. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .