"""2025-08-05
Colorido geométrico IV
Hexágonos distribuídos em uma grade, com cores baseadas em senoides e cossenoides.
ericof.com
png
Sketch,py5,CreativeCoding
"""
from sketches.padroes.poligonos import gera_poligono_regular
from sketches.utils.draw import canvas
from sketches.utils.draw.grade import cria_grade_ex
from sketches.utils.helpers import sketches as helpers
import py5
sketch = helpers.info_for_sketch(__file__, __doc__)
LARGURA = 30
ALTURA = 30
LADOS = 6
forma: py5.Py5Shape | None = None
def setup():
global forma
py5.size(*helpers.DIMENSOES.external, py5.P3D)
py5.color_mode(py5.HSB, 360, 100, 100)
py5.shape_mode(py5.CORNER)
forma = gera_poligono_regular(
lados=LADOS, largura=LARGURA, altura=ALTURA, rotacao=py5.PI / LADOS
)
def cores_posicao(idx, idy, linhas, colunas) -> tuple[int, int]:
"""Calcula as cores baseadas na posição da grade."""
meio_x = colunas // 2 == idx
meio_y = linhas // 2 == idy
h = 80 if not (meio_x or meio_y) else 340
s = 100
b = 100
preenchimento = py5.color(h, s, b)
h -= 360
s -= py5.sin(idy * 0.1) * 100
traco = py5.color(abs(h), abs(s), b)
return preenchimento, traco
def draw():
cor_fundo = py5.color(0)
py5.background(cor_fundo)
grade = cria_grade_ex(
largura=py5.width,
altura=py5.height,
margem_x=0,
margem_y=0,
celula_x=LARGURA,
celula_y=ALTURA,
alternada=True,
)
colunas = py5.width // LARGURA
linhas = py5.height // ALTURA
meio = linhas // 2
if forma is not None:
forma.set_stroke_weight(2)
for idx, x, idy, y in grade:
preenchimento, traco = cores_posicao(idx, idy, linhas, colunas)
forma.set_fill(preenchimento)
forma.set_stroke(traco)
z = (10 * ((idy - meio) / meio)) - 30
with py5.push():
py5.translate(x, y, z)
# Desenho da forma
py5.shape(forma, 0, 0)
# Credits and go
canvas.sketch_frame(
sketch, cor_fundo, "large_transparent_white", "transparent_white"
)
def key_pressed():
key = py5.key
if key == " ":
save_and_close()
def save_and_close():
py5.no_loop()
canvas.save_sketch_image(sketch)
py5.exit_sketch()
if __name__ == "__main__":
py5.run_sketch()