forked from LedFx/LedFx
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdroplet_creator.py
49 lines (38 loc) · 1.52 KB
/
droplet_creator.py
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
import os
import numpy as np
# duration of droplet animation
N_FRAMES = 60
# size of animation on strip (will probably be scaled anyway)
WIDTH = 60
# name this droplet animation
NAME = "my_cool_droplet"
# Write a function that takes:
# x values eg. np.array([-3, -2, -1, 0, 1, 2, 3])
# frame count eg. 4
# and returns an array the same shape as x, with some maths done to it!
# Each value of the frame corresponds to pixel brightness (0-1)
# You should check these examples for how to write a function that does this.
# Simple example: https://www.desmos.com/calculator/hg4uezvvuf
# Hard example: https://www.desmos.com/calculator/esmm3pfngm
def droplet_maths(x: np.ndarray, frame_counter: int) -> np.ndarray:
return np.sin(x + frame_counter)
# No touching below here
radius = WIDTH // 2
_, droplet = np.mgrid[:N_FRAMES, -radius:radius]
for frame_counter, x in enumerate(droplet):
frame = droplet_maths(x, frame_counter)
# clip the values to between 0 and 1
frame[frame < 0] = 0
frame[frame > 1] = 1
droplet[frame_counter, :] = frame
# automatically generate filename and save
dir_path = os.path.dirname(os.path.realpath(__file__))
droplets_location = os.path.join(dir_path, "ledfx", "effects", "droplets")
assert os.path.isdir(droplets_location)
path = os.path.join(droplets_location, f"{NAME}.npy")
i = 0
while os.path.exists(path):
i += 1
path = os.path.join(droplets_location, f"{NAME}_{i}.npy")
np.save(path, droplet)
print(f"Done! Saved as {NAME}_{i}.npy - restart LedFx to see it in action.")