import rhinoscriptsyntax as rs #delete everything and start from scratch allobjs = rs.AllObjects() rs.DeleteObjects(allobjs) #domino variables A = 5 B = A/3 thick = 0.2 hgt = 4 xcol = 2 ycol = 3 levels = 3 f_height = 0.5 f_size = 0.8 #derived values center_pt = [A*(xcol-1)/2, A*(ycol-1)/2,f_height] p_width = A/(xcol-1)+2*B p_length = A*(ycol-1)+f_size """ #set variables/parameters xsize = 10 #xside lenght of box ysize = 10 #yside lenght of box zsize = 10 #zside lenght of box #create a box corners = [[0,0,0], [xsize,0,0], [xsize,ysize,0], [0, ysize,0], [0,0,zsize], [xsize, 0, zsize], [xsize, ysize, zsize], [0,ysize,zsize]] rs.AddBox(corners) """ rs.EnableRedraw(False) def make_box(insertion=[0,0,0], xsize=10,ysize=10,zsize=10): #create a box corners = [[0,0,0], [xsize,0,0], [xsize,ysize,0], [0, ysize,0], [0,0,zsize], [xsize, 0, zsize], [xsize, ysize, zsize], [0,ysize,zsize]] box=rs.AddBox(corners) rs.MoveObject(box, (-xsize/2, -ysize/2, 0)) rs.MoveObject(box, insertion) return(box) def make_podest(insertion=[0,0,0], xsize=10,ysize=10,zsize=10): #create a box corners = [[0,0,0], [xsize,0,0], [xsize,ysize,0], [0, ysize,0], [0,0,zsize], [xsize, 0, zsize], [xsize, ysize, zsize], [0,ysize,zsize]] box=rs.AddBox(corners) rs.MoveObject(box, insertion) return(box) #make_box([10,3,4], zsize=2) #function to create a field of foundations def make_foundations(A=5.0, f_size=0.8, f_height=0.5, xcol=2, ycol=3): fns = [] for i in range (xcol): for j in range (ycol): fns.append(make_box([i*A,j*A,0], f_size, f_size, f_height)) return(fns) #function to create a field of columns def make_columns(A=5.0, level=0.7, thick=0.2, hgt=3.0, xcol=2, ycol=3): cls = [] for i in range (xcol): for j in range (ycol): cls.append(make_box([i*A,j*A,level], thick, thick, hgt)) return(cls) """ def make_arc(insertion, rad, thick, hgt, orientation): segs=[] segs.append(rs.AddArc([0,0,0], rad, 180)) segs.append(rs.AddArc([0,0,0], rad-thick, 180)) segs.append(rs.AddLine([rad,0,0], [rad-thick,0,0])) segs.append(rs.AddLine([-(rad-thick),0,0], [-rad,0,0])) crv=rs.JoinCurves(segs,delete_input=True) path=rs.AddLine([0,0,0],[0,0,3.0]) arc=rs.ExtrudeCurve(crv, path) rs.CapPlanarHoles(arc) rs.DeleteObject(crv) rs.DeleteObject(path) rs.RotateObject(arc, [0,0,0], orientation) rs.MoveObject(arc,insertion) return(arc) def make_terrace(A=5.0, level=0.7, thick=0.2, hgt=3.0, xcol=2, ycol=3): cls = [] for i in range (xcol-1): for j in range (ycol-1): # ori = ran.randint(0,3) # orientation=ori*90 cls.append(make_arc([i*A+A/2,j*A+A/2,level], A/2, thick, hgt, 90)) return(cls) """ #function to create stair def make_stair (start,th, tt,steps, thick, s_width): pointlist =[start] for i in range (steps): pointlist.append([pointlist[-1][0],pointlist[-1][1],pointlist[-1][2]+th]) pointlist.append([pointlist[-1][0]+tt,pointlist[-1][1],pointlist[-1][2]]) pointlist.append([pointlist[-1][0],pointlist[-1][1],pointlist[-1][2]-thick]) pointlist.append([pointlist[0][0],pointlist[0][1],pointlist[0][2]-0.2]) pointlist.append([pointlist[0][0],pointlist[0][1],pointlist[0][2]]) s_outline=rs.AddPolyline(pointlist) path = rs.AddLine(start, [start[0],start[1]+s_width,start[2]]) hull = rs.ExtrudeCurve(s_outline, path) rs.CapPlanarHoles(hull) return(hull) #steps=26 #th=0.18 #tt=0.3 #thick=0.2 #s_width=1.5 # #make_stair([0,0,0], th, tt , steps, thick, 1.5) #make_stair([steps*tt, s_width, steps*th], th, -tt , steps, thick, s_width) #building dom-ino def make_domino (A=A, B=B, thick=thick, hgt=hgt, levels=levels, xcol=xcol, ycol=ycol, f_height=f_height, f_size=f_size): f_list = [] #list of foundations c_list = [] #list of columns p_list = [] #list of plates for i in range (levels): center_pt[2] = f_height + i*(thick+hgt) level = f_height + thick + (i-1)*(hgt+thick) if i==0: f_list = make_foundations(A, f_size, f_height, xcol, ycol) else: c_list.extend(make_columns(A, level, thick, hgt, xcol,ycol)) p_list.append(make_box(center_pt, p_width, p_length, thick)) # level=f_height + thick + (levels-1)*(hgt+thick) # make_terrace(A,level, thick,hgt, xcol, ycol) steps = int( (hgt+thick)/0.17) if steps%2: steps= steps-1 th= (hgt+thick)/steps if(th>0.19): steps=steps+2 th= (hgt+thick)/steps if (th>0.19): steps=steps+2 th= (hgt+thick)/steps tt=0.3 s_width=1.2 pod_w=B start = [pod_w,-(s_width*2+f_size/2), f_height+thick] stair_l =[] for i in range (levels): start[2]=f_height+thick+i*(thick+hgt) if i==levels-1: stair_l.append(make_podest([start[0]-pod_w,start[1]+s_width,start[2]-thick], pod_w, s_width, thick)) else: stair_l.append(make_podest ([start[0]-pod_w,start[1],start[2]-thick], pod_w, s_width*2, thick)) stair_l.append(make_stair(start,th, tt,int(steps/2), thick, s_width)) stair_l.append(make_podest ([start[0]+(steps/2)*tt,start[1],start[2]+(steps/2)*th-thick], pod_w, s_width*2, thick)) stair_l.append(make_stair([start[0]+(steps/2)*tt, start[1]+s_width, start [2]+(steps/2)*th],th, -tt,int(steps/2), thick, s_width)) return(f_list, c_list, p_list, stair_l) (f_list, c_list, p_list, stair_l) = make_domino() rs.AddLayer("foundation") rs.LayerColor("foundation", (220,60,60)) rs.ObjectLayer(f_list, "foundation") rs.AddLayer("columns") rs.LayerColor("columns", (60,220,60)) rs.ObjectLayer(c_list, "columns") rs.AddLayer("plates") rs.LayerColor("plates", (60,60,220)) rs.ObjectLayer(p_list, "plates") #create fassade #set variables/parameters asize = A+2*B #xside lenght of box bsize = 0.2 #yside lenght of box csize = 0.2 #zside lenght of box hsize = (csize+csize) count = (int(hgt/hsize)) #create a box crns = [[0,0,0], [asize,0,0], [asize,bsize,0], [0, bsize,0], [0,0,csize], [asize, 0, csize], [asize, bsize, csize], [0,bsize,csize]] #fsd = rs.AddBox(crns) #rs.MoveObject (fsd, (-B, (-bsize-(thick/2)), (f_height+thick))) # # #for j in range (levels-1): # for i in range (count): # rs.CopyObject(fsd, (0,0, (0.4*i)+(j*(hgt+thick)))) fsd = rs.AddBox(crns) rs.MoveObject (fsd, (-B, ((2*A+thick+bsize)-bsize-(thick/2)), (f_height+thick))) for j in range (levels-1): for i in range (count): rs.CopyObject(fsd, (0,0, (0.4*i)+(j*(hgt+thick)))) crns = [[0,0,0], [0,2*A,0], [bsize,2*A,0], [bsize, 0,0], [0,0,csize], [0, 2*A, csize], [bsize, 2*A, csize], [bsize,0,csize]] fsd = rs.AddBox(crns) rs.MoveObject (fsd, (-B, 0, (f_height+thick))) for j in range (levels-1): for i in range (count): rs.CopyObject(fsd, (0,0, (0.4*i)+(j*(hgt+thick)))) fsd = rs.AddBox(crns) rs.MoveObject (fsd, (A+B-bsize, 0, (f_height+thick))) for j in range (levels-1): for i in range (count): rs.CopyObject(fsd, (0,0, (0.4*i)+(j*(hgt+thick)))) allobjs = rs.AllObjects() rs.RotateObjects(allobjs, (0,0,0), 45) rs.MoveObject(allobjs, (25,0,0)) ################################## #2nd house ################################## #domino variables A = 8 B = A/3 thick = 0.2 hgt = 8 xcol = 2 ycol = 3 levels = 8 f_height = 0.5 f_size = 0.8 #derived values center_pt = [A*(xcol-1)/2, A*(ycol-1)/2,f_height] p_width = A/(xcol-1)+2*B p_length = A*(ycol-1)+f_size rs.EnableRedraw(False) def make_box(insertion=[0,0,0], xsize=10,ysize=10,zsize=10): #create a box corners = [[0,0,0], [xsize,0,0], [xsize,ysize,0], [0, ysize,0], [0,0,zsize], [xsize, 0, zsize], [xsize, ysize, zsize], [0,ysize,zsize]] box=rs.AddBox(corners) rs.MoveObject(box, (-xsize/2, -ysize/2, 0)) rs.MoveObject(box, insertion) return(box) def make_podest(insertion=[0,0,0], xsize=10,ysize=10,zsize=10): #create a box corners = [[0,0,0], [xsize,0,0], [xsize,ysize,0], [0, ysize,0], [0,0,zsize], [xsize, 0, zsize], [xsize, ysize, zsize], [0,ysize,zsize]] box=rs.AddBox(corners) rs.MoveObject(box, insertion) return(box) #function to create a field of foundations def make_foundations(A=5.0, f_size=0.8, f_height=0.5, xcol=2, ycol=3): fns = [] for i in range (xcol): for j in range (ycol): fns.append(make_box([i*A,j*A,0], f_size, f_size, f_height)) return(fns) #function to create a field of columns def make_columns(A=5.0, level=0.7, thick=0.2, hgt=3.0, xcol=2, ycol=3): cls = [] for i in range (xcol): for j in range (ycol): cls.append(make_box([i*A,j*A,level], thick, thick, hgt)) return(cls) #function to create stair def make_stair (start,th, tt,steps, thick, s_width): pointlist =[start] for i in range (steps): pointlist.append([pointlist[-1][0],pointlist[-1][1],pointlist[-1][2]+th]) pointlist.append([pointlist[-1][0]+tt,pointlist[-1][1],pointlist[-1][2]]) pointlist.append([pointlist[-1][0],pointlist[-1][1],pointlist[-1][2]-thick]) pointlist.append([pointlist[0][0],pointlist[0][1],pointlist[0][2]-0.2]) pointlist.append([pointlist[0][0],pointlist[0][1],pointlist[0][2]]) s_outline=rs.AddPolyline(pointlist) path = rs.AddLine(start, [start[0],start[1]+s_width,start[2]]) hull = rs.ExtrudeCurve(s_outline, path) rs.CapPlanarHoles(hull) return(hull) #building dom-ino def make_domino (A=A, B=B, thick=thick, hgt=hgt, levels=levels, xcol=xcol, ycol=ycol, f_height=f_height, f_size=f_size): f_list = [] #list of foundations c_list = [] #list of columns p_list = [] #list of plates for i in range (levels): center_pt[2] = f_height + i*(thick+hgt) level = f_height + thick + (i-1)*(hgt+thick) if i==0: f_list = make_foundations(A, f_size, f_height, xcol, ycol) else: c_list.extend(make_columns(A, level, thick, hgt, xcol,ycol)) p_list.append(make_box(center_pt, p_width, p_length, thick)) # level=f_height + thick + (levels-1)*(hgt+thick) # make_terrace(A,level, thick,hgt, xcol, ycol) steps = int( (hgt+thick)/0.17) if steps%2: steps= steps-1 th= (hgt+thick)/steps if(th>0.19): steps=steps+2 th= (hgt+thick)/steps if (th>0.19): steps=steps+2 th= (hgt+thick)/steps tt=0.3 s_width=1.2 pod_w=B start = [pod_w,-(s_width*2+f_size/2), f_height+thick] stair_l =[] for i in range (levels): start[2]=f_height+thick+i*(thick+hgt) if i==levels-1: stair_l.append(make_podest([start[0]-pod_w,start[1]+s_width,start[2]-thick], pod_w, s_width, thick)) else: stair_l.append(make_podest ([start[0]-pod_w,start[1],start[2]-thick], pod_w, s_width*2, thick)) stair_l.append(make_stair(start,th, tt,int(steps/2), thick, s_width)) stair_l.append(make_podest ([start[0]+(steps/2)*tt,start[1],start[2]+(steps/2)*th-thick], pod_w, s_width*2, thick)) stair_l.append(make_stair([start[0]+(steps/2)*tt, start[1]+s_width, start [2]+(steps/2)*th],th, -tt,int(steps/2), thick, s_width)) return(f_list, c_list, p_list, stair_l) (f_list, c_list, p_list, stair_l) = make_domino() rs.AddLayer("foundation") rs.LayerColor("foundation", (220,60,60)) rs.ObjectLayer(f_list, "foundation") rs.AddLayer("columns") rs.LayerColor("columns", (60,220,60)) rs.ObjectLayer(c_list, "columns") rs.AddLayer("plates") rs.LayerColor("plates", (60,60,220)) rs.ObjectLayer(p_list, "plates") #create fassade #set variables/parameters asize = A+2*B #xside lenght of box bsize = 0.2 #yside lenght of box csize = 0.2 #zside lenght of box hsize = (csize+csize) count = (int(hgt/hsize)) #create a box crns = [[0,0,0], [asize,0,0], [asize,bsize,0], [0, bsize,0], [0,0,csize], [asize, 0, csize], [asize, bsize, csize], [0,bsize,csize]] fsd = rs.AddBox(crns) rs.MoveObject (fsd, (-B, ((2*A+thick+bsize)-bsize-(thick/2)), (f_height+thick))) for j in range (levels-1): for i in range (count): rs.CopyObject(fsd, (0,0, (0.4*i)+(j*(hgt+thick)))) crns = [[0,0,0], [0,2*A,0], [bsize,2*A,0], [bsize, 0,0], [0,0,csize], [0, 2*A, csize], [bsize, 2*A, csize], [bsize,0,csize]] fsd = rs.AddBox(crns) rs.MoveObject (fsd, (-B, 0, (f_height+thick))) for j in range (levels-1): for i in range (count): rs.CopyObject(fsd, (0,0, (0.4*i)+(j*(hgt+thick)))) fsd = rs.AddBox(crns) rs.MoveObject (fsd, (A+B-bsize, 0, (f_height+thick))) for j in range (levels-1): for i in range (count): rs.CopyObject(fsd, (0,0, (0.4*i)+(j*(hgt+thick)))) allobjs = rs.AllObjects() rs.RotateObjects(allobjs, (0,0,0), 60) rs.MoveObject(allobjs, (0,20,0)) ################################## #3rd house ################################## #domino variables A = 5 B = A/3 thick = 0.8 hgt = 6 xcol = 2 ycol = 3 levels = 6 f_height = 0.5 f_size = 0.8 #derived values center_pt = [A*(xcol-1)/2, A*(ycol-1)/2,f_height] p_width = A/(xcol-1)+2*B p_length = A*(ycol-1)+f_size rs.EnableRedraw(False) def make_box(insertion=[0,0,0], xsize=10,ysize=10,zsize=10): #create a box corners = [[0,0,0], [xsize,0,0], [xsize,ysize,0], [0, ysize,0], [0,0,zsize], [xsize, 0, zsize], [xsize, ysize, zsize], [0,ysize,zsize]] box=rs.AddBox(corners) rs.MoveObject(box, (-xsize/2, -ysize/2, 0)) rs.MoveObject(box, insertion) return(box) def make_podest(insertion=[0,0,0], xsize=10,ysize=10,zsize=10): #create a box corners = [[0,0,0], [xsize,0,0], [xsize,ysize,0], [0, ysize,0], [0,0,zsize], [xsize, 0, zsize], [xsize, ysize, zsize], [0,ysize,zsize]] box=rs.AddBox(corners) rs.MoveObject(box, insertion) return(box) #function to create a field of foundations def make_foundations(A=5.0, f_size=0.8, f_height=0.5, xcol=2, ycol=3): fns = [] for i in range (xcol): for j in range (ycol): fns.append(make_box([i*A,j*A,0], f_size, f_size, f_height)) return(fns) #function to create a field of columns def make_columns(A=5.0, level=0.7, thick=0.2, hgt=3.0, xcol=2, ycol=3): cls = [] for i in range (xcol): for j in range (ycol): cls.append(make_box([i*A,j*A,level], thick, thick, hgt)) return(cls) #function to create stair def make_stair (start,th, tt,steps, thick, s_width): pointlist =[start] for i in range (steps): pointlist.append([pointlist[-1][0],pointlist[-1][1],pointlist[-1][2]+th]) pointlist.append([pointlist[-1][0]+tt,pointlist[-1][1],pointlist[-1][2]]) pointlist.append([pointlist[-1][0],pointlist[-1][1],pointlist[-1][2]-thick]) pointlist.append([pointlist[0][0],pointlist[0][1],pointlist[0][2]-0.2]) pointlist.append([pointlist[0][0],pointlist[0][1],pointlist[0][2]]) s_outline=rs.AddPolyline(pointlist) path = rs.AddLine(start, [start[0],start[1]+s_width,start[2]]) hull = rs.ExtrudeCurve(s_outline, path) rs.CapPlanarHoles(hull) return(hull) #building dom-ino def make_domino (A=A, B=B, thick=thick, hgt=hgt, levels=levels, xcol=xcol, ycol=ycol, f_height=f_height, f_size=f_size): f_list = [] #list of foundations c_list = [] #list of columns p_list = [] #list of plates for i in range (levels): center_pt[2] = f_height + i*(thick+hgt) level = f_height + thick + (i-1)*(hgt+thick) if i==0: f_list = make_foundations(A, f_size, f_height, xcol, ycol) else: c_list.extend(make_columns(A, level, thick, hgt, xcol,ycol)) p_list.append(make_box(center_pt, p_width, p_length, thick)) # level=f_height + thick + (levels-1)*(hgt+thick) # make_terrace(A,level, thick,hgt, xcol, ycol) steps = int( (hgt+thick)/0.17) if steps%2: steps= steps-1 th= (hgt+thick)/steps if(th>0.19): steps=steps+2 th= (hgt+thick)/steps if (th>0.19): steps=steps+2 th= (hgt+thick)/steps tt=0.3 s_width=1.2 pod_w=B start = [pod_w,-(s_width*2+f_size/2), f_height+thick] stair_l =[] for i in range (levels): start[2]=f_height+thick+i*(thick+hgt) if i==levels-1: stair_l.append(make_podest([start[0]-pod_w,start[1]+s_width,start[2]-thick], pod_w, s_width, thick)) else: stair_l.append(make_podest ([start[0]-pod_w,start[1],start[2]-thick], pod_w, s_width*2, thick)) stair_l.append(make_stair(start,th, tt,int(steps/2), thick, s_width)) stair_l.append(make_podest ([start[0]+(steps/2)*tt,start[1],start[2]+(steps/2)*th-thick], pod_w, s_width*2, thick)) stair_l.append(make_stair([start[0]+(steps/2)*tt, start[1]+s_width, start [2]+(steps/2)*th],th, -tt,int(steps/2), thick, s_width)) return(f_list, c_list, p_list, stair_l) (f_list, c_list, p_list, stair_l) = make_domino() rs.AddLayer("foundation") rs.LayerColor("foundation", (220,60,60)) rs.ObjectLayer(f_list, "foundation") rs.AddLayer("columns") rs.LayerColor("columns", (60,220,60)) rs.ObjectLayer(c_list, "columns") rs.AddLayer("plates") rs.LayerColor("plates", (60,60,220)) rs.ObjectLayer(p_list, "plates") #create fassade #set variables/parameters asize = A+2*B #xside lenght of box bsize = 0.2 #yside lenght of box csize = 0.2 #zside lenght of box hsize = (csize+csize) count = (int(hgt/hsize)) #create a box crns = [[0,0,0], [asize,0,0], [asize,bsize,0], [0, bsize,0], [0,0,csize], [asize, 0, csize], [asize, bsize, csize], [0,bsize,csize]] fsd = rs.AddBox(crns) rs.MoveObject (fsd, (-B, ((2*A+thick+bsize)-bsize-(thick/2)), (f_height+thick))) for j in range (levels-1): for i in range (count): rs.CopyObject(fsd, (0,0, (0.4*i)+(j*(hgt+thick)))) crns = [[0,0,0], [0,2*A,0], [bsize,2*A,0], [bsize, 0,0], [0,0,csize], [0, 2*A, csize], [bsize, 2*A, csize], [bsize,0,csize]] fsd = rs.AddBox(crns) rs.MoveObject (fsd, (-B, 0, (f_height+thick))) for j in range (levels-1): for i in range (count): rs.CopyObject(fsd, (0,0, (0.4*i)+(j*(hgt+thick)))) fsd = rs.AddBox(crns) rs.MoveObject (fsd, (A+B-bsize, 0, (f_height+thick))) for j in range (levels-1): for i in range (count): rs.CopyObject(fsd, (0,0, (0.4*i)+(j*(hgt+thick)))) rs.EnableRedraw(True)