Unleash Your Inner Wizard: Image Reveal with GSAP!

Are you tired of boring, static images on your website? Do you wish you could add some magic and excitement to your page? Well, my dear reader, it’s time to unleash your inner wizard with GSAP!

What is GSAP?

If you’re not familiar with GSAP, let me educate you, my friend. GSAP stands for GreenSock Animation Platform, and it’s a JavaScript library that allows you to create stunning animations and effects for your website. It’s like having a wand that can turn your pages into something straight out of Hogwarts.

Why Use Image Reveal?

Images are a crucial aspect of any website. They can convey emotions, showcase products, and add some much-needed visual interest to your page. But just having a static image on your site can be boring and unengaging. That’s where image reveal comes in.

With image reveal, you can create an element of surprise and excitement for your visitors. It’s like unwrapping a present, except the present is your website. Plus, it keeps your visitors on your page for longer, which is always a good thing.

How to Implement Image Reveal with GSAP

Now that you understand the benefits of image reveal let’s get into how you can implement it with GSAP. First, you’ll need to include the GSAP library on your page. You can either download it and host it on your server or include it via a CDN.

Once you’ve got GSAP set up, you’ll need to add some HTML and CSS to create your image reveal container. Here’s an example:

<div class="reveal-container">
  <img src="image.jpg" alt="Image">
  <div class="overlay"></div>

  .reveal-container {
    position: relative;

  .reveal-container .overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: black;
    opacity: 0;

In this example, we’ve created a div with a class of reveal-container that contains an image and an empty div with a class of overlay. We’ve also added some basic CSS to position the elements and set the overlay to a solid black color with 0 opacity.

See also  Get Your Coat(hanger) Ready: Eastwood DTM Epoxy Primer Has You Covered!

Now that we have our HTML and CSS set up, we can add some GSAP magic to create our image reveal effect. Here’s the JavaScript code:

const revealContainer = document.querySelector('.reveal-container');
const overlay = document.querySelector('.overlay');

gsap.set(overlay, { opacity: 1 });

revealContainer.addEventListener('mouseenter', () => {
  gsap.to(overlay, { duration: 1, opacity: 0, ease: 'power2.inOut' });

revealContainer.addEventListener('mouseleave', () => {
  gsap.to(overlay, { duration: 1, opacity: 1, ease: 'power2.inOut' });

In this code, we’re using GSAP’s set() method to set the starting opacity of the overlay to 1 (meaning it will be completely black and cover the image). Then, we’re using the addEventListener() method to add mouseenter and mouseleave events to the revealContainer. When the mouse enters the container, we’re using GSAP’s to() method to animate the overlay’s opacity from 1 to 0 over 1 second with an ease of ‘power2.inOut’. When the mouse leaves the container, we’re doing the reverse animation, animating the overlay’s opacity from 0 to 1 over 1 second with the same ease.

And voila! You now have a beautiful image reveal effect on your website. But wait, there’s more!

Taking Image Reveal to the Next Level

If you want to take your image reveal to the next level, you can add some additional effects to make it even more magical. Here are a few ideas to get you started:


Add some movement to your reveal container to make it look like the image is coming to life. You can use GSAP’s to() method to animate the position or scale of the image to create a stunning effect.

gsap.to(revealContainer, { duration: 1, x: 50, scale: 1.2, ease: 'power2.inOut' });


Instead of a simple black overlay, add some color to your reveal effect to create a more vibrant and dynamic look. You can use GSAP’s to() method to animate the color property of the overlay.

gsap.to(overlay, { duration: 1, backgroundColor: '#ff0000', ease: 'power2.inOut' });


Add some text to your reveal container to create a more informative and engaging effect. You can use GSAP’s to() method to animate the text’s opacity or position.

const text = document.querySelector('.text');

gsap.set(text, { opacity: 0 });

revealContainer.addEventListener('mouseenter', () => {
  gsap.to([overlay, text], { duration: 1, opacity: 0, ease: 'power2.inOut' });

revealContainer.addEventListener('mouseleave', () => {
  gsap.to([overlay, text], { duration: 1, opacity: 1, ease: 'power2.inOut' });

In this code, we’re adding a text element with a class of text to our reveal container, and using GSAP’s set() method to set the starting opacity to 0. We’re then using to() method to animate both the overlay and text’s opacity on mouseenter and mouseleave.

See also  Honey, I Shrunk the Car: Adventures with Honeyman Ford


With GSAP, you can unleash your inner wizard and create stunning image reveal effects that will make your website stand out from the crowd. Whether you want to add movement, color, or text to your reveal, GSAP makes it easy to bring your ideas to life.

So what are you waiting for? Grab your wand (or keyboard) and get coding! The world of image reveal is waiting for you.


Here is a table that shows the differences between static images and image reveal:

Static Images Image Reveal
Boring and unengaging Exciting and surprising
Visitors may not stay on page long Increases time spent on page
Limited communication of information Communicates information in a dynamic way
No element of surprise Creates an element of surprise


  • GreenSock Animation Platform. (n.d.). Retrieved August 10, 2021, from https://greensock.com/
  • Holland, T. (2021, April 21). The benefits of image reveal animations and how to create them. Creative Bloq. https://www.creativebloq.com/how-to/the-benefits-of-image-reveal-animations-and-how-to-create-them
  • Quinault, J. (2021, June 3). Make your images come to life with this image reveal CSS trick. CSS-Tricks. https://css-tricks.com/make-your-images-come-to-life-with-this-image-reveal-css-trick/