Cobogó 4

2023-09-30

"""2023-09-30"""
from helpers import CelulaV3 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(0),
]


def forma_01(x, y, largura, largura_i):
    x1 = x + largura
    y1 = y + largura
    xh = x + largura / 2
    yh = y + largura / 2
    # Interno
    buffer_i = (largura - largura_i) / 2
    xi0 = x + buffer_i
    xi1 = xi0 + largura_i
    xih = (largura_i / 2) + xi0
    yi0 = y + buffer_i
    yi1 = yi0 + largura_i
    yih = (largura_i / 2) + yi0
    xbz1 = xi0 + ((largura_i / 2) * 0.45)
    xbz2 = xi1 - ((largura_i / 2) * 0.45)
    ybz1 = yi0 + ((largura_i / 2) * 0.45)
    ybz2 = yi1 - ((largura_i / 2) * 0.45)
    s = py5.create_shape()
    s.set_fill(False)
    s.set_stroke_weight(6)
    with s.begin_shape():
        s.vertex(x, y)

        s.vertex(xh, y)
        s.vertex(xih, yi0)
        s.vertex(xh, y)

        s.vertex(x1, y)

        s.vertex(x1, yh)
        s.vertex(xi1, yih)
        s.vertex(x1, yh)

        s.vertex(x1, y1)

        s.vertex(xh, y1)
        s.vertex(xih, yi1)
        s.vertex(xh, y1)

        s.vertex(x, y1)

        s.vertex(x, yh)
        s.vertex(xi0, yih)
        s.vertex(x, yh)

        s.vertex(x, y)
        with s.begin_contour():
            s.vertex(xi0, yih)
            s.bezier_vertex(xi0, ybz1, xbz1, yi0, xih, yi0)
            s.bezier_vertex(xbz2, yi0, xi1, ybz1, xi1, yih)
            s.bezier_vertex(xi1, ybz2, xbz2, yi1, xih, yi1)
            s.bezier_vertex(xbz1, yi1, xi0, ybz2, xi0, yih)

    return s


def forma_02(x, y, largura, largura_i):
    x1 = x + largura
    y1 = y + largura
    xh = x + largura / 2
    yh = y + largura / 2
    # Interno
    buffer_i = (largura - largura_i) / 2
    xi0 = x + buffer_i
    xi1 = xi0 + largura_i
    xih = (largura_i / 2) + xi0
    yi0 = y + buffer_i
    yi1 = yi0 + largura_i
    yih = (largura_i / 2) + yi0

    s = py5.create_shape()
    s.set_fill(False)
    s.set_stroke_weight(6)
    with s.begin_shape():
        s.vertex(x, y)

        s.vertex(xh, y)
        s.vertex(xih, yi0)
        s.vertex(xh, y)

        s.vertex(x1, y)

        s.vertex(x1, yh)
        s.vertex(xi1, yih)
        s.vertex(x1, yh)

        s.vertex(x1, y1)

        s.vertex(xh, y1)
        s.vertex(xih, yi1)
        s.vertex(xh, y1)

        s.vertex(x, y1)

        s.vertex(x, yh)
        s.vertex(xi0, yih)
        s.vertex(x, yh)

        s.vertex(x, y)
        with s.begin_contour():
            s.vertex(xih, yi0)
            s.vertex(xi1, yih)
            s.vertex(xih, yi1)
            s.vertex(xi0, yih)
            s.vertex(xih, yi0)

    return s


def forma_03(x, y, largura, largura_i):
    x1 = x + largura
    y1 = y + largura
    xh = x + largura / 2
    yh = y + largura / 2
    # Interno
    buffer_i = (largura - largura_i) / 2
    xi0 = x + buffer_i
    xi1 = xi0 + largura_i
    xih = (largura_i / 2) + xi0
    yi0 = y + buffer_i
    yi1 = yi0 + largura_i
    yih = (largura_i / 2) + yi0
    xbz1 = xi0 + ((largura_i / 2) * 0.45)
    xbz2 = xi1 - ((largura_i / 2) * 0.55)
    ybz1 = yi0 + ((largura_i / 2) * 0.45)
    ybz2 = yi1 - ((largura_i / 2) * 0.55)

    s = py5.create_shape()
    s.set_fill(False)
    s.set_stroke_weight(6)
    with s.begin_shape():
        s.vertex(x, y)
        s.vertex(xi0, yi0)
        s.vertex(x, y)
        s.vertex(x1, y)
        s.vertex(xi1, yi0)
        s.vertex(x1, y)
        s.vertex(x1, y1)
        s.vertex(xi1, yi1)
        s.vertex(x1, y1)
        s.vertex(x, y1)
        s.vertex(xi0, yi1)
        s.vertex(x, y1)
        s.vertex(x, y)
        with s.begin_contour():
            s.vertex(xi0, yi0)
            s.bezier_vertex(xi0, yi0, xbz2, ybz1, xi1, yi0)
            s.bezier_vertex(xi1, yi0, xbz2, yi1, xi1, yi1)
            s.bezier_vertex(xi1, yi1, xbz2, ybz2, xi0, yi1)
            s.bezier_vertex(xi0, yi1, xbz1, ybz2, xi0, yi0)

    return s


def setup():
    py5.size(WIDTH, HEIGHT, py5.P3D)
    py5.background(py5.color(255))
    linhas = 8
    colunas = 8
    margem = 40
    largura = (py5.width - (2 * margem)) / colunas
    grade = Grade(0, 0, WIDTH, HEIGHT, colunas, linhas, margem, margem)
    todas_formas = [
        forma_01(0, 0, largura, largura * 0.7),
        forma_02(0, 0, largura, largura * 0.7),
        forma_03(0, 0, largura, largura * 0.6),
    ]
    for idx, slot in enumerate(grade):
        x, y = slot.x, slot.y
        forma = idx % 3
        formas = [
            todas_formas[forma],
        ]
        slot.celulas.append(Celula(x, y, largura, formas, CORES))
    for distance in range(0, 20, 2):
        with py5.push_matrix():
            py5.translate(0, 0, distance)
            py5.rotate_x(py5.radians(1))
            grade.desenha()
    write_legend([py5.color(255)], 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()