-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathanimation.ts
58 lines (44 loc) · 2.38 KB
/
animation.ts
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
import { Animation, Easing, Game, getWindowDimensions, Interface, Renderer } from '../../dist/unrail-engine.es.js'
const { width, height } = getWindowDimensions()
const NB_TEST = 4
const offset = 25
const dimension = (width - 2 * NB_TEST * offset) / NB_TEST
let linear_x = new Animation(0, dimension, 2000, Easing.linear, { autostart: true, loop: true })
let linear_y = new Animation(dimension, 0, 2000, 'linear', { autostart: true, loop: true })
let easeIn_y = new Animation(dimension, 0, 2000, 'easeIn', { autostart: true, loop: true })
let easeOut_y = new Animation(dimension, 0, 2000, Easing.easeOut, { autostart: true, loop: true })
let easeInOut_y = new Animation(dimension, 0, 2000, Easing.easeInOutBack, { autostart: true, loop: true })
let speed = new Animation(0, width - 2 * offset, 2500, Easing.easeInOut, { autostart: true, loop: true })
let speed2 = new Animation(0, width - 2 * offset, 2500, Easing.linear, { autostart: true, loop: true })
let speed3 = new Animation(0, width - 2 * offset, 2500, Easing.easeIn, { autostart: true, loop: true })
function draw(ts) {
Renderer.clear()
Renderer.text('Linear', offset, offset + dimension + 20, { size: 16 })
Renderer.rect(offset, offset, dimension, dimension, { lineWidth: .5 })
Renderer.circle(offset + linear_x.value, offset + linear_y.value, .5)
Renderer.rect(dimension + 2 * offset, offset, dimension, dimension, { lineWidth: .5 })
Renderer.circle(dimension + 2 * offset + linear_x.value, offset + easeIn_y.value, 1)
Renderer.rect(2 * dimension + 3 * offset, offset, dimension, dimension, { lineWidth: .5 })
Renderer.circle(2 * dimension + 3 * offset + linear_x.value, offset + easeOut_y.value, 1)
Renderer.rect(3 * dimension + 4 * offset, offset, dimension, dimension, { lineWidth: .5 })
Renderer.circle(3 * dimension + 4 * offset + linear_x.value, offset + easeInOut_y.value, 1)
Renderer.circle(offset + speed.value, height / 2, 10)
Renderer.circle(offset + speed2.value, height / 2 + 25, 10)
Renderer.circle(offset + speed3.value, height / 2 + 50, 10)
}
let pause = false
Interface.addButton(() => pause ? '||' : '>', e => {
pause = !pause
linear_x.toggle()
linear_y.toggle()
})
Interface.addButton(() => 'Reset', e => {
linear_x.reset()
linear_y.reset()
})
const game = new Game('Animation Test')
Renderer.create()
game.setMainLoop(draw)
game.toggleStats()
game.setFPS(60)
game.start()