sketch-a-day/s075/s075.pyde

61 wiersze
1.7 KiB
Python

"""
sketch 75 180316 - 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, 10)
C = Slider(-2, 2, 0)
D = Slider(2, 15, 10)
def setup():
size(600, 600, P2D)
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(0)
stroke(255)
strokeWeight(2)
a = A.value() # Angle
b = B.value() # branch size randomization
c = C.value() # angle randomization
d = D.value() # recursion depth
randomSeed(1)
translate(width / 2, height / 2)
branch(d, a, width/30)
# uncomment next line to export GIF
#if not frameCount % 10: gif_export(GifMaker, frames=2000)
def branch(gen, theta, branch_size):
# All recursive functions must have an exit condition!!!!
if gen > 1 and branch_size > 1:
h = branch_size * (1 + random(b) / 4)
branch_size *= 1 - random(b) / 10
with pushMatrix():
rotate(theta + c * random(1)) # Rotate by theta
line(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!!
branch(gen - 1, theta, branch_size)
# Repeat the same thing, only branch off to the "left" this time!
with pushMatrix():
rotate(-theta + c * random(1))
line(0, 0, 0, -h)
translate(0, -h)
branch(gen - 1, theta, branch_size)