sketch-a-day/2019/sketch_190601a/sketch_190601a.pyde

103 wiersze
2.9 KiB
Python

# Alexandre B A Villares - https://abav.lugaralgum.com/sketch-a-day
# More explorations of lines in grids
from random import shuffle
from itertools import product, combinations, permutations, combinations_with_replacement
from gif_exporter import gif_export
add_library('GifAnimation')
space, border = 20, 20
position = 0 # initial position
def setup():
global line_combos, W, H, position, num
size(800, 660)
frameRate(1)
rectMode(CENTER)
strokeWeight(1.5)
grid = product(range(-1, 2), repeat=2) # 2X2
# all line permutations on a grid
possible_lines = list(combinations(grid, 3))
# allow only some lines
# possible_lines = []
# for l in lines:
# (x0, y0), (x1, y1) = l[0], l[1]
# if dist(x0, y0, x1, y1) < 2: # rule defined here...
# possible_lines.append(l)
num_possible_lines = len(possible_lines)
println("Number of possible lines: {}".format(num_possible_lines))
# main stuff
line_combos = list(combinations(possible_lines, 2))
# shuffle(line_combos) # ucomment to shuffle!
num = len(line_combos)
println("Number of permutations: {}".format(num))
W = (width - border * 2) // space
H = (height - border * 2) // space
println("Cols: {} Rows: {} Visible grid: {}".format(W, H, W * H))
def draw():
global position
background(240)
i = position
for y in range(H):
for x in range(W):
if i < len(line_combos):
pushMatrix()
translate(border / 2 + space + space * x,
border / 2 + space + space * y)
# translate(border + space + space * x,
# border + space + space * y)
draw_combo(i)
popMatrix()
i += 1
if i < len(line_combos):
gif_export(GifMaker, SKETCH_NAME)
position += H * W
else:
gif_export(GifMaker, finish=True)
def draw_combo(n):
colorMode(RGB)
siz = space / 2
for i, sl in enumerate(line_combos[n]):
colorMode(HSB)
fill(i * 128, 128, 128, 100)
(x0, y0), (x1, y1), (x2, y2) = sl[0], sl[1], sl[2]
# noStroke()
poly(((x0 * siz, y0 * siz),
(x1 * siz, y1 * siz),
(x2 * siz, y2 * siz)))
def keyPressed():
global W, H
if key == "s":
saveFrame("####.png")
def poly(p_list, closed=True):
beginShape()
for p in p_list:
if len(p) == 2 or p[2] == 0:
vertex(p[0], p[1])
else:
vertex(*p)
if closed:
endShape(CLOSE)
else:
endShape()
def settings():
from os import path
global SKETCH_NAME
SKETCH_NAME = path.basename(sketchPath())
OUTPUT = ".png"
println(
"""
![{0}]({2}/{0}/{0}{1})
[{0}](https://github.com/villares/sketch-a-day/tree/master/{2}/{0}) [[Py.Processing](https://villares.github.io/como-instalar-o-processing-modo-python/index-EN)]
""".format(SKETCH_NAME, OUTPUT, year())
)