animation timing function steps. Let’s take a look at one more possible class of animation-timing-function values — steps. animation timing function steps

 
 Let’s take a look at one more possible class of animation-timing-function values — stepsanimation timing function steps  If no animation-timing-function is specified on a keyframe, the corresponding value of animation-timing-function from the element to which the animation is applied is used for that keyframe

但是有的时候我们并不想要平滑的过渡,比如想要. will be familiar with keyframes. animation-timing-function: steps(n, jump-none); Here [easing] is one of those listed at easings. It appears as if the element bounces off the left side. ease-in: animation. This acceleration curve is defined using one <timing. There are different techniques provided by this library to animate your component’s properties, the most basic being `Animated. For more information about Tailwind's responsive design features, check out the Responsive. inOut(Easing. animation-timing-function: steps(3, end) Values ease Default. I'm using keyframes and an animation-timing-function of steps (3). For keyframed animations, the timing function applies between keyframes rather than over the entire animation. Description. The animation is created by gradually changing from one set of CSS styles to another. Syntax:An animation (let's say w/ 4 steps) when set to ease it will always ease every step of the animation. */ steps(2) These timing function are invalid :Overview. Add animation with the animation property. For example, although mathematically we might expect that a step timing function with a step position of jump-start would step up (i. Sorted by: 2. With the linear timing function, the animation is going through the keyframes at a constant speed. If no animation-timing-function is specified on a keyframe, the corresponding value of animation-timing-function from the element to which the animation is applied is used for that keyframe. For a keyframed animation, the animation-timing-function applies between keyframes, not over the entire animation. In other words, the timing function is. div { width: 200px; height: 200px; animation: bg 4s steps(1) infinite; } @keyframes bg { 0% { background: blue; } 50% { background: grey; } }. transition-timing-function: steps(8, end); Animations. I have a div where I'm animating the width from 0 to 100% in 3 steps. To show this we are going to begin creating a simple. See animation iteration count for more examples. item. animation-timing-function: establishes preset acceleration curves such as ease or linear. And draw can go beyond properties, create new elements for like fireworks animation or something. Para animaciones con keyframes, la timing function se aplica entre los keyframes en lugar de sobre toda la animación. animation-timing-function: Specifies the speed curve of the animation; animation-delay: Specifies a delay for the start of an animation; animation-iteration-count:. config. 1. The animation-timing-function CSS property sets how an animation progresses through the duration of each cycle. auto Experimental. animation-delay: value; Xem DemoInstead of repeating the animation infinite times, you can specify a number of repetitions like this: animation: spin 3s 3 ease-in-out; /* 3secs, repeat 3 times */. 1 Answer. That is, you can specify a timing function using the easing property. Using this timing function, the animation jumps immediately to the end state and stay in that position until the end of the animation. 5s; Now we’ve created our fly cycle, our bird is presently fluttering her wings, however, isn’t going anyplace. About External Resources. You are still missing two things. The non-step keyword values (ease, linear, ease-in-out, etc. And draw can go beyond properties, create new elements for like fireworks animation or something. By using steps () with an integer, you can define a specific number of steps before reaching the end. The output progress value is current step / jumps. 第一个参数 n 是一个正整数,表示阶跃次数,. start 表示一开始就先进行阶跃, end 表示每阶段完成后再进行阶跃,. A segment will use the animation-timing-function that is active at the start of the segment. */ steps(2, start) /* The second parameter is optional. The animation-timing-function CSS property sets how an animation progresses through the duration of each cycle. The default value is 0, which means that no animation will occur. These timing functions are valid : /* There is 5 treads, the last one happens right before the end of the animation. The optional start and end values define where these steps take place. */ steps(5, end) /* A two-step staircase, the first one happening at the start of the animation. If you are planning on using custom cubic-bezier function, we would recommend using cubic-bezier. <easing-function> Each <easing-function> represents the easing function to link to the corresponding property to transition, as defined in transition-property. 2-The animation starts slowly and accelerates gradually until the end. Una de esas características nos informa del Animation. If no animation-timing-function is specified on a keyframe, the corresponding value of animation-timing-function from the element to which the animation is applied is used for that keyframe. animation. キーフレームに animation-timing-function が指定されていない場合、そのキーフレームにはアニメーションが適用された要素から animation-timing-function の適切な値が. Description. Technically, the implementation would involve transform, transform-origin, animation-timing-function and several more calculations. I did the following code in SCSS (you can see in the pen above ). A more natural approach would be to accelerate, maintain speed, and then "brake":Step 3: Add the Magic. In other words, t is the same as animation progress. It is defined by a number of steps and a step position. I copied “cabins 10s linear infinite” and pasted it after the animation property in the cabin selector. The following code will make the transition stay on the last frame: -webkit-timing-function:ease; -webkit-iteration-count:1; This is wrong, it's forwards, not the iteration count. animation-timing-function: steps(30, end) makes the animation play in a stepwise manner, instead of smoothly. Landing, step 1. The value must be positive or zero. The non-step keyword values (ease, linear, ease-in-out, etc. I want to be able to change animation-timing-function and -webkit-animation-timing-function etc. 5); } Until then, feel free to use this generator for anything you need, and if you have any thoughts or suggestions about how to improve this method, write them in. animation-timing-functionの値一覧. As you can see, the hand jumps to the 5-second. The final transition property is CSS transition-delay. The non-step keyword values (ease, linear, ease-in-out, etc. you can apply an animation-timing-function that adds personality to. I'm using keyframes and an animation-timing-function of steps(3). Let’s take a look at one more possible class of animation-timing-function values — steps. Here, we want to use the steps() value, which breaks the transition into equal segments. linear The animation begins and progresses at a constant rate over the specified duration; this value is equivalent to cubic-bezier(0,0,1,1)In This Article. The keyword values ease, linear, ease-in, ease-out, and ease-in-out are serialized as-is, that is, they are not converted to the equivalent cubic. But it becomes very simple if we devote a bit time to it. cabin selector, you can use the animation property to set these all at once. The typewriter effect relies on the CSS step() timing function and animation-fill-mode: forwards. Put all your images in one sprite by creating a line of frames that preserves the images’ order, i. The way these work is that they progress the animation in steps — as opposed to a smooth curve like the Bézier curve functions. And when done well it can WOW your audience. alternate. transition-timing-function. The animation has a slow start, then fast, before it ends slowly. Note : When you specify multiple comma-separated values on an animation-* property, they will be assigned to the animations specified in the animation-name property in different ways depending on how many there are. These timing functions are valid : /* There is 5 treads, the last one happens right before the end of the animation. Animation steps are performed backwards, and easing functions are also reversed. animation-duration: 1. 2: . Specify when the style change will happen in percent, or with the keywords "from" and "to", which is the same as 0%. Timing functions may be specified on individual keyframes in a @keyframes rule. animation-duration: value; Note: if you don't define the duration for the animation, it will not run at all, as the default value is 0s. Ease-in and Ease-out: Animations with Ease-in start slowly and speed up until the animation cycle is complete, while Ease. Transition-timing-function This property can greatly change the look of your animation. Sorted by: 1. keyframes object, then add the animation to theme. Just put a URL to it here and we'll apply it, in the order you have them, before the CSS in the Pen itself. It divides the duration from 0% to 100% into 2 parts which are 0% – 50% and 50% – 100% respectively. In between each stop the interpolation is done in a linear way, explaining the name of the function. , the first image will be the leftmost and the last image will be the rightmost. . At the end of this tutorial, you’ll understand how to create an animation that uses both a fan-out and a bounce effect. For a keyframed animation, the animation-timing-function applies between keyframes, not over the entire animation. yes, lets say, when I press A, I would like to get the same effect that I already have when you click, it swap the classes and makes a switch, animation play, animation reverse, I did that calling default2 which plays and back which plays default2 in reverse. Easing functions may be specified on individual keyframes in a @keyframes rule. Share. */ steps(2, start) /* The second parameter is optional. Link to. See scroll() for more information. */ steps(2) These timing function are invalid :CSS transition-timing-function Property. The non-step keyword values (ease, linear, ease-in-out, etc. With the linear timing function, the animation is going through the keyframes at a constant speed. transitionTimingFunction or theme. ) animation-timing-function. animation-timing-function: steps(4, end); By using steps() with an integer, you can define a specific number of steps before reaching the end. Link to Codepen Example. Using the steps() function you can force the interpolation to be an exact number of keyframes. Introduction. . 2. 0, 0. blink { -webkit-animation: blinker 1s step-end infinite; animation: blinker 1s step-end infinite; }…In other words, the animation-timing-function property specifies the speed for implementing the animation at various intervals of its duration. In this video, learn how to use the steps() timing function to create a sprite animation with CSS. ) each represent cubic Bézier curve with fixed four point values, with the cubic-bezier() function value allowing for a non-predefined value. 1. If no animation-timing-function is specified on a keyframe, the corresponding value of animation-timing-function from the element to which the animation is applied is used for that keyframe. Try it It is often convenient to use the shorthand property animation to set all animation properties at once. Will it start slowly and then go fast, or vice versa. animation-direction: sets the direction of the animation after the cycle. This feature specifies the speed curve of an. 5s; Now we’ve created our fly cycle, our bird is currently flapping her wings but isn’t going anywhere. steps Timing FunctionIf you want to skip gradual transition completely, you can use animation-timing-function: step-end (or steps(1,end); but you have to move your "target" state to the "middle" keyframe). Timing functions. For example, an ease-in easing function becomes ease-out. The @keyframes rule specifies the animation code. The linear easing function: linear The linear easing function is an identity function meaning that its output progress value is equal to the input progress value for all inputs. step-start: Equivalent to steps(1, start) step-end: Equivalent to steps(1, end) steps(int,start|end) Specifies a stepping function, with two parameters. The animation-iteration-count property specifies the iteration count of the animation’s associated. If no animation-timing-function is specified on a keyframe, the corresponding value of animation-timing-function from the element to which the animation is applied is used for that keyframe. As the name implies, this enables you to set a delay between when the transition is triggered, and when the animation actually begins. ttf-ease, . のようにY方向に100pxの間隔で5コマを並べたSprite画像があるとして、 Description. This is exactly the effect we want — we need each frame to be played in a sequence — so set the number of steps to 6 as there are six frames in the animation. Ease: Animations with this timing function start slowly, speed up, and slow down as they reach the end of the animation cycle. You can use steps as your timing-function to pause the animation until the next keyframe. 1 Value Definitions. timing`. 9, 0. ttf-ease-in, etc. 3-The animation starts quickly and decelerates gradually until the end. Within a keyframe, animation-timing-function is an at-rule. ¿Qué podemos animar en una web? La propiedad animation nos permite animar muchas de las propiedades CSS: color, posición, márgenes, paddings (no puedo llamarle rellenos 😅), opacidad o tamaños. transition. Animation Timing. I require the animation to be non-linear and stepped, such as having the first two steps be faster, and the last step slower. */ steps(5, end) /* A two-step staircase, the first one happening at the start of the animation. The steps Timing Function. I'm using this in my stylesheet in Harlowe 3. Description . Within a keyframe, animation-timing-function is an at-rule-specific. Squash and Stretch. 第二个参数 start 或 end ,表示阶跃点,. The animation-timing-function property is used to specify a timing function which defines the speed over time of an object being animated. e. The ‘animation-timing-function’ in CSS determines how fast your animation will play: animation-timing-function: value; To make the changes smoother, a speed curve is used. First of all, define some basic CSS styles for the “ . Saved searches Use saved searches to filter your results more quickly こちらはCSSアニメーションのイージングプロパティ(animation-timing-function)で指定可能な値と、比較用の動作サンプル集になります。. js file. cabin rule to cabins 10s linear infinite. This acceleration curve is defined using one <easing-function> for each property to be transitioned. In other words, the timing function is applied at the start of the keyframe and at the end of the keyframe. animation-name: fly-cycle; animation-timing-function: steps(10); animation-iteration-count: infinite; animation-duration: 1s; animation-delay: -0. It applies built in eases such as ease-in or you can define a cubic-bezier for a more custom ease. Here are some more animation forms: ease-in, ease-out and ease-in-out. animation-timing-function is the timing-function used for the animation. In other words, each time the animation cycles, the animation will reset to the end state and start over again. ) each represent cubic Bézier curve with fixed four point values, with the cubic-bezier() function value allowing for a non-predefined value. 伸縮バーでイージングアニメーションを比較. However, you can also set custom styles for it according to your needs. Then speeds it up and ends it slowly. In general, animation-timing-function is basically divided into two types of functions: 1. In some cases, this is desirable; however, in the real world, motion usually doesn’t work like that. Steps. 2,1) or 1,0,0,1 - with short duration it is quite. The CSS animation-timing-function defines the pace of your. Linear Functions. animation-duration: 4s; animation-timing-function. It should be something like this:Timing Functions in CSS Animations. Use animation-timing-function: linear; to get even animation speed. Have the animation last 3s, infinitely iterate, and have a linear timing function. Source. I'm trying to get the animation to scale up and down in a bouncy way using the animation timing function. animation-timing-function: ease-in, linear; Each timing function is applied to the corresponding animation as specified by the animation-name property. animation-timing-function: linear|ease|ease-in|ease-out|ease-in-out|step-start|step-end|steps (int,start|end)|cubic-bezier ( n, n, n, n )|initial|inherit; The animation-timing-function uses a mathematical function, called the Cubic Bezier curve, to make the speed curve. Slow function: It describes the rate at which one-dimensional values change in a transition or animation. The steps() timing function is unique to CSS and can be used to create some interesting effects. Moreover, the CSS step() function will break the animation into segments; in this case, it’s the text that will be broken into segments. The function takes two parameters — the first specifies the positive number of steps we want our animation to take. 以上这 8 个属性就决定了 Animation 能够实现一个什么样的动画效果。 本文主要介绍 timing-function中的steps()函数。Animation 在执行动画时默认以 ease函数进行过渡,ease 会在每个关键帧之间插入补间动画,所以动画效果是连贯的。除了ease函数之外,linear和cubic-bezier(贝塞尔曲线)等过渡函数也会为其插入. As an individual value, steps() is associated with the animation-timing-function: animation-timing-function: steps(4); start and end. Config is an object that may have the following options: duration: Length of animation (milliseconds). 下4つをまとめて指定可能. com steps() is a timing function that allows us to break an animation or transition into segments, rather than one continuous transition from one state to another. ) each represent cubic Bézier curve with fixed four point values, with the cubic-bezier() function value allowing for a non-predefined value. ) correspondent à une courbe de Bézier cubique fixe avec quatre valeurs prédéfinies; La fonction cubic-bezier() permet de paramétrer une courbe spécifique. This acceleration curve is defined using one <easing-function> for each property. You are free to choose the length. The timing is not being animated. It basically tell CSS to render the element at its initial state until the time runs out, and then immediately render the end state. Edit timing functions¶ When you create a CSS animation you can specify a timing function: this determines the rate at which the animation progresses. Animation Timing Function. animation-timing-function: establishes preset acceleration curves such as ease or linear. steps (num_of_steps, direction) num_of_steps可以简单理解为整个动画过程要跳几步,要求是一个正整数. Make changes to your css like: -webkit-animation-timing-function: steps (1); -moz-animation-timing-function: steps (1); animation-timing-function: steps (1); Tweak them with different values to get desired animation , currently they show and stop at each of 21 frames. ease-in. Syntax: animation-timing-function: linear | ease | ease-in | ease-out | ease-in-out |step-start | step-end| steps(int, start | end) | cubic-bezier. CSSでアニメーションするには、keyframesとanimationプロパティの2つを組み合わせます。 keyframesでどのような時刻にどのような状態かを指定し、animationプロパティで時刻の変化の仕方を指定します。 The animation-timing-function CSS property sets how an animation progresses through the duration of each cycle. To learn more, see the Color Schemes documentation. The animation-timing-function CSS property sets how an animation progresses through the duration of each cycle. 伸縮バーでイージングアニメーションを比較. Los posibles valores son una o varias <timing-function> (en-US). A @keyframes rule specifies the style. thanks for the answer! understand what you're saying about fill-mode and direction, but see an issue with steps. So, for our new animation, the utility class should look something like this:Try it. Pre- and post-animation state: animation-fill-mode, step. Animation-timing-function, step 3. transition-timing-function: steps(4, start); transition-timing-function: steps(4, end); A value of start would run the animation at the beginning of each step, whereas a value of end would run the. <easing-function> The easing function that corresponds to a given animation, as determined by animation-name. Easing functions may be specified on individual keyframes in a @keyframes rule. Cubic Bézier easing functions: ease, ease-in, ease-out, ease-in-out, cubic-bezier() A. Resumen. easing: Easing function to define curve. 30 is the number of steps the animation takes, and these steps are spread evenly until the end of the animation. Specifies the speed curve of an animation. css property: animation-timing-function: `jump-` keywords for `steps()` Can I use. animation-timing-function 除了上面的几种常用方式之外,还有个一实用的函数,steps(number_of_steps, direction),这个函数叫做阶梯函数. 目次. 애니메이션을 적용하려면 애니메이션 이름을 반드시 설정해야 하지만, animation 축약의 모든 값은 선택 사항이며, 각 animation 구성 요소의 초기 값이 기본값입니다. An animation-timing-function defined within a keyframe block applies to. We update the value of each variable on hover (or toggle, or whatever). animation: move 1s 部分就是动画的第一部分,用于描述动画的各个规则;; @keyframes move {} 部分就是动画的第二部分. The timing function that corresponds to a property to animate, as determined by animation-property. The possible values are one or several <timing-function>. ) each represent cubic Bézier curve with fixed four point values, with the cubic-bezier() function value allowing for a non-predefined value. This replaces the smooth. Step start will take effect when the playhead reaches the first keyframe, in this case right when I hit play, because the keyframe is at 0 seconds. If no animation-timing-function is specified on a keyframe, the corresponding value of animation-timing-function from the element to which the animation is applied is used for that keyframe. The transition-timing function specifies the time an animation uses to change from one set of CSS transitions to another. The animation-timing-function property can have the following values: ease - Specifies an animation with a slow start, then fast, then end slowly (this is default) linear - Specifies. e. Multiple steps. @keyframes rules don't cascade, so animations never derive keyframes from more than one rule set. Definition and Usage. Result: CSS Code: #myDIV { animation-timing-function: ease-in-out; } Click the property values above to see the result. step-start: Equivalent to steps(1, start) step-end: Equivalent to steps(1, end) steps(int,start|end) Specifies a stepping function, with two parameters. -webkit-animation-timing-function: steps(1,end); animation-timing-function: steps(1,end); See this jsFiddle. Similar to “transition-timing-function”, the “animation-timing-function” works on the complete keyframe (i. 2 Answers. You can customize these values by editing theme. You can apply CSS to your Pen from any stylesheet on the web. This lets you vary the animation's speed over the course of its duration. /* @keyframes duration | timing-function | delay | iteration. e. **Your code. Now, you can easily fine-tune your style for the color schemes. This acceleration curve is defined using one <easing-function> for each property to be transitioned. In order to move her across the screen, we create another keyframe animation. The animation-timeline CSS property specifies the timeline that is used to control the progress of a CSS animation. By default, the animation-timing-function is set to ease if not specified by the developer. property:. The animation-timing-function CSS property sets how an animation progresses through the duration of each cycle. The number of times the animation will repeat; this is 1 by default. Equal to cubic-bezier (0. animation-timing-function: steps(4, end); By using steps() with an integer , you can define a specific number of steps before reaching the end. In this video, learn how to use the steps() timing function to create a sprite animation with CSS. The animation-timing-function CSS property sets how an animation progresses through the duration of each cycle. The step-end keyword causes the animation to remain in the start. Let's define each below. The animation-timing-function can work with any of the easing functions, as well as three other timing. I'm trying to write an Android equivalent of the CSS cubic-bezier animation timing function using a custom TimeInterpolator. The steps () method is a timing function in animation property that divides an animation into n steps, displaying each step at equal intervals of time. My question is, whether it is possible to apply the animation timing function for all 4 steps altogether without having to run some complicated math w/ a cubic bezier. Default 500. The last timing function we will look at is something that affects the rate at which our properties change but isn't technically a timing function. 5s; animation-timing-function: elastic(7, 1. That will be a blinking cursor at the end of the text. ease). A JS-free solution would be to put the couting numbers actually in the HTML and then animate between those with. Responsive. About External Resources. animation-timing-function: linear: animation-timing-function: linear; Chuyển động sẽ cùng tốc độ từ lúc bắt đầu tới lúc kết thúc. 时间并没有被动画化。. . 複数. As the name implies, this enables you to set a delay between when the transition is triggered, and when the animation actually begins. CSS /* Keyword values */ animation-timing-function: ease; animation-timing-function: ease-in; animation-timing-function: ease-out; animation-timing-function: ease-in-out;. ) each represent cubic Bézier curve with fixed four point values, with the cubic-bezier() function value allowing for a non-predefined value. shewine: animation-name: cabins; animation-duration: 10s; animation-iteration-count: infinite; animation-timing-function: linear; shewie you written all thing correct but you need write to in one property called animation. Create a reference variable of Animated. The animation-timing-function property specifies the speed curve of the animation. animation-name 의 초기 값은 none 입니다. To create a CSS animation sequence, you style the element you want to animate with the animation property or its sub-properties. CSS3帧动画. Creating the leaves. Description. Animation-timing-function: This animation attribute specifies how an animation transitions through keyframes by establishing acceleration curves. Easing functions may be specified on individual keyframes in a @keyframes rule. It is the way actions. The animation-timing-function CSS property sets how an animation progresses through the duration of each cycle. –La propriété animation-timing-function définit comment la vitesse de l'animation va changer pendant chaque cycle, et pas pandent l'animation entière. The keyword values ease, linear, ease-in, ease-out, and ease-in-out are serialized as-is, that is, they are not converted to the equivalent cubic. 1 Answer. The non-step keyword values (ease, linear, ease-in-out, etc. 目次. Timing functions may be specified on individual keyframes in a @keyframes rule. Demo: Syntax. linear. The steps() easing function lets you break the timeline into defined, equal intervals. To apply it to the whole animation you can use:These timing functions are valid : /* There is 5 treads, the last one happens right before the end of the animation. For now, we have to fiddle with the percentages of the time to create the custom timing like:The W3Schools online code editor allows you to edit code and view the result in your browserAnimation steps are performed backwards, and timing functions are also reversed. If no animation-timing-function is specified on a keyframe, the corresponding value of animation-timing-function from the element to which the animation is applied is used for that keyframe. animation-timing-function 除了上面的几种常用方式之外,还有个一实用的函数,steps(number_of_steps, direction),这个函数叫做阶梯函数. <step-easing-function> Specifies a steps() function that divides the animation into a set number of equal-length intervals or "steps", causing the animation. For keyframed animations, the timing function applies between keyframes rather than over the entire animation. The syntax for the linear easing function is simply the linear keyword. Rocket to the launch pad, step 1. You can achieve it using the animation-timing-function: steps(1) as given in below snippet. La lista de propiedades CSS que pueden ser animadas está disponible; cabe señalar que estas son las mismas. Note: When you specify multiple comma-separated values on an animation-* property. We’ve covered linear functions in one of the previous examples, so let’s do a quick recap. Squash and stretch is applied to give a sense of weight and/or flexibility to objects or even to people. Viewed 331 times 0 I've been trying to blink two colors, using the following CSS rules but the colors just ends up blending. Arguably the most fundamental of the 12 principles of animation. Just put a URL to it here and we'll apply it, in the order you have them, before the CSS in the Pen itself. css. About External Resources. If no timing function is specified for. Serialization. Timing Functions. Here is the jsfiddle:. The steps () functional notation defines a step function dividing the domain of output values in equidistant steps. */ steps(5, end) /* A two-step staircase, the first one happening at the start of the animation. I'm using keyframes and an animation-timing-function of steps(3). Example. jump-end. The animation-timing-function CSS property sets how an animation progresses through the duration of each cycle. In This Article. alternate The animation reverses direction each cycle, with the first iteration being played forwards. Unlike CSS animations you can either apply this to the whole animation or between individual keyframes. The animation-composition property helps to specify how to combine the underlying value with the effect value. <step-easing-function> Specifies a steps() function that divides the animation into a set number of equal-length intervals or "steps", causing the animation to jump from one step to the next rather than transitioning smoothly. steps() is part of the animation timing function. Description. CSS свойство animation-timing-function CSS свойства Определение и применение. The animation-timing-function CSS property sets how an animation progresses through the duration of each cycle. This, in essence, lets you establish an acceleration curve so that the speed of the transition can vary over its duration. Read more about animation-timing-function and steps function at Mozilla Developer. animation-timing-function is never used in Method 2 and Method 3. This is important because it creates the “typed” effect. In the world of web development, user experience is king. . The animation-iteration-count property. Rocket to the launch pad, step 2. animation-timing-functionの設定方法. There is. As per MDN (picked from definition for step-start but it is same as steps(1, start)):. Here is where the magic happens. See the Pen CSS Animation Example 3 by Kelby Gassman on CodePen.