forked from vlang/ui
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtransition.v
141 lines (127 loc) · 3.28 KB
/
transition.v
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
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
// Copyright (c) 2020-2021 Leah Lundqvist. All rights reserved.
// Use of this source code is governed by a GPL license
// that can be found in the LICENSE file.
module ui
import time
[heap]
pub struct Transition {
mut:
// pub:
x int
y int
z_index int
offset_x int
offset_y int
last_draw_time i64
started_time i64
duration i64
animating bool
easing EasingFunction
parent Layout = empty_stack
start_value int
last_draw_target int
ui &UI = voidptr(0)
hidden bool
pub mut:
id string
target_value int
animated_value &int
}
pub struct TransitionConfig {
z_index int
duration int
animated_value &int = 0
easing EasingFunction
ref &Transition = voidptr(0)
}
pub fn transition(c TransitionConfig) &Transition {
mut transition := &Transition{
last_draw_time: time.ticks()
started_time: 0
duration: c.duration
animating: false
easing: c.easing
ui: 0
animated_value: 0
z_index: c.z_index
}
return transition
}
fn (mut t Transition) init(parent Layout) {
t.parent = parent
ui := parent.get_ui()
t.ui = ui
}
[manualfree]
pub fn (mut t Transition) cleanup() {
unsafe { t.free() }
}
[unsafe]
pub fn (t &Transition) free() {
$if free ? {
print('transition $t.id')
}
unsafe {
t.id.free()
free(t)
}
$if free ? {
println(' -> freed')
}
}
pub fn (mut t Transition) set_value(animated_value &int) {
t.animated_value = unsafe { animated_value }
t.start_value = *animated_value
t.target_value = *animated_value
t.last_draw_target = *animated_value
}
fn (t &Transition) set_pos(x int, y int) {
}
fn (t &Transition) propose_size(w int, h int) (int, int) {
return 0, 0
}
fn (mut t Transition) size() (int, int) {
return 0, 0
}
fn (mut t Transition) draw() {
if t.animated_value == 0 {
return
}
if t.target_value != *t.animated_value && !t.animating {
// Initiate the transition by setting start_time to the current time
// and set the start value to the current value of the transition target.
t.started_time = time.ticks()
t.start_value = *t.animated_value
t.animating = true
} else if t.animating && t.target_value != t.last_draw_target {
// Update the target and restart time if target changes
// while it's still animating the previous value change.
t.started_time = time.ticks()
t.start_value = *t.animated_value
}
if t.animating {
// Get the current progress of start_time -> start_time+duration
x := f32(time.ticks() - t.started_time + 1) / f32(t.duration)
// Map the progress value [0 -> 1] to [0 -> delta value]
// Using the defined EasingFunction
mut mapped := t.start_value + int(t.easing(x) * f64(t.target_value - t.start_value))
// Animation finished
if x >= 1 {
t.animating = false
mapped = t.target_value
}
// Update the target value and request a redraw
(*t.animated_value) = mapped
// t.ui.redraw_requested = true
t.ui.window.refresh()
// Set last_draw_target to check for target_value changes between renders.
t.last_draw_target = t.target_value
// Update last draw time to calculate frame delta
t.last_draw_time = time.ticks()
}
}
fn (t &Transition) set_visible(state bool) {
}
fn (t &Transition) point_inside(x f64, y f64) bool {
return false
}