-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathgween.go
79 lines (72 loc) · 2.23 KB
/
gween.go
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
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
// Package gween provides the Tween struct that allows an easing function to be
// animated over time. This can be used in tandem with the ease package to provide
// the easing functions.
package gween
import "github.com/tanema/gween/ease"
type (
// Tween encapsulates the easing function along with timing data. This allows
// a ease.TweenFunc to be used to be easily animated.
Tween struct {
duration float32
time float32
begin float32
end float32
change float32
Overflow float32
easing ease.TweenFunc
reverse bool
}
)
// New will return a new Tween when passed a beginning and end value, the duration
// of the tween and the easing function to animate between the two values. The
// easing function can be one of the provided easing functions from the ease package
// or you can provide one of your own.
func New(begin, end, duration float32, easing ease.TweenFunc) *Tween {
return &Tween{
begin: begin,
end: end,
change: end - begin,
duration: duration,
easing: easing,
Overflow: 0,
reverse: false,
}
}
// Set will set the current time along the duration of the tween. It will then return
// the current value as well as a boolean to determine if the tween is finished.
func (tween *Tween) Set(time float32) (current float32, isFinished bool) {
switch {
case time <= 0:
tween.Overflow = time
tween.time = 0
current = tween.begin
case time >= tween.duration:
tween.Overflow = time - tween.duration
tween.time = tween.duration
current = tween.end
default:
tween.Overflow = 0
tween.time = time
current = tween.easing(tween.time, tween.begin, tween.change, tween.duration)
}
if tween.reverse {
return current, tween.time <= 0
}
return current, tween.time >= tween.duration
}
// Reset will set the Tween to the beginning of the two values.
func (tween *Tween) Reset() {
if tween.reverse {
tween.Set(tween.duration)
} else {
tween.Set(0)
}
}
// Update will increment the timer of the Tween and ease the value. It will then
// return the current value as well as a bool to mark if the tween is finished or not.
func (tween *Tween) Update(dt float32) (current float32, isFinished bool) {
if tween.reverse {
return tween.Set(tween.time - dt)
}
return tween.Set(tween.time + dt)
}