-
Notifications
You must be signed in to change notification settings - Fork 1
/
__main__.py
70 lines (53 loc) · 1.67 KB
/
__main__.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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
"""2024-09-19
Esfera 03
Estudo sobre esferas multicoloridas
png
Sketch,py5,CreativeCoding
"""
import numpy as np
import py5
from utils import helpers
sketch = helpers.info_for_sketch(__file__, __doc__)
raio: int = 300
pontos = []
def calcula_esfera(num: int, raio: int = 200):
indices = np.arange(0, num, dtype=float) + 0.5
phi = np.arccos(1 - 2 * indices / num)
theta = np.pi * (20 + (5**0.5)) * indices
x, y, z = np.cos(theta) * np.sin(phi), np.sin(theta) * np.sin(phi), np.cos(phi)
pontos = []
for i in range(0, num):
pontos.append((x[i] * raio, y[i] * raio, z[i] * raio))
return pontos
def setup():
global pontos
py5.size(helpers.LARGURA, helpers.ALTURA, py5.P3D)
py5.background(0)
py5.color_mode(py5.HSB, 360, 100, 100)
pontos.extend(calcula_esfera(500, raio))
def draw():
py5.background(0)
py5.stroke_weight(3)
frame = py5.frame_count
with py5.push_matrix(), py5.push_style():
py5.translate(py5.width / 2, py5.height / 2, 0)
py5.rotate_y(py5.radians(frame))
py5.rotate_z(py5.radians(frame))
for x, y, z in pontos:
h = py5.remap(x, -raio, raio, 0, 360)
s = py5.remap(x, -raio, raio, 50, 100)
b = py5.remap(x, -raio, raio, 50, 100)
cor = py5.color(h, s, b)
py5.stroke(cor)
py5.line(x, y, z, x / 1.2, y / 1.2, z / 1.2)
helpers.write_legend(sketch=sketch, frame="#fff", cor="#000")
def key_pressed():
key = py5.key
if key == " ":
save_and_close()
def save_and_close():
py5.no_loop()
helpers.save_sketch_image(sketch)
py5.exit_sketch()
if __name__ == "__main__":
py5.run_sketch()