-
Notifications
You must be signed in to change notification settings - Fork 335
/
Copy pathConvertBlockToGroup.rvb
74 lines (64 loc) · 2.19 KB
/
ConvertBlockToGroup.rvb
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
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' ConvertBlockToGroup.rvb -- March 2010
' If this code works, it was written by Dale Fugier.
' If not, I don't know who wrote it.
' Works with Rhino 4.0.
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Option Explicit
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' Main procedure for script
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Sub ConvertBlockToGroup()
' Local variables
Dim arrBlocks, strBlock, arrObjects(), nBound
' Get blocks to explode
arrBlocks = Rhino.GetObjects("Select blocks to convert", 4096, True, True)
If IsNull(arrBlocks) Then Exit Sub
' Explode the blocks
For Each strBlock In arrBlocks
' Reset our array of objects
ReDim arrObjects(-1)
' Explode the block
Call BlockExplode(strBlock, arrObjects)
' See if any objects were added to our array
On Error Resume Next
nBound = UBound(arrObjects)
If (Err.Number = 0) Then
' Group the objects
Call Rhino.AddObjectsToGroup(arrObjects, Rhino.AddGroup())
End If
Next
End Sub
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' Explodes a block and all of its nested blocks
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Sub BlockExplode(ByVal strBlock, ByRef arrObjects)
' Local variables
Dim arrExplodes, strExplode
' Explode the block
If Rhino.IsBlockInstance(strBlock) Then
arrExplodes = Rhino.ExplodeBlockInstance(strBlock)
If IsArray(arrExplodes) Then
For Each strExplode In arrExplodes
' Recusive call...
Call BlockExplode(strExplode, arrObjects)
Next
End If
Else
' Add the object to our array
Call ArrayAdd(arrObjects, strBlock)
End If
End Sub
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' Adds a new element to the end of an array
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Sub ArrayAdd(ByRef arr, ByVal val)
Dim ub
If IsArray(arr) Then
On Error Resume Next
ub = UBound(arr)
If Err.Number <> 0 Then ub = -1
ReDim Preserve arr(ub + 1)
arr(UBound(arr)) = val
End If
End Sub