Concentricos 4

2023-07-24

"""2023-07-24"""
from helpers import HEIGHT
from helpers import save_image
from helpers import WIDTH
from helpers import write_legend
from pathlib import Path

import numpy as np
import py5


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


def calcula_circulo(diametro):
    pontos = []
    raio = diametro // 2
    n = 360
    for ponto in range(0, n + 1):
        x = np.cos(2 * py5.PI / n * ponto) * raio
        y = np.sin(2 * py5.PI / n * ponto) * raio
        pontos.append((int(x), int(y)))
    return pontos


def setup():
    py5.size(WIDTH, HEIGHT, py5.P3D)
    py5.color_mode(py5.HSB, 360, 100, 100)
    py5.background(py5.color(0, 0, 0))
    diametros = [d for d in range(50, 850, 50)]
    total_diametros = len(diametros)
    circulos = [(diametro, calcula_circulo(diametro)) for diametro in diametros]
    with py5.push_matrix():
        py5.translate(0, HEIGHT / 2)
        py5.ellipse_mode(py5.CENTER)
        py5.fill(py5.color(120, 40, 40))
        py5.circle(WIDTH / 2, 0, WIDTH)
        py5.fill(py5.color(0, 0, 0))
        py5.rect(0, 1, WIDTH, HEIGHT / 2)
        py5.shape_mode(py5.CORNERS)
        py5.stroke_weight(2)
        for idx in range(total_diametros):
            c_idx = total_diametros - idx - 2
            d_1, c_1 = circulos[idx]
            pontos_1 = sorted([(x, y) for x, y in c_1[180:]], reverse=True)
            if c_idx > -1:
                d_2, c_2 = circulos[c_idx]
                pontos_2 = sorted([(x, y) for x, y in c_2[:181]])
            else:
                pontos_2 = None
            h = 150
            s = 100 - idx * 4
            b = 40 + idx * 4
            c = py5.color(h, s, b)
            py5.stroke(c)
            s = py5.create_shape()
            s.set_fill(False)
            with s.begin_shape():
                for x, y in pontos_1:
                    s.vertex(x + d_1 / 2, y)
            py5.shape(s, 0, 0)
            if pontos_2:
                s = py5.create_shape()
                s.set_fill(c)
                with s.begin_shape():
                    for x, y in pontos_2:
                        s.vertex(x + d_2 / 2 + d_1, y)
            py5.shape(s, 0, 0)
    write_legend([py5.color(0, 0, 100)], img_name=IMG_NAME)


def key_pressed():
    key = py5.key
    if key == " ":
        save_image(IMG_NAME, "png")
        py5.exit_sketch()


py5.run_sketch()