Normand Briere
2016-02-27 28ab4dad99d24372ea58b09a00eafbce1291c278
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
package aurelienribon.tweenengine.equations;
 
import aurelienribon.tweenengine.TweenEquation;
 
/**
 * Easing equation based on Robert Penner's work:
 * http://robertpenner.com/easing/
 * @author Aurelien Ribon | http://www.aurelienribon.com/
 */
public abstract class Bounce extends TweenEquation {
   public static final Bounce IN = new Bounce() {
       @Override
       public final float compute(float t) {
           return 1 - OUT.compute(1-t);
       }
 
       @Override
       public String toString() {
           return "Bounce.IN";
       }
   };
 
   public static final Bounce OUT = new Bounce() {
       @Override
       public final float compute(float t) {
           if (t < (1/2.75)) {
               return 7.5625f*t*t;
           } else if (t < (2/2.75)) {
               return 7.5625f*(t-=(1.5f/2.75f))*t + .75f;
           } else if (t < (2.5/2.75)) {
               return 7.5625f*(t-=(2.25f/2.75f))*t + .9375f;
           } else {
               return 7.5625f*(t-=(2.625f/2.75f))*t + .984375f;
           }
       }
 
       @Override
       public String toString() {
           return "Bounce.OUT";
       }
   };
 
   public static final Bounce INOUT = new Bounce() {
       @Override
       public final float compute(float t) {
           if (t < 0.5f) return IN.compute(t*2) * .5f;
           else return OUT.compute(t*2-1) * .5f + 0.5f;
       }
 
       @Override
       public String toString() {
           return "Bounce.INOUT";
       }
   };
}