Example Description
In this example we use the following 3 animations to demonstrate how to flip an hourglass automatically or on a button click:
Hourglass: The flip effect of the hourglass.
Balls in the hourglass: The falling effect of the balls in the hourglass. This animation is triggered once the hourglass is flipped.
The flip button: Animation of the button when the site visitor hovers over it.
How We Built It
Page Elements
In our site we added the following page elements:
A transparent image of an hourglass with a black background.
A container box with the following elements:
A white container box the size of the hourglass to create a white background (mask) for the hourglass animation.
A group containing 5 circle vector images of different sizes and colors to create the balls in the hourglass.
A group containing 1 rectangle vector image and 1 text element to create a custom button (flip button) to trigger the flipping hourglass animation.
An additional identical rectangle vector image for the flip button animation.
Code
In the $w.onReady() function we declare all the elements we want to animate. On mobile we also adjust the size of the hourglass to be compatible with mobile devices. Next we create the individual animations for each of the 3 animations:
1. balls_animation: Before creating the balls animation, we first position the balls in the hourglass at a random distance within our desired range. This allows the animation of the balls to be a bit different each time the hourglass is flipped. When doing this, we also make sure to perform certain calculations on the balls in the hourglass to mimic the behavior of sand particles moving in a real hourglass. Once the balls are positioned, we animate them to fall at our desired duration, delay, easing parameters, and x and y positions.
2. hourglass_animation: To flip the hourglass, we rotate the container with the hourglass balls and the hourglass mask by 180 degrees at a duration of 400 milliseconds. In our example, we want to run this animation automatically every 8 seconds. We simplify this by using states. Since there are 2 possible states of the hourglass, upright or flipped, we set an animation state to flip the hourglass according to that state. We then use a setTimeout() function to switch states after 8 seconds.
See the 2 states below:
State 1: The hourglass is upright, and the balls have already fallen. In this state, we set the hourglass flip animation to play (the hourglass to flip), and the balls animation to reverse (the balls to fall again).
State 2: The hourglass is flipped, and the balls haven’t fallen yet. In this state, we set the hourglass flip animation to reverse (the hourglass to go back to its upright position), and the balls animation to play (the balls to fall).
We also include the functionality of running this animation when the user clicks on the flip button by adding an onClick() event handler to the flip button.
3. button_animation: When the user hovers over the flip button, we move the flip button down and to the right, and the rectangle vector image up and to the left. This gives an illusion that the rectangle vector image slid under the button.
Related Examples
Did this help?
|
Thanks for your feedback!
data:image/s3,"s3://crabby-images/68e54/68e546c3f437e9b94015ded8b5d715c66ce193ef" alt="Custom Button Animation"
Custom Button Animation
Create a custom button that rotates clockwise and changes color on click using the Wix Animations API.
data:image/s3,"s3://crabby-images/eafc5/eafc5cc0f834fed7f0037e0c8de676696c2e9b1e" alt="Intermediate.png"
Beginner
data:image/s3,"s3://crabby-images/e1072/e1072885a9a733a59315fbe96a884d42210e3e64" alt="Solar System Animation"
Solar System Animation
Create a simplified solar system animation using the Wix Animations API.
data:image/s3,"s3://crabby-images/eafc5/eafc5cc0f834fed7f0037e0c8de676696c2e9b1e" alt="Intermediate.png"
Advanced
data:image/s3,"s3://crabby-images/aef0b/aef0b327c0f092c492403a2cd46ad3e2e8f022ed" alt="Ball Drop Animation"
Ball Drop Animation
Create a ball drop animation where balls fall through a maze and dot the letter I’s in your words.
data:image/s3,"s3://crabby-images/eafc5/eafc5cc0f834fed7f0037e0c8de676696c2e9b1e" alt="Intermediate.png"
Advanced
data:image/s3,"s3://crabby-images/b418c/b418ccca6988f83be913e0d2bdfd6484b29e1602" alt="Text Microinteractions"
Text Microinteractions
Create different microinteractions on 3 text elements using the Wix Animations API.
data:image/s3,"s3://crabby-images/eafc5/eafc5cc0f834fed7f0037e0c8de676696c2e9b1e" alt="Intermediate.png"
Intermediate
data:image/s3,"s3://crabby-images/c2599/c25991eb50cde1c2ab6051761612d0c4ad415ee6" alt="Vector Image Animation"
Vector Image Animation
Create an animation of a ball moving and then taking the place of the letter O’s in your words.
data:image/s3,"s3://crabby-images/eafc5/eafc5cc0f834fed7f0037e0c8de676696c2e9b1e" alt="Intermediate.png"
Beginner