-
Notifications
You must be signed in to change notification settings - Fork 6
/
Copy pathgrad.go
58 lines (52 loc) · 1.08 KB
/
grad.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
package main
type Gradient []Color128
func New() Gradient {
return make(Gradient, 0)
}
func (grad *Gradient) Append(c Color128) {
*grad = append(*grad, c)
}
func clamp(v, min, max float64) float64 {
if v < min {
return min
}
if v > max {
return max
}
return v
}
func (grad Gradient) Index(i float64) (int, float64) {
n := len(grad)
if n == 0 {
return -1, -1
}
c := clamp(i, 0, 1)
if c == 1 {
return n - 1, 0.0
}
x := int(c * float64(n-1))
return x, (c - float64(x)/float64(n-1)) * float64(n-1)
}
func (grad Gradient) ColorAt(i float64) Color128 {
n := len(grad)
if n == 0 {
return Color128{}
}
if n == 1 {
return grad[0]
}
nx, ni := grad.Index(i)
if nx >= n-1 {
return grad[nx]
}
r := (float64(grad[nx+1].R)-float64(grad[nx].R))*ni + float64(grad[nx].R)
g := (float64(grad[nx+1].G)-float64(grad[nx].G))*ni + float64(grad[nx].G)
b := (float64(grad[nx+1].B)-float64(grad[nx].B))*ni + float64(grad[nx].B)
a := (float64(grad[nx+1].A)-float64(grad[nx].A))*ni + float64(grad[nx].A)
return Color128{
R: uint32(r),
G: uint32(g),
B: uint32(b),
A: uint32(a),
}
}