sketch-a-day/s079/s079.pyde

94 wiersze
2.7 KiB
Python

"""
sketch 79 180320 - Alexandre B A Villares
https://abav.lugaralgum.com/sketch-a-day
Based on Recursive Tree by Daniel Shiffman.
"""
add_library('gifAnimation')
from gif_exporter import gif_export
from slider import Slider
A = Slider(0, HALF_PI, QUARTER_PI)
B = Slider(0, 10, 0)
C = Slider(-2, 2, 0)
D = Slider(2, 10, 10)
def setup():
size(600, 600, P2D)
colorMode(HSB)
frameRate(30)
A.position(20, height - 60)
B.position(20, height - 30)
C.position(width - 180, height - 60)
D.position(width - 180, height - 30)
def draw():
global b, c, d
background(200)
a = A.value() # Angle
b = B.value() # branch size randomization
c = C.value() # angle randomization
d = D.value() # recursion depth
randomSeed(int(d*10))
translate(width / 2, height / 2)
branch(d, a, width/25 + (width/75)*b)
# #uncomment next lines to export GIF
if not frameCount % 10: gif_export(GifMaker,
frames=2000,
filename="s079")
def branch(gen, theta, branch_size):
strokeWeight(2)
# All recursive functions must have an exit condition!!!!
if gen > 1:# and branch_size > 1:
with pushMatrix():
stroke(0)
h = branch_size * (1 - random(b/3,b) / 15)
rotate(theta + c * random(1)) # Rotate by theta
arrow(0, 0, 0, -h) # Draw the branch
translate(0, -h) # Move to the end of the branch
# Ok, now call myself to draw two branches!!
with pushStyle():
branch(gen - 1, theta, h)
with pushMatrix():
stroke(255)
h = branch_size * (1 - random(b/3, b) / 15)
rotate(-theta + c * random(1))
arrow(0, 0, 0, -h)
translate(0, -h)
with pushStyle():
branch(gen - 1, theta, h)
def arrow(x1, y1, x2, y2, shorter=0, head=None,
tail_func=None, tail_size=None):
"""
O código para fazer as setas, dois pares (x, y),
um parâmetro de encurtamento: shorter
e para o tamanho da cabeça da seta: head
"""
rectMode(CENTER)
L = dist(x1, y1, x2, y2)
if not head:
head = max(L / 10, 10)
with pushMatrix():
translate(x1, y1)
angle = atan2(x1 - x2, y2 - y1)
rotate(angle)
offset = shorter / 2
strokeCap(ROUND)
line(0, L - offset, -head / 3, L - offset - head)
line(0, L - offset, head / 3, L - offset - head)
strokeCap(SQUARE)
line(0, offset, 0, L - offset)
if tail_func:
if not tail_size:
tail_size = head
tail_func(0, 0, tail_size, tail_size)