Calçada Bilbao 3

2023-10-11

"""2023-10-11"""
from helpers import CelulaV4 as Celula
from helpers import Grade
from helpers import HEIGHT
from helpers import save_image
from helpers import WIDTH
from helpers import write_legend
from pathlib import Path

import py5


IMG_NAME = Path(__file__).name.replace(".py", "")

CORES = [
    py5.color(240),
]

LADO = 50

FATOR = 0.6
FATOR_LARGURA_INTERNA = 0.85


def forma_01():
    limite = LADO * FATOR
    bz1 = LADO * FATOR
    s = py5.create_shape()
    with s.begin_shape():
        s.vertex(0, 0)
        s.vertex(0, LADO)
        s.vertex(limite, LADO)
        s.bezier_vertex(limite, LADO, bz1, bz1, LADO, limite)
        s.vertex(LADO, limite)
        s.vertex(LADO, 0)
        s.vertex(0, 0)
    return s


def forma_02():
    limite = LADO * FATOR
    bz1 = LADO * FATOR
    bz2 = (LADO - limite) * FATOR
    s = py5.create_shape()
    with s.begin_shape():
        s.vertex(0, 0)
        s.vertex(0, limite)
        s.bezier_vertex(0, limite, bz2, bz1, LADO - limite, LADO)
        s.vertex(LADO - limite, LADO)
        s.vertex(limite, LADO)
        s.bezier_vertex(limite, LADO, bz1, bz1, LADO, limite)
        s.vertex(LADO, 0)
        s.vertex(0, 0)
    return s


def forma_03():
    limite = LADO * FATOR
    bz1 = LADO * FATOR
    bz2 = (LADO - limite) * FATOR
    s = py5.create_shape()
    with s.begin_shape():
        s.vertex(0, 0)
        s.vertex(0, LADO)
        s.vertex(limite, LADO)
        s.bezier_vertex(limite, LADO, bz1, bz1, LADO, limite)
        s.vertex(LADO, limite)
        s.vertex(LADO, LADO - limite)
        s.bezier_vertex(LADO, LADO - limite, bz1, bz2, limite, 0)
        s.vertex(limite, 0)
        s.vertex(0, 0)
    return s


def circulo(s, inicio, meio, fim):
    s.vertex(inicio, meio)
    s.bezier_vertex(inicio, meio, inicio, inicio, meio, inicio)
    s.vertex(meio, inicio)
    s.bezier_vertex(meio, inicio, fim, inicio, fim, meio)
    s.vertex(fim, meio)
    s.bezier_vertex(fim, meio, fim, fim, meio, fim)
    s.vertex(meio, fim)
    s.bezier_vertex(meio, fim, inicio, fim, inicio, meio)
    s.vertex(inicio, meio)


def forma_centro():
    inicio = 0
    fim = LADO
    meio = fim // 2
    s = py5.create_shape()
    with s.begin_shape():
        circulo(s, inicio, meio, fim)
        with s.begin_contour():
            inicio = 6
            fim = LADO - inicio
            meio = (fim - inicio) // 2
            circulo(s, inicio, meio, fim)

    return s


def _factory(pontos):
    s = py5.create_shape()
    with s.begin_shape():
        for x, y in pontos:
            s.vertex(x, y)
    return s


def setup():
    py5.size(WIDTH, HEIGHT, py5.P3D)
    py5.background(py5.color(120))
    formas = [forma_01(), forma_02(), forma_03(), forma_centro()]
    linhas = 36
    colunas = 36
    margem = -1600
    bloco = 3
    largura = (py5.width - (2 * margem)) / colunas
    grade = Grade(0, 0, WIDTH, HEIGHT, colunas, linhas, margem, margem)
    for idx, slot in enumerate(grade):
        linha = idx // colunas
        coluna = idx % colunas
        coluna_interna = coluna % bloco
        linha_interna = linha % bloco
        forma = formas[1] if (linha_interna + coluna_interna) % 2 else formas[0]
        largura_interna = largura * FATOR_LARGURA_INTERNA
        x, y, largura_celula = slot.x, slot.y, largura
        if linha_interna == 1:
            # Linha do meio
            forma = formas[2]
            if coluna_interna == 1:
                largura_interna = largura
                forma = formas[3]
        celula = Celula(
            x,
            y,
            largura_celula,
            [forma],
            CORES,
            border=0,
        )
        celula.largura_interna = largura_interna
        celula.espelhada = coluna_interna == 2
        celula.espelhada_vertical = linha_interna == 2
        if linha_interna == coluna_interna == 1:
            celula.fill = True
            celula.largura_interna = largura

        slot.celulas.append(celula)
    with py5.push_matrix():
        py5.translate(WIDTH // 2, HEIGHT // 2)
        py5.rotate_x(py5.radians(60))
        py5.translate(-(WIDTH // 2), -(HEIGHT // 2))
        grade.desenha()
    write_legend([py5.color(0, 0, 0)], IMG_NAME)


def key_pressed():
    key = py5.key
    if key == " ":
        save_and_close()


def save_and_close():
    py5.no_loop()
    save_image(IMG_NAME, "png")
    py5.exit_sketch()


py5.run_sketch()