Colisões 11

2025-05-07

"""2025-05-07
Colisões 11
Grades com padrões fabricados
png
Sketch,py5,CreativeCoding
"""

from collections import defaultdict

import numpy as np
import py5

from padroes import biblioteca as b
from padroes import tipos as t
from padroes.fabrica import GradeLinearPadroes
from utils import helpers
from utils.draw import gera_paleta

sketch = helpers.info_for_sketch(__file__, __doc__)


def gera_colecao() -> list[t.Padrao]:
    payload = {"traco": 8}
    colecao = [
        padrao(**payload) for padrao in b.Biblioteca.get_categoria("tracos").values()
    ]
    return colecao


def gera_cores_padrao(idz: int) -> t.CoresPadrao:
    nome_paleta = [
        "franca-01",
        "italia-01",
        "basco-01",
        "brasil-01",
    ][idz % 4]
    paleta = gera_paleta(nome_paleta)
    fundo = None
    valida = False
    while not valida:
        preenchimento = py5.random_choice(paleta)
        traco = py5.random_choice(paleta)
        valida = preenchimento != traco != py5.color("#FFF")
    return t.CoresPadrao(traco, preenchimento, fundo)


def setup():
    py5.size(helpers.LARGURA, helpers.ALTURA, py5.P3D)
    py5.background(0)
    colecao = gera_colecao()
    with py5.push():
        py5.translate(0, 0, -200)
        py5.rect_mode(py5.CORNER)
        py5.fill("#333")
        py5.rect(-py5.width * 2, -py5.height * 2, py5.width * 4, py5.height * 4)
    celulas = 40
    espacamento = 1
    fundo = py5.color("#111")
    borda = t.Borda(fundo, espacamento)
    largura = 800
    rotacoes = range(0, 360, 45)
    imagens = defaultdict(list)
    for idz in range(0, 3):
        grade = GradeLinearPadroes(
            largura,
            largura,
            celulas,
            celulas,
            (espacamento, espacamento),
            colecao,
            borda=borda,
        )
        grade_padroes = grade.padroes
        z = -10
        for celula in grade.celulas:
            cores = gera_cores_padrao(idz)
            if idz == 0:
                cores.fundo = py5.color("#FFF")
            padrao = next(grade_padroes)
            rotacao = py5.random_choice(rotacoes)
            img = celula(padrao, rotacao, cores, False)
            key = (celula.x, celula.y, z, celula.largura, celula.altura)
            imagens[key].append(img)
    for key, imgs in imagens.items():
        x, y, z, lar, alt = key
        imgs = sum([img.get_np_pixels() for img in imgs])
        img = py5.create_image_from_numpy(imgs.astype(np.uint8))
        with py5.push():
            py5.translate(x, y, z)
            py5.image(img, 0, 0, lar, alt)
    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()