kopia lustrzana https://github.com/villares/sketch-a-day
182 wiersze
5.0 KiB
Python
182 wiersze
5.0 KiB
Python
add_library('OBJExport')
|
|
# Alexandre B A Villares - https://abav.lugaralgum.com/sketch-a-day
|
|
# s231 20180817
|
|
|
|
# made my own randint so no need of this: # from random import randint
|
|
from gif_export_wrapper import gif_export
|
|
from my_box import my_box
|
|
add_library('gifAnimation')
|
|
add_library('peasycam')
|
|
add_library('dxf')
|
|
|
|
|
|
GRID_SIZE = 32
|
|
SKETCH_NAME = "s231"
|
|
OUTPUT = ".gif"
|
|
# Cutting-plane position (press + & - to change)
|
|
cut_plane = GRID_SIZE
|
|
export = False
|
|
|
|
def setup():
|
|
print_text_for_readme(SKETCH_NAME, OUTPUT)
|
|
size(700, 700, P3D)
|
|
#colorMode(HSB)
|
|
# optional PeasyCam setup to allow orbiting with a mouse drag
|
|
cam = PeasyCam(this, 100)
|
|
cam.setMinimumDistance(1000)
|
|
cam.setMaximumDistance(1000)
|
|
# sets border and grid spacing
|
|
Node.border = 50
|
|
Node.spacing = (width - Node.border * 2) / GRID_SIZE
|
|
# Node.nodes is a list of nodes in a 3D grid
|
|
for x in range(GRID_SIZE):
|
|
for y in range(GRID_SIZE):
|
|
for z in range(GRID_SIZE):
|
|
new_node = Node(x, y, z)
|
|
Node.nodes.append(new_node)
|
|
Node.grid[x, y, z] = new_node
|
|
# crear objects
|
|
create_boxes()
|
|
|
|
def draw():
|
|
#lights()
|
|
background(000)
|
|
if export:
|
|
beginRaw("nervoussystem.obj.OBJExport", "filename.obj")
|
|
|
|
for node in Node.nodes:
|
|
if node.iz < cut_plane:
|
|
node.plot()
|
|
|
|
if export:
|
|
endRaw()
|
|
global export
|
|
export = False
|
|
|
|
def create_boxes():
|
|
# sets the objects, list of tuples -> hollowed boxes
|
|
seed = int(random(1000)) # seed = 205
|
|
println("seed: {}".format(seed))
|
|
randomSeed(seed)
|
|
m = GRID_SIZE - 1
|
|
box_list = []
|
|
num_boxes = 10
|
|
border = 1
|
|
for i in range(num_boxes):
|
|
# random size in range 3 to GRID_SIZE - borders
|
|
w = randint(3, m - border * 2)
|
|
h = randint(3, m - border * 2)
|
|
d = randint(3, m - border * 2)
|
|
# random position
|
|
x = randint(border, m - w - border)
|
|
y = randint(border, m - h - border)
|
|
z = randint(border, m - d - border)
|
|
box_tuple = (x, y, z, w, h, d)
|
|
# print(box_tuple)
|
|
box_list.append(box_tuple)
|
|
# solid boxes
|
|
for i in range(num_boxes):
|
|
x, y, z, w, h, d = box_list[i]
|
|
big_box(x, y, z, w, h, d,
|
|
color(64 + (i % 3) * 32, 200, 200, 255))
|
|
# erase inside boxes
|
|
for i in range(num_boxes):
|
|
x, y, z, w, h, d = box_list[i]
|
|
big_box(x + 1, y + 1, z + 1, w - 2, h - 2, d - 2,
|
|
# use color(0) below, instead of None to debug
|
|
# color(0))
|
|
None)
|
|
# side = (i % 3) + 1
|
|
# if side == 1:
|
|
# h -= 2
|
|
# w -= 2
|
|
# z -= 1
|
|
# elif side == 2:
|
|
# d -= 2
|
|
# h -= 2
|
|
# x -= 1
|
|
# else:
|
|
# w -= 2
|
|
# d -= 2
|
|
# y -= 1
|
|
|
|
def keyPressed():
|
|
""" press P to save an image """
|
|
if key in ['p', 'P']:
|
|
saveFrame("####" + SKETCH_NAME + OUTPUT)
|
|
if key == " ":
|
|
for node in Node.nodes:
|
|
node.cor = None
|
|
create_boxes()
|
|
if key == "g":
|
|
gif_export(GifMaker, delay=1000, filename=SKETCH_NAME)
|
|
if key == "f":
|
|
gif_export(GifMaker, finish=True)
|
|
# cut plane adjust
|
|
global cut_plane, export
|
|
if key == "-":
|
|
cut_plane -= 1
|
|
print(cut_plane)
|
|
if key in ['+', '=']:
|
|
cut_plane += 1
|
|
print(cut_plane)
|
|
if key == 'e':
|
|
export = True
|
|
|
|
|
|
def big_box(px, py, pz, w, h=None, d=None, c=255):
|
|
h = h if h else w
|
|
d = d if d else w
|
|
for z in range(pz, pz + d):
|
|
for y in range(py, py + h):
|
|
for x in range(px, px + w):
|
|
if (0 <= x < GRID_SIZE and
|
|
0 <= y < GRID_SIZE and
|
|
0 <= z < GRID_SIZE):
|
|
Node.grid[(x, y, z)].cor = c
|
|
|
|
|
|
class Node():
|
|
nodes = []
|
|
grid = dict()
|
|
|
|
def __init__(self, x, y, z):
|
|
self.ix = x
|
|
self.iy = y
|
|
self.iz = z
|
|
self.x = Node.border + Node.spacing / 2 + x * Node.spacing - width / 2
|
|
self.y = Node.border + Node.spacing / 2 + y * Node.spacing - width / 2
|
|
self.z = Node.border + Node.spacing / 2 + z * Node.spacing - width / 2
|
|
self.size_ = 1
|
|
self.cor = None
|
|
|
|
def plot(self):
|
|
""" draws box """
|
|
if self.cor:
|
|
#stroke(0, 200)
|
|
noStroke() # stroke(0)
|
|
if self.cor == color(0):
|
|
noFill()
|
|
else:
|
|
fill(self.cor)
|
|
with pushMatrix():
|
|
translate(self.x, self.y, self.z)
|
|
my_box(Node.spacing * self.size_)
|
|
|
|
def randint(a, b=None):
|
|
if not b:
|
|
b = a
|
|
a = 0
|
|
return int(random(a, b + 1))
|
|
|
|
|
|
def print_text_for_readme(name, output):
|
|
""" prints text in the console to add to project README.md """
|
|
println("""
|
|

|
|
|
|
{1}: [code](https://github.com/villares/sketch-a-day/tree/master/{0}) [[Py.Processing](https://villares.github.io/como-instalar-o-processing-modo-python/index-EN)]
|
|
|
|
""".format(name, name[1:], output)
|
|
)
|