-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathget_layers.py
101 lines (77 loc) · 2.85 KB
/
get_layers.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
import rhinoscriptsyntax as rs
import os
import shutil
import sys
file_path = 'C:\\Users\\Rebecca Napolitano\\Documents\\GitHub\\generate3DModels\\'
sys.path.append(file_path)
import find_small_rigid_blocks as zeroVol
directory = 'G:\\My Drive\\Documents\\Research\\mikehess\\palazzo vecchio\\2017_9_7_ElementiModels\\FoundationModels\\ExistingGeometry\\2017_10_30\\'
fileName = 'this_is_a_test'
filetype = '.wrl'
meshValue = '10 '
mesh = ['1']
angle = ' _angle=0'
aspectratio =' _aspectratio=0'
distance = ' _distance=0'
grid = ' _grid=0'
maxedgelength = ' _maxedgelength=' + meshValue
maxedgelengthstr= maxedgelength
minedgelength = ' _minedgelength=' + meshValue
minedgelengthstr = minedgelength
advOptions = angle + aspectratio + distance + grid + maxedgelengthstr + minedgelengthstr
#gsurfcommands
mode = '_mode=tri'
minedgelength = '_minedgelength=' + meshValue
maxedgelength = '_maxedgelength=' + meshValue
ridgeangle = '_ridgeangle=20'
maxgradation = '_maxgradation=1'
deleteinput = '_deleteinput=Yes'
gsurfOptions = mode + minedgelength + maxedgelength + ridgeangle + maxgradation + deleteinput
#gvol options
gvol_mode = '_mode=tet '
outputformat = '_outputformat=3DEC '
gvolOptions = gvol_mode + outputformat
#find zero volume blocks
zeroVol.zero_vol_rigid_blocks()
#get layers
layers = rs.LayerNames()
os.chdir(directory)
for layer in layers:
rs.Command("Show")
rs.Command("-_SelNone ")
if layer in mesh:
#run mesh, gsurf, gvol
rs.Command("-_SelLayer " + layer)
rs.Command("Invert ")
rs.Command("Hide Enter ")
rs.Command("-_SelLayer " + layer)
rs.Command("-_Mesh _DetailedOptions _AdvancedOptions " + advOptions + '_Enter _Enter')
rs.Command("-_SelNone ")
rs.Command("-_SelMesh ")
rs.Command("-_Gsurf " + gsurfOptions + '_Enter _Enter')
rs.Command("-_SelMesh")
rs.Command("-_Gvol " + gvolOptions + '_Enter _Enter')
#rename gvol
saveName = fileName + "_" + layer + ".3ddat"
shutil.move('GVol.3ddat', saveName)
else:
#grab only that layer
rs.Command("-_SelLayer " + layer)
#simple planes
rs.Command("-_Mesh DetailedOptions SimplePlane=Yes Enter")
#make cmdstr for export
path = "\"" + directory + fileName + "_" + layer + filetype + "\""
cmdstr = "-_Export " + path
if filetype == '.wrl':
cmdstr += " Enter Enter"
#selmesh and export
rs.Command("-_SelNone ")
rs.Command("-_SelLayer " + layer)
rs.Command("-_Invert ")
rs.Command("Hide Enter")
rs.Command("-_SelMesh ")
cmd = rs.Command(cmdstr)
if not (cmd):
success = False
rs.Command("-_SelNone")
rs.Command("Show ")