top of page
Writer's pictureDavid Mans

Surface Six Pack

💻 Rhino 5

🔼 Rhino Script

🛠️ Visual Basic

 

This script produces six options for surface subdivisions within Rhino. It provides a curve set as an output that can be used for module population.

 
Option Explicit
'Script written by <David Mans>
'Script copyrighted by <NeoArchaic Design>
'Script version Wednesday, November 14, 2007 3:26:27 AM
 
 
Call Main()
Sub Main()
    'Inputs 
    Dim Surface, Cols, Rows, amplitudeD, amplitudeE
    'loops
    Dim i,o
    'returns
     
    Surface = Rhino.GetObject("Select Surface", 8)
    If isNull(Surface) Then Exit Sub
    Call reparameterize(Surface)
     
    Dim selection, gridset
     
    selection = Rhino.GetString("Select Grid Method", "Hexagon", array("Rectangle", "Diamond", "Hexagon", "TriangleA", "TriangleB", "X"))
     
    Cols = 10 'Rhino.GetReal("Cols",10,1)
    If isNull(Cols) Then Exit Sub
    Rows = 10 'Rhino.GetReal("Rows",10,1)
    If isNull(Rows) Then Exit Sub
     
    Call Rhino.EnableRedraw(False)
    If selection = "Rectangle" Then
        gridset = rectGrid(surface, cols, rows)
         
    ElseIf selection = "Diamond" Then
        gridset = diaGrid(surface, cols, rows)
         
    ElseIf selection = "TriangleA" Then
        gridset = TriangleGridA(surface, cols, rows)
         
    ElseIf selection = "TriangleB" Then
        gridset = TriangleGridB(surface, cols, rows)
         
    ElseIf selection = "X" Then
        gridset = XGrid(surface, cols, rows)
         
    ElseIf selection = "Hexagon" Then
        gridset = HexGrid(surface, cols, rows)
         
    End If
     
    'gridset variables now contain a two dimensional array of curves which can be used to populate units
     
    Call Rhino.EnableRedraw(True)
End Sub
Function reparameterize(strCurveID)
    If Rhino.IsCurve(strCurveID) = True Then
        Call rhino.SelectObject(strCurveID)
        Call rhino.Command("reparameterize 0 1")
        Call rhino.UnselectAllObjects()
    End If
    If Rhino.IsSurface(strCurveID) = True Then
        Call rhino.SelectObject(strCurveID)
        Call rhino.Command("reparameterize 0 1 0 1")
        Call rhino.UnselectAllObjects()
    End If     
End Function
Function HexGrid(surface, cols, rows)
    HexGrid = Null
    Dim i,j
    Dim uDom,vDom,uStep,vStep
    Dim origin(), originSet(),ptA(6)
    Dim curves(),curveSet()
    ReDim curves(rows),curveSet(cols)
    ReDim origin(rows)
     
    uDom = Rhino.SurfaceDomain(surface, 0)
    vDom = Rhino.SurfaceDomain(surface, 1)
    uStep = uDom(1) / cols
    vStep = vDom(1) / rows
    For i = 0 To cols - 1 Step 1
        For j = 0 To rows Step 1
             
            If abs(j) Mod 2 Then
                origin(j) = Rhino.EvaluateSurface(surface, array(uStep * i, vStep * j))
                ptA(0) = Rhino.EvaluateSurface(surface, array(uStep * i + uStep / 3, vStep * j))
                ptA(1) = Rhino.EvaluateSurface(surface, array(uStep * i + uStep / 6, vStep * j + vStep))
                ptA(2) = Rhino.EvaluateSurface(surface, array(uStep * i - uStep / 6, vStep * j + vStep))
                ptA(3) = Rhino.EvaluateSurface(surface, array(uStep * i - uStep / 3, vStep * j))
                ptA(4) = Rhino.EvaluateSurface(surface, array(uStep * i - uStep / 6, vStep * j - vStep))
                ptA(5) = Rhino.EvaluateSurface(surface, array(uStep * i + uStep / 6, vStep * j - vStep))
                ptA(6) = ptA(0)
                curves(j) = Rhino.AddPolyline(ptA)
            Else
                If j > 0 And j < rows Then
                    origin(j) = Rhino.EvaluateSurface(surface, array(uStep * .5+uStep * i, vStep * j))
                    ptA(0) = Rhino.EvaluateSurface(surface, array(uStep * .5+uStep * i + uStep / 3, vStep * j))
                    ptA(1) = Rhino.EvaluateSurface(surface, array(uStep * .5+uStep * i + uStep / 6, vStep * j + vStep))
                    ptA(2) = Rhino.EvaluateSurface(surface, array(uStep * .5+uStep * i - uStep / 6, vStep * j + vStep))
                    ptA(3) = Rhino.EvaluateSurface(surface, array(uStep * .5+uStep * i - uStep / 3, vStep * j))
                    ptA(4) = Rhino.EvaluateSurface(surface, array(uStep * .5+uStep * i - uStep / 6, vStep * j - vStep))
                    ptA(5) = Rhino.EvaluateSurface(surface, array(uStep * .5+uStep * i + uStep / 6, vStep * j - vStep))
                    ptA(6) = ptA(0)
                    curves(j) = Rhino.AddPolyline(ptA)
                End If
            End If
        Next
    curveSet(i) = curves
    Next
     
    HexGrid = curveSet
End Function
Function TriangleGridA(surface, cols, rows)
    TriangleGridA = Null
    Dim i,j
    Dim uDom,vDom,uStep,vStep
    Dim origins, points(), pointset()
    ReDim points(rows), pointset(cols)
    uDom = Rhino.SurfaceDomain(surface, 0)
    vDom = Rhino.SurfaceDomain(surface, 1)
    uStep = uDom(1) / cols
    vStep = vDom(1) / rows
     
    For i = 0 To cols Step 1
        For j = 0 To rows Step 1
            If abs(j) Mod 2 Then
                points(j) = Rhino.EvaluateSurface(surface, array(uStep * .5+i * uStep, j * vStep))
                'Call Rhino.AddPoint(points(j))
            Else
                points(j) = Rhino.EvaluateSurface(surface, array(i * uStep, j * vStep))
                'Call Rhino.AddPoint(points(j))
            End If
        Next
    pointset(i) = points
    Next
    For i = 0 To cols Step 1
        For j = 0 To rows Step 1
            If j < rows Then
                If abs(j) Mod 2 Then
                    If i < cols Then
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j + 1),, pointset(i + 1)(j), pointset(i)(j)))
                    Else
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j + 1),, pointset(0)(j), pointset(i)(j)))
                    End If
                Else
                    If i = 0Then
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j + 1),, pointset(cols)(j), pointset(i)(j)))
                    Else
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j + 1),, pointset(i - 1)(j), pointset(i)(j)))
                    End If
                End If     
            End If
            If j > 0 Then
                If abs(j) Mod 2 Then
                    If i < cols Then
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j - 1),, pointset(i + 1)(j), pointset(i)(j)))
                    Else
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j - 1),, pointset(0)(j), pointset(i)(j)))
                    End If
                Else
                    If i = 0Then
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j - 1),, pointset(cols)(j), pointset(i)(j)))
                    Else
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j - 1),, pointset(i - 1)(j), pointset(i)(j)))
                    End If
                End If     
            End If
             
        Next
    Next   
    TriangleGridA = array(origins, points)
End Function
Function TriangleGridB(surface, cols, rows)
    TriangleGridB = Null
    Dim i,j
    Dim uDom,vDom,uStep,vStep
    Dim origins, points(), pointset()
    ReDim points(rows), pointset(cols)
    uDom = Rhino.SurfaceDomain(surface, 0)
    vDom = Rhino.SurfaceDomain(surface, 1)
    uStep = uDom(1) / cols
    vStep = vDom(1) / rows
     
    For i = 0 To cols Step 1
        For j = 0 To rows Step 1
            If abs(j) Mod 2 Then
                points(j) = Rhino.EvaluateSurface(surface, array(uStep * .5+i * uStep, j * vStep))
                'Call Rhino.AddPoint(points(j))
            Else
                points(j) = Rhino.EvaluateSurface(surface, array(i * uStep, j * vStep))
                'Call Rhino.AddPoint(points(j))
            End If
        Next
    pointset(i) = points
    Next
     
    For i = 0 To cols Step 1
        For j = 0 To rows Step 1
            If j < rows Then
                If abs(j) Mod 2 Then
                    If i = 0 Then
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j + 1),, pointset(cols)(j), pointset(i)(j)))
                    Else
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j + 1),, pointset(i - 1)(j), pointset(i)(j)))
                    End If
                 
                Else
                    If i < cols Then
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j + 1),, pointset(i + 1)(j), pointset(i)(j)))
                    Else
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j + 1),, pointset(0)(j), pointset(i)(j)))
                    End If
 
                End If     
            End If
             
            If j > 0 Then
                If abs(j) Mod 2 Then
                    If i = 0 Then
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j - 1),, pointset(cols)(j), pointset(i)(j)))
                    Else
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j - 1),, pointset(i - 1)(j), pointset(i)(j)))
                    End If
                 
                Else
                    If i < cols Then
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j - 1),, pointset(i + 1)(j), pointset(i)(j)))
                    Else
                        Call Rhino.AddPolyline(array(pointset(i)(j), pointset(i)(j - 1),, pointset(0)(j), pointset(i)(j)))
                    End If
 
                End If     
            End If
             
        Next
    Next   
    TriangleGridB = array(origins, points)
End Function
Function rectGrid(surface, cols, rows)
    rectGrid = Null
    Dim i,j,dblUdom, dblVdom, dblUstep, dblVstep
    Dim pt(4),crv(),crvSet()
    ReDim crv(cols),crvSet(rows)
         
    dblUdom = Rhino.SurfaceDomain(surface, 0)
    dblVdom = Rhino.SurfaceDomain(surface, 1)
    dblUstep = dblUdom(1) / (cols)
    dblVstep = dblVdom(1) / (rows)
     
    For i = 0 To cols - 1 Step 1
        For j = 0 To rows - 1 Step 1
             
            pt(0) = Rhino.EvaluateSurface(surface, array(dblUstep * .5+i * dblUstep - dblUstep * .5, dblVstep * .5+j * dblVstep - dblVstep * .5))
            pt(1) = Rhino.EvaluateSurface(surface, array(dblUstep * .5+i * dblUstep - dblUstep * .5, dblVstep * .5+j * dblVstep + dblVstep * .5))
            pt(2) = Rhino.EvaluateSurface(surface, array(dblUstep * .5+i * dblUstep + dblUstep * .5, dblVstep * .5+j * dblVstep + dblVstep * .5))
            pt(3) = Rhino.EvaluateSurface(surface, array(dblUstep * .5+i * dblUstep + dblUstep * .5, dblVstep * .5+j * dblVstep - dblVstep * .5))
            pt(4) = pt(0)
             
            crv(j) = Rhino.AddPolyline(pt)          
        Next
    crvSet(i) = crv
    Next       
    rectGrid = array(crvSet)
End Function
Function diaGrid(surface, cols, rows)
    diaGrid = Null
    Dim i,j
    Dim uDom,vDom,uStep,vStep
    Dim origin(), originSet(),ptA(4)
    Dim curves(),curveSet()
    ReDim curves(rows),curveSet(cols)
    ReDim origin(rows)
     
    uDom = Rhino.SurfaceDomain(surface, 0)
    vDom = Rhino.SurfaceDomain(surface, 1)
    uStep = uDom(1) / cols
    vStep = vDom(1) / rows
    For i = 0 To cols - 1 Step 1
        For j = 0 To rows Step 1
             
            If abs(j) Mod 2 Then
                origin(j) = Rhino.EvaluateSurface(surface, array(uStep * i, vStep * j))
                ptA(0) = Rhino.EvaluateSurface(surface, array(uStep * i, vStep * j - vStep))
                ptA(1) = Rhino.EvaluateSurface(surface, array(uStep * i - uStep * .5, vStep * j))
                ptA(2) = Rhino.EvaluateSurface(surface, array(uStep * i, vStep * j + vStep))
                ptA(3) = Rhino.EvaluateSurface(surface, array(uStep * i + uStep * .5, vStep * j))
                ptA(4) = ptA(0)
                curves(j) = Rhino.AddPolyline(ptA)
            Else
                If j > 0 And j < rows Then
                    origin(j) = Rhino.EvaluateSurface(surface, array(uStep * .5+uStep * i, vStep * j))
                    ptA(0) = Rhino.EvaluateSurface(surface, array(uStep * .5+uStep * i, vStep * j - vStep))
                    ptA(1) = Rhino.EvaluateSurface(surface, array(uStep * .5+uStep * i - uStep * .5, vStep * j))
                    ptA(2) = Rhino.EvaluateSurface(surface, array(uStep * .5+uStep * i, vStep * j + vStep))
                    ptA(3) = Rhino.EvaluateSurface(surface, array(uStep * .5+uStep * i + uStep * .5, vStep * j))
                    ptA(4) = ptA(0)
                    curves(j) = Rhino.AddPolyline(ptA)
                End If
            End If
        Next
    curveSet(i) = curves
    Next   
    diaGrid = array(curveSet)
End Function
Function XGrid(surface, cols, rows)
    XGrid = Null
    Dim i,j,dblUdom, dblVdom, dblUstep, dblVstep
    Dim pt(4),crvA(),crvSetA(),crvB(),crvSetB()
    ReDim crvA(rows),crvSetA(cols),crvB(rows),crvSetB(cols)
         
    dblUdom = Rhino.SurfaceDomain(surface, 0)
    dblVdom = Rhino.SurfaceDomain(surface, 1)
    dblUstep = dblUdom(1) / (cols)
    dblVstep = dblVdom(1) / (rows)
     
    For i = 0 To cols - 1 Step 1
        For j = 0 To rows - 1 Step 1
             
            pt(0) = Rhino.EvaluateSurface(surface, array(dblUstep * .5+i * dblUstep - dblUstep * .5, dblVstep * .5+j * dblVstep - dblVstep * .5))
            pt(1) = Rhino.EvaluateSurface(surface, array(dblUstep * .5+i * dblUstep - dblUstep * .5, dblVstep * .5+j * dblVstep + dblVstep * .5))
            pt(2) = Rhino.EvaluateSurface(surface, array(dblUstep * .5+i * dblUstep + dblUstep * .5, dblVstep * .5+j * dblVstep + dblVstep * .5))
            pt(3) = Rhino.EvaluateSurface(surface, array(dblUstep * .5+i * dblUstep + dblUstep * .5, dblVstep * .5+j * dblVstep - dblVstep * .5))
             
            crvA(j) = Rhino.AddLine(pt(0), pt(2))   
            crvB(j) = Rhino.AddLine(pt(1), pt(3))   
        Next
    crvSetA(i) = crvA
    crvSetB(i) = crvB
    Next       
    XGrid = array(crvSetA, crvSetB)
End Function
 


4 views

Recent Posts

See All
bottom of page