-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathBaseballSeam.rvb
74 lines (62 loc) · 2.03 KB
/
BaseballSeam.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
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' BaseballSeam.rvb -- May 2012
' If this code works, it was written by Dale Fugier.
' If not, I don't know who wrote it.
' Works with Rhino 4.0 and Rhino 5.0.
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Option Explicit
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' Baseball
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Sub BaseballSeam()
Dim a : a = 0.4
Dim n : n = 40
Dim t0 : t0 = 0.0
Dim t1 : t1 = 4.0 * Rhino.PI
Dim pts()
ReDim pts(n)
Dim u0 : u0 = 0
Dim u1 : u1 = UBound(pts)
Dim i, t, x
For i = u0 To u1
x = NormalizedAt(u0, u1, i)
t = ParameterAt(t0, t1, x)
pts(i) = PointAt(a, t)
Rhino.Print Rhino.Pt2Str(pts(x))
Next
Call Rhino.AddInterpCurve(pts, 3, 3)
End Sub
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' PointAt
' Evaluates an ellipse at a parmeter
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Function PointAt(a, t)
Dim p, pt(2)
p = Rhino.PI
pt(0) = Sin(p / 2 - (p / 2 - a) * Cos(t)) * Cos(t / 2 + a * Sin(2 * t))
pt(1) = Sin(p / 2 - (p / 2 - a) * Cos(t)) * Sin(t / 2 + a * Sin(2 * t))
pt(2) = Cos(p / 2 - (p / 2 - a) * Cos(t))
PointAt = pt
End Function
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' ParameterAt
' Converts a normalized parameter to an interval value
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Function ParameterAt(t0, t1, x)
ParameterAt = (1.0 - x) * t0 + x * t1
End Function
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
' NormalizedAt
' Converts an interval value to a normalized parameter
'''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''''
Function NormalizedAt(t0, t1, t)
Dim x : x = t0
If (t0 <> t1) Then
If (t = t1) Then
x = 1.0
Else
x = (t - t0) / (t1 - t0)
End If
End If
NormalizedAt = x
End Function