"""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()