-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathConvertLayersToGrayscale.rvb
49 lines (34 loc) · 1.45 KB
/
ConvertLayersToGrayscale.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
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' ConvertLayersToGrayscale.rvb -- May 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
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' Converts the colors of layers to grayscale
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Sub ConvertLayersToGrayscale()
' Declare local variables
Dim arrLayers, strLayer, lngColor
Dim nGray, nRed, nGreen, nBlue
' Turn off screen redrawing (for performance)
Call Rhino.EnableRedraw(False)
' Get all of the layers in the document
arrLayers = Rhino.LayerNames
' Process each layer one-by-one
For Each strLayer In arrLayers
' Get the layer's color
lngColor = Rhino.LayerColor(strLayer)
' Get the color's red-green-blue components
nRed = Rhino.ColorRedValue(lngColor)
nGreen = Rhino.ColorGreenValue(lngColor)
nBlue = Rhino.ColorBlueValue(lngColor)
' Calculate the grayscale based on the NTSC color gamut
nGray = CByte(nRed * 0.30) + CByte(nGreen * 0.59) + CByte(nBlue * 0.11)
' Modify the layer's color
Call Rhino.LayerColor(strlayer, RGB(nGray, nGray, nGray))
Next
' Turn on screen redrawing
Call Rhino.EnableRedraw(True)
End Sub