ruby-opengl2 0.60.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (117) hide show
  1. data/Rakefile +80 -0
  2. data/examples/NeHe/nehe_lesson02.rb +117 -0
  3. data/examples/NeHe/nehe_lesson03.rb +122 -0
  4. data/examples/NeHe/nehe_lesson04.rb +133 -0
  5. data/examples/NeHe/nehe_lesson05.rb +186 -0
  6. data/examples/NeHe/nehe_lesson36.rb +303 -0
  7. data/examples/OrangeBook/3Dlabs-License.txt +33 -0
  8. data/examples/OrangeBook/brick.frag +36 -0
  9. data/examples/OrangeBook/brick.rb +376 -0
  10. data/examples/OrangeBook/brick.vert +41 -0
  11. data/examples/OrangeBook/particle.frag +17 -0
  12. data/examples/OrangeBook/particle.rb +406 -0
  13. data/examples/OrangeBook/particle.vert +38 -0
  14. data/examples/README +16 -0
  15. data/examples/RedBook/aapoly.rb +142 -0
  16. data/examples/RedBook/aargb.rb +119 -0
  17. data/examples/RedBook/accanti.rb +162 -0
  18. data/examples/RedBook/accpersp.rb +215 -0
  19. data/examples/RedBook/alpha.rb +123 -0
  20. data/examples/RedBook/alpha3D.rb +158 -0
  21. data/examples/RedBook/bezcurve.rb +105 -0
  22. data/examples/RedBook/bezmesh.rb +137 -0
  23. data/examples/RedBook/checker.rb +124 -0
  24. data/examples/RedBook/clip.rb +95 -0
  25. data/examples/RedBook/colormat.rb +135 -0
  26. data/examples/RedBook/cube.rb +69 -0
  27. data/examples/RedBook/depthcue.rb +99 -0
  28. data/examples/RedBook/dof.rb +205 -0
  29. data/examples/RedBook/double.rb +105 -0
  30. data/examples/RedBook/drawf.rb +91 -0
  31. data/examples/RedBook/feedback.rb +145 -0
  32. data/examples/RedBook/fog.rb +167 -0
  33. data/examples/RedBook/font.rb +151 -0
  34. data/examples/RedBook/hello.rb +79 -0
  35. data/examples/RedBook/image.rb +137 -0
  36. data/examples/RedBook/jitter.rb +207 -0
  37. data/examples/RedBook/lines.rb +128 -0
  38. data/examples/RedBook/list.rb +111 -0
  39. data/examples/RedBook/material.rb +275 -0
  40. data/examples/RedBook/mipmap.rb +156 -0
  41. data/examples/RedBook/model.rb +113 -0
  42. data/examples/RedBook/movelight.rb +132 -0
  43. data/examples/RedBook/pickdepth.rb +179 -0
  44. data/examples/RedBook/planet.rb +108 -0
  45. data/examples/RedBook/quadric.rb +158 -0
  46. data/examples/RedBook/robot.rb +115 -0
  47. data/examples/RedBook/select.rb +196 -0
  48. data/examples/RedBook/smooth.rb +95 -0
  49. data/examples/RedBook/stencil.rb +163 -0
  50. data/examples/RedBook/stroke.rb +167 -0
  51. data/examples/RedBook/surface.rb +166 -0
  52. data/examples/RedBook/teaambient.rb +132 -0
  53. data/examples/RedBook/teapots.rb +182 -0
  54. data/examples/RedBook/tess.rb +183 -0
  55. data/examples/RedBook/texbind.rb +147 -0
  56. data/examples/RedBook/texgen.rb +169 -0
  57. data/examples/RedBook/texturesurf.rb +128 -0
  58. data/examples/RedBook/varray.rb +159 -0
  59. data/examples/RedBook/wrap.rb +148 -0
  60. data/examples/misc/OGLBench.rb +337 -0
  61. data/examples/misc/anisotropic.rb +194 -0
  62. data/examples/misc/fbo_test.rb +356 -0
  63. data/examples/misc/font-glut.rb +46 -0
  64. data/examples/misc/glfwtest.rb +30 -0
  65. data/examples/misc/plane.rb +161 -0
  66. data/examples/misc/readpixel.rb +65 -0
  67. data/examples/misc/sdltest.rb +34 -0
  68. data/examples/misc/trislam.rb +828 -0
  69. data/ext/common/common.h +423 -0
  70. data/ext/common/conv.h +243 -0
  71. data/ext/common/funcdef.h +280 -0
  72. data/ext/common/gl-enums.h +10031 -0
  73. data/ext/common/gl-error.h +23 -0
  74. data/ext/common/gl-types.h +63 -0
  75. data/ext/common/glu-enums.h +463 -0
  76. data/ext/gl/gl-1.0-1.1.c +2811 -0
  77. data/ext/gl/gl-1.2.c +814 -0
  78. data/ext/gl/gl-1.3.c +443 -0
  79. data/ext/gl/gl-1.4.c +348 -0
  80. data/ext/gl/gl-1.5.c +225 -0
  81. data/ext/gl/gl-2.0.c +657 -0
  82. data/ext/gl/gl-2.1.c +57 -0
  83. data/ext/gl/gl-enums.c +3354 -0
  84. data/ext/gl/gl-error.c +104 -0
  85. data/ext/gl/gl-ext-3dfx.c +27 -0
  86. data/ext/gl/gl-ext-arb.c +866 -0
  87. data/ext/gl/gl-ext-ati.c +41 -0
  88. data/ext/gl/gl-ext-ext.c +889 -0
  89. data/ext/gl/gl-ext-gremedy.c +41 -0
  90. data/ext/gl/gl-ext-nv.c +679 -0
  91. data/ext/gl/gl.c +214 -0
  92. data/ext/gl/mkrf_conf.rb +37 -0
  93. data/ext/glu/glu-enums.c +164 -0
  94. data/ext/glu/glu.c +1530 -0
  95. data/ext/glu/mkrf_conf.rb +39 -0
  96. data/ext/glut/glut.c +1627 -0
  97. data/ext/glut/mkrf_conf.rb +37 -0
  98. data/lib/opengl.rb +84 -0
  99. data/test/README +10 -0
  100. data/test/tc_common.rb +98 -0
  101. data/test/tc_ext_arb.rb +467 -0
  102. data/test/tc_ext_ati.rb +33 -0
  103. data/test/tc_ext_ext.rb +551 -0
  104. data/test/tc_ext_gremedy.rb +36 -0
  105. data/test/tc_ext_nv.rb +357 -0
  106. data/test/tc_func_10_11.rb +1281 -0
  107. data/test/tc_func_12.rb +186 -0
  108. data/test/tc_func_13.rb +229 -0
  109. data/test/tc_func_14.rb +197 -0
  110. data/test/tc_func_15.rb +270 -0
  111. data/test/tc_func_20.rb +346 -0
  112. data/test/tc_func_21.rb +541 -0
  113. data/test/tc_glu.rb +310 -0
  114. data/test/tc_include_gl.rb +35 -0
  115. data/test/tc_misc.rb +54 -0
  116. data/test/tc_require_gl.rb +34 -0
  117. metadata +164 -0
@@ -0,0 +1,123 @@
1
+ #
2
+ # Copyright (c) 1993-1997, Silicon Graphics, Inc.
3
+ # ALL RIGHTS RESERVED
4
+ # Permission to use, copy, modify, and distribute this software for
5
+ # any purpose and without fee is hereby granted, provided that the above
6
+ # copyright notice appear in all copies and that both the copyright notice
7
+ # and this permission notice appear in supporting documentation, and that
8
+ # the name of Silicon Graphics, Inc. not be used in advertising
9
+ # or publicity pertaining to distribution of the software without specific,
10
+ # written prior permission.
11
+ #
12
+ # THE MATERIAL EMBODIED ON THIS SOFTWARE IS PROVIDED TO YOU "AS-IS"
13
+ # AND WITHOUT WARRANTY OF ANY KIND, EXPRESS, IMPLIED OR OTHERWISE,
14
+ # INCLUDING WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY OR
15
+ # FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL SILICON
16
+ # GRAPHICS, INC. BE LIABLE TO YOU OR ANYONE ELSE FOR ANY DIRECT,
17
+ # SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY
18
+ # KIND, OR ANY DAMAGES WHATSOEVER, INCLUDING WITHOUT LIMITATION,
19
+ # LOSS OF PROFIT, LOSS OF USE, SAVINGS OR REVENUE, OR THE CLAIMS OF
20
+ # THIRD PARTIES, WHETHER OR NOT SILICON GRAPHICS, INC. HAS BEEN
21
+ # ADVISED OF THE POSSIBILITY OF SUCH LOSS, HOWEVER CAUSED AND ON
22
+ # ANY THEORY OF LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE
23
+ # POSSESSION, USE OR PERFORMANCE OF THIS SOFTWARE.
24
+ #
25
+ # US Government Users Restricted Rights
26
+ # Use, duplication, or disclosure by the Government is subject to
27
+ # restrictions set forth in FAR 52.227.19(c)(2) or subparagraph
28
+ # (c)(1)(ii) of the Rights in Technical Data and Computer Software
29
+ # clause at DFARS 252.227-7013 and/or in similar or successor
30
+ # clauses in the FAR or the DOD or NASA FAR Supplement.
31
+ # Unpublished-- rights reserved under the copyright laws of the
32
+ # United States. Contractor/manufacturer is Silicon Graphics,
33
+ # Inc., 2011 N. Shoreline Blvd., Mountain View, CA 94039-7311.
34
+ #
35
+ # OpenGL(R) is a registered trademark of Silicon Graphics, Inc.
36
+ #
37
+ # alpha.c
38
+ # This program draws several overlapping filled polygons
39
+ # to demonstrate the effect order has on alpha blending results.
40
+ # Use the 't' key to toggle the order of drawing polygons.
41
+ require 'opengl'
42
+ require 'mathn'
43
+ include Gl,Glu,Glut
44
+
45
+ $leftFirst = GL_TRUE
46
+
47
+ # Initialize alpha blending function.
48
+ def init
49
+ glEnable(GL_BLEND)
50
+ glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA)
51
+ glShadeModel(GL_FLAT)
52
+ glClearColor(0.0, 0.0, 0.0, 0.0)
53
+ end
54
+
55
+ def drawLeftTriangle
56
+ # draw yellow triangle on LHS of screen
57
+
58
+ glBegin(GL_TRIANGLES)
59
+ glColor(1.0, 1.0, 0.0, 0.75)
60
+ glVertex(0.1, 0.9, 0.0)
61
+ glVertex(0.1, 0.1, 0.0)
62
+ glVertex(0.7, 0.5, 0.0)
63
+ glEnd()
64
+ end
65
+
66
+ def drawRightTriangle
67
+ # draw cyan triangle on RHS of screen
68
+
69
+ glBegin(GL_TRIANGLES)
70
+ glColor(0.0, 1.0, 1.0, 0.75)
71
+ glVertex(0.9, 0.9, 0.0)
72
+ glVertex(0.3, 0.5, 0.0)
73
+ glVertex(0.9, 0.1, 0.0)
74
+ glEnd()
75
+ end
76
+
77
+ display = Proc.new do
78
+ glClear(GL_COLOR_BUFFER_BIT)
79
+
80
+ if ($leftFirst)
81
+ drawLeftTriangle()
82
+ drawRightTriangle()
83
+ else
84
+ drawRightTriangle()
85
+ drawLeftTriangle()
86
+ end
87
+ glutSwapBuffers()
88
+ end
89
+
90
+ reshape = Proc.new do |w, h|
91
+ glViewport(0, 0, w, h)
92
+ glMatrixMode(GL_PROJECTION)
93
+ glLoadIdentity()
94
+ if (w <= h)
95
+ gluOrtho2D(0.0, 1.0, 0.0, 1.0*h/w)
96
+ else
97
+ gluOrtho2D(0.0, 1.0*w/h, 0.0, 1.0)
98
+ end
99
+ end
100
+
101
+ keyboard = Proc.new do|key, x, y|
102
+ case (key)
103
+ when ?t,?T
104
+ $leftFirst = !$leftFirst
105
+ glutPostRedisplay()
106
+ when ?\e # Escape key
107
+ exit(0)
108
+ end
109
+ end
110
+
111
+ # Main Loop
112
+ # Open window with initial window size, title bar,
113
+ # RGBA display mode, and handle input events.
114
+ glutInit
115
+ glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB)
116
+ glutInitWindowSize(500, 500)
117
+ glutInitWindowPosition(100, 100)
118
+ glutCreateWindow($0)
119
+ init()
120
+ glutReshapeFunc(reshape)
121
+ glutKeyboardFunc(keyboard)
122
+ glutDisplayFunc(display)
123
+ glutMainLoop()
@@ -0,0 +1,158 @@
1
+ #
2
+ # Copyright (c) 1993-1997, Silicon Graphics, Inc.
3
+ # ALL RIGHTS RESERVED
4
+ # Permission to use, copy, modify, and distribute this software for
5
+ # any purpose and without fee is hereby granted, provided that the above
6
+ # copyright notice appear in all copies and that both the copyright notice
7
+ # and this permission notice appear in supporting documentation, and that
8
+ # the name of Silicon Graphics, Inc. not be used in advertising
9
+ # or publicity pertaining to distribution of the software without specific,
10
+ # written prior permission.
11
+ #
12
+ # THE MATERIAL EMBODIED ON THIS SOFTWARE IS PROVIDED TO YOU "AS-IS"
13
+ # AND WITHOUT WARRANTY OF ANY KIND, EXPRESS, IMPLIED OR OTHERWISE,
14
+ # INCLUDING WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY OR
15
+ # FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL SILICON
16
+ # GRAPHICS, INC. BE LIABLE TO YOU OR ANYONE ELSE FOR ANY DIRECT,
17
+ # SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY
18
+ # KIND, OR ANY DAMAGES WHATSOEVER, INCLUDING WITHOUT LIMITATION,
19
+ # LOSS OF PROFIT, LOSS OF USE, SAVINGS OR REVENUE, OR THE CLAIMS OF
20
+ # THIRD PARTIES, WHETHER OR NOT SILICON GRAPHICS, INC. HAS BEEN
21
+ # ADVISED OF THE POSSIBILITY OF SUCH LOSS, HOWEVER CAUSED AND ON
22
+ # ANY THEORY OF LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE
23
+ # POSSESSION, USE OR PERFORMANCE OF THIS SOFTWARE.
24
+ #
25
+ # US Government Users Restricted Rights
26
+ # Use, duplication, or disclosure by the Government is subject to
27
+ # restrictions set forth in FAR 52.227.19(c)(2) or subparagraph
28
+ # (c)(1)(ii) of the Rights in Technical Data and Computer Software
29
+ # clause at DFARS 252.227-7013 and/or in similar or successor
30
+ # clauses in the FAR or the DOD or NASA FAR Supplement.
31
+ # Unpublished-- rights reserved under the copyright laws of the
32
+ # United States. Contractor/manufacturer is Silicon Graphics,
33
+ # Inc., 2011 N. Shoreline Blvd., Mountain View, CA 94039-7311.
34
+ #
35
+ # OpenGL(R) is a registered trademark of Silicon Graphics, Inc.
36
+ #
37
+ # alpha3D.c
38
+ # This program demonstrates how to intermix opaque and
39
+ # alpha blended polygons in the same scene, by using
40
+ # glDepthMask. Press the 'a' key to animate moving the
41
+ # transparent object through the opaque object. Press
42
+ # the 'r' key to reset the scene.
43
+ require 'opengl'
44
+ include Gl,Glu,Glut
45
+
46
+ MAXZ=1.0
47
+ MINZ=-2.0
48
+ ZINC=0.1
49
+
50
+ $solidZ = MAXZ
51
+ $transparentZ = MINZ
52
+ $sphereList=nil
53
+ $cubeList=nil
54
+
55
+ def init
56
+ mat_specular = [ 1.0, 1.0, 1.0, 0.15 ]
57
+ mat_shininess = [ 100.0 ]
58
+ position = [ 0.5, 0.5, 1.0, 0.0 ]
59
+
60
+ glMaterial(GL_FRONT, GL_SPECULAR, mat_specular)
61
+ glMaterial(GL_FRONT, GL_SHININESS, mat_shininess)
62
+ glLight(GL_LIGHT0, GL_POSITION, position)
63
+
64
+ glEnable(GL_LIGHTING)
65
+ glEnable(GL_LIGHT0)
66
+ glEnable(GL_DEPTH_TEST)
67
+
68
+ $sphereList = glGenLists(1)
69
+ glNewList($sphereList, GL_COMPILE)
70
+ glutSolidSphere(0.4, 16, 16)
71
+ glEndList()
72
+
73
+ $cubeList = glGenLists(1)
74
+ glNewList($cubeList, GL_COMPILE)
75
+ glutSolidCube(0.6)
76
+ glEndList()
77
+ end
78
+
79
+ display = proc do
80
+ mat_solid = [ 0.75, 0.75, 0.0, 1.0 ]
81
+ mat_zero = [ 0.0, 0.0, 0.0, 1.0 ]
82
+ mat_transparent = [ 0.0, 0.8, 0.8, 0.6 ]
83
+ mat_emission = [ 0.0, 0.3, 0.3, 0.6 ]
84
+
85
+ glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT)
86
+
87
+ glPushMatrix()
88
+ glTranslate(-0.15, -0.15, $solidZ)
89
+ glMaterial(GL_FRONT, GL_EMISSION, mat_zero)
90
+ glMaterial(GL_FRONT, GL_DIFFUSE, mat_solid)
91
+ glCallList($sphereList)
92
+ glPopMatrix()
93
+
94
+ glPushMatrix()
95
+ glTranslate(0.15, 0.15, $transparentZ)
96
+ glRotate(15.0, 1.0, 1.0, 0.0)
97
+ glRotate(30.0, 0.0, 1.0, 0.0)
98
+ glMaterial(GL_FRONT, GL_EMISSION, mat_emission)
99
+ glMaterial(GL_FRONT, GL_DIFFUSE, mat_transparent)
100
+ glEnable(GL_BLEND)
101
+ glDepthMask(GL_FALSE)
102
+ glBlendFunc(GL_SRC_ALPHA, GL_ONE)
103
+ glCallList($cubeList)
104
+ glDepthMask(GL_TRUE)
105
+ glDisable(GL_BLEND)
106
+ glPopMatrix()
107
+
108
+ glutSwapBuffers()
109
+ end
110
+
111
+ reshape = proc do |w, h|
112
+ glViewport(0, 0, w, h)
113
+ glMatrixMode(GL_PROJECTION)
114
+ glLoadIdentity()
115
+ if (w <= h)
116
+ glOrtho(-1.5, 1.5, -1.5*h.to_f/w, 1.5*h.to_f/w, -10.0, 10.0)
117
+ else
118
+ glOrtho(-1.5*w.to_f/h, 1.5*w.to_f/h, -1.5, 1.5, -10.0, 10.0)
119
+ end
120
+ glMatrixMode(GL_MODELVIEW)
121
+ glLoadIdentity()
122
+ end
123
+
124
+ animate = proc do
125
+ if ($solidZ <= MINZ || $transparentZ >= MAXZ)
126
+ glutIdleFunc(nil)
127
+ else
128
+ $solidZ -= ZINC
129
+ $transparentZ += ZINC
130
+ glutPostRedisplay()
131
+ end
132
+ end
133
+
134
+ keyboard = proc do |key, x, y|
135
+ case (key)
136
+ when ?a,?A
137
+ $solidZ = MAXZ
138
+ $transparentZ = MINZ
139
+ glutIdleFunc(animate)
140
+ when ?r, ?R
141
+ $solidZ = MAXZ
142
+ $transparentZ = MINZ
143
+ glutPostRedisplay()
144
+ when ?\e
145
+ exit(0)
146
+ end
147
+ end
148
+
149
+ glutInit()
150
+ glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB | GLUT_DEPTH)
151
+ glutInitWindowSize(500, 500)
152
+ glutInitWindowPosition(100, 100)
153
+ glutCreateWindow($0)
154
+ init()
155
+ glutReshapeFunc(reshape)
156
+ glutKeyboardFunc(keyboard)
157
+ glutDisplayFunc(display)
158
+ glutMainLoop()
@@ -0,0 +1,105 @@
1
+ #
2
+ # Copyright (c) 1993-1997, Silicon Graphics, Inc.
3
+ # ALL RIGHTS RESERVED
4
+ # Permission to use, copy, modify, and distribute this software for
5
+ # any purpose and without fee is hereby granted, provided that the above
6
+ # copyright notice appear in all copies and that both the copyright notice
7
+ # and this permission notice appear in supporting documentation, and that
8
+ # the name of Silicon Graphics, Inc. not be used in advertising
9
+ # or publicity pertaining to distribution of the software without specific,
10
+ # written prior permission.
11
+ #
12
+ # THE MATERIAL EMBODIED ON THIS SOFTWARE IS PROVIDED TO YOU "AS-IS"
13
+ # AND WITHOUT WARRANTY OF ANY KIND, EXPRESS, IMPLIED OR OTHERWISE,
14
+ # INCLUDING WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY OR
15
+ # FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL SILICON
16
+ # GRAPHICS, INC. BE LIABLE TO YOU OR ANYONE ELSE FOR ANY DIRECT,
17
+ # SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY
18
+ # KIND, OR ANY DAMAGES WHATSOEVER, INCLUDING WITHOUT LIMITATION,
19
+ # LOSS OF PROFIT, LOSS OF USE, SAVINGS OR REVENUE, OR THE CLAIMS OF
20
+ # THIRD PARTIES, WHETHER OR NOT SILICON GRAPHICS, INC. HAS BEEN
21
+ # ADVISED OF THE POSSIBILITY OF SUCH LOSS, HOWEVER CAUSED AND ON
22
+ # ANY THEORY OF LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE
23
+ # POSSESSION, USE OR PERFORMANCE OF THIS SOFTWARE.
24
+ #
25
+ # US Government Users Restricted Rights
26
+ # Use, duplication, or disclosure by the Government is subject to
27
+ # restrictions set forth in FAR 52.227.19(c)(2) or subparagraph
28
+ # (c)(1)(ii) of the Rights in Technical Data and Computer Software
29
+ # clause at DFARS 252.227-7013 and/or in similar or successor
30
+ # clauses in the FAR or the DOD or NASA FAR Supplement.
31
+ # Unpublished-- rights reserved under the copyright laws of the
32
+ # United States. Contractor/manufacturer is Silicon Graphics,
33
+ # Inc., 2011 N. Shoreline Blvd., Mountain View, CA 94039-7311.
34
+ #
35
+ # OpenGL(R) is a registered trademark of Silicon Graphics, Inc.
36
+ #
37
+ # bezcurve.c
38
+ # This program uses evaluators to draw a Bezier curve.
39
+
40
+ require "opengl"
41
+ include Gl,Glu,Glut
42
+
43
+ $ctrlpoints = [
44
+ [-4.0,-4.0, 0.0],
45
+ [-2.0, 4.0, 0.0],
46
+ [ 2.0,-4.0, 0.0],
47
+ [ 4.0, 4.0, 0.0]
48
+ ]
49
+
50
+ def init
51
+ glClearColor(0.0, 0.0, 0.0, 0.0)
52
+ glShadeModel(GL_FLAT)
53
+ glMap1d(GL_MAP1_VERTEX_3, 0.0, 1.0, 3, 4, $ctrlpoints.flatten)
54
+ glEnable(GL_MAP1_VERTEX_3)
55
+ end
56
+
57
+ display = proc do
58
+ glClear(GL_COLOR_BUFFER_BIT)
59
+ glColor(1.0, 1.0, 1.0)
60
+ glBegin(GL_LINE_STRIP)
61
+ for i in 0..30
62
+ glEvalCoord1d(i.to_f/30.0)
63
+ end
64
+ glEnd()
65
+ # The following code displays the control points as dots.
66
+ glPointSize(5.0)
67
+ glColor(1.0, 1.0, 0.0)
68
+ glBegin(GL_POINTS)
69
+ for i in 0...4
70
+ glVertex($ctrlpoints[i])
71
+ end
72
+ glEnd()
73
+ glutSwapBuffers()
74
+ end
75
+
76
+ reshape = proc do |w, h|
77
+ glViewport(0, 0, w, h)
78
+ glMatrixMode(GL_PROJECTION)
79
+ glLoadIdentity()
80
+ if (w <= h)
81
+ glOrtho(-5.0, 5.0, -5.0*h/w, 5.0*h/w, -5.0, 5.0)
82
+ else
83
+ glOrtho(-5.0*w/h, 5.0*w/h, -5.0, 5.0, -5.0, 5.0)
84
+ end
85
+ glMatrixMode(GL_MODELVIEW)
86
+ glLoadIdentity()
87
+ end
88
+
89
+ keyboard = proc do |key, x, y|
90
+ case (key)
91
+ when ?\e
92
+ exit(0)
93
+ end
94
+ end
95
+
96
+ glutInit()
97
+ glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB)
98
+ glutInitWindowSize(500, 500)
99
+ glutInitWindowPosition(100, 100)
100
+ glutCreateWindow()
101
+ init()
102
+ glutDisplayFunc(display)
103
+ glutReshapeFunc(reshape)
104
+ glutKeyboardFunc(keyboard)
105
+ glutMainLoop()
@@ -0,0 +1,137 @@
1
+ #
2
+ # Copyright (c) Mark J. Kilgard, 1994.
3
+ #
4
+ # (c) Copyright 1993, Silicon Graphics, Inc.
5
+ # ALL RIGHTS RESERVED
6
+ # Permission to use, copy, modify, and distribute this software for
7
+ # any purpose and without fee is hereby granted, provided that the above
8
+ # copyright notice appear in all copies and that both the copyright notice
9
+ # and this permission notice appear in supporting documentation, and that
10
+ # the name of Silicon Graphics, Inc. not be used in advertising
11
+ # or publicity pertaining to distribution of the software without specific,
12
+ # written prior permission.
13
+ #
14
+ # THE MATERIAL EMBODIED ON THIS SOFTWARE IS PROVIDED TO YOU "AS-IS"
15
+ # AND WITHOUT WARRANTY OF ANY KIND, EXPRESS, IMPLIED OR OTHERWISE,
16
+ # INCLUDING WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY OR
17
+ # FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL SILICON
18
+ # GRAPHICS, INC. BE LIABLE TO YOU OR ANYONE ELSE FOR ANY DIRECT,
19
+ # SPECIAL, INCIDENTAL, INDIRECT OR CONSEQUENTIAL DAMAGES OF ANY
20
+ # KIND, OR ANY DAMAGES WHATSOEVER, INCLUDING WITHOUT LIMITATION,
21
+ # LOSS OF PROFIT, LOSS OF USE, SAVINGS OR REVENUE, OR THE CLAIMS OF
22
+ # THIRD PARTIES, WHETHER OR NOT SILICON GRAPHICS, INC. HAS BEEN
23
+ # ADVISED OF THE POSSIBILITY OF SUCH LOSS, HOWEVER CAUSED AND ON
24
+ # ANY THEORY OF LIABILITY, ARISING OUT OF OR IN CONNECTION WITH THE
25
+ # POSSESSION, USE OR PERFORMANCE OF THIS SOFTWARE.
26
+ #
27
+ # US Government Users Restricted Rights
28
+ # Use, duplication, or disclosure by the Government is subject to
29
+ # restrictions set forth in FAR 52.227.19(c)(2) or subparagraph
30
+ # (c)(1)(ii) of the Rights in Technical Data and Computer Software
31
+ # clause at DFARS 252.227-7013 and/or in similar or successor
32
+ # clauses in the FAR or the DOD or NASA FAR Supplement.
33
+ # Unpublished-- rights reserved under the copyright laws of the
34
+ # United States. Contractor/manufacturer is Silicon Graphics,
35
+ # Inc., 2011 N. Shoreline Blvd., Mountain View, CA 94039-7311.
36
+ #
37
+ # OpenGL(TM) is a trademark of Silicon Graphics, Inc.
38
+ #
39
+ # bezsurf.c
40
+ # This program renders a lighted, filled Bezier surface,
41
+ # using two-dimensional evaluators.
42
+ #
43
+
44
+ require 'opengl'
45
+ include Gl,Glu,Glut
46
+
47
+ $ctrlpoints = [
48
+ [
49
+ [-1.5, -1.5, 4.0],
50
+ [-0.5, -1.5, 2.0],
51
+ [0.5, -1.5, -1.0],
52
+ [1.5, -1.5, 2.0]],
53
+ [
54
+ [-1.5, -0.5, 1.0],
55
+ [-0.5, -0.5, 3.0],
56
+ [0.5, -0.5, 0.0],
57
+ [1.5, -0.5, -1.0]],
58
+ [
59
+ [-1.5, 0.5, 4.0],
60
+ [-0.5, 0.5, 0.0],
61
+ [0.5, 0.5, 3.0],
62
+ [1.5, 0.5, 4.0]],
63
+ [
64
+ [-1.5, 1.5, -2.0],
65
+ [-0.5, 1.5, -2.0],
66
+ [0.5, 1.5, 0.0],
67
+ [1.5, 1.5, -1.0]]
68
+ ]
69
+
70
+ def initlights
71
+ ambient = [0.2, 0.2, 0.2, 1.0]
72
+ position = [0.0, 0.0, 2.0, 1.0]
73
+ mat_diffuse = [0.6, 0.6, 0.6, 1.0]
74
+ mat_specular = [1.0, 1.0, 1.0, 1.0]
75
+ mat_shininess = [50.0]
76
+
77
+ glEnable(GL_LIGHTING)
78
+ glEnable(GL_LIGHT0)
79
+
80
+ glLight(GL_LIGHT0, GL_AMBIENT, ambient)
81
+ glLight(GL_LIGHT0, GL_POSITION, position)
82
+
83
+ glMaterial(GL_FRONT, GL_DIFFUSE, mat_diffuse)
84
+ glMaterial(GL_FRONT, GL_SPECULAR, mat_specular)
85
+ glMaterial(GL_FRONT, GL_SHININESS, mat_shininess)
86
+ end
87
+
88
+ display = proc do
89
+ glClear(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT)
90
+ glPushMatrix()
91
+ glRotate(85.0, 1.0, 1.0, 1.0)
92
+ glEvalMesh2(GL_FILL, 0, 20, 0, 20)
93
+ glPopMatrix()
94
+ glutSwapBuffers()
95
+ end
96
+
97
+ def myinit
98
+ glClearColor(0.0, 0.0, 0.0, 1.0)
99
+ glEnable(GL_DEPTH_TEST)
100
+ glMap2d(GL_MAP2_VERTEX_3, 0, 1, 3, 4, 0, 1, 12, 4, $ctrlpoints.flatten)
101
+ glEnable(GL_MAP2_VERTEX_3)
102
+ glEnable(GL_AUTO_NORMAL)
103
+ glEnable(GL_NORMALIZE)
104
+ glMapGrid2d(20, 0.0, 1.0, 20, 0.0, 1.0)
105
+ initlights() # for lighted version only
106
+ end
107
+
108
+ myReshape = proc do |w, h|
109
+ glViewport(0, 0, w, h)
110
+ glMatrixMode(GL_PROJECTION)
111
+ glLoadIdentity()
112
+ if (w <= h)
113
+ glOrtho(-4.0, 4.0, -4.0 * h / w, 4.0 * h / w, -4.0, 4.0)
114
+ else
115
+ glOrtho(-4.0 * w / h, 4.0 * w / h, -4.0, 4.0, -4.0, 4.0)
116
+ end
117
+ glMatrixMode(GL_MODELVIEW)
118
+ glLoadIdentity()
119
+ end
120
+
121
+ keyboard = Proc.new do |key, x, y|
122
+ case (key)
123
+ when ?\e
124
+ exit(0);
125
+ end
126
+ end
127
+
128
+ glutInit()
129
+ glutInitDisplayMode(GLUT_DOUBLE | GLUT_RGB | GLUT_DEPTH)
130
+ glutInitWindowSize(500, 500)
131
+ glutInitWindowPosition(100, 100)
132
+ glutCreateWindow($0)
133
+ myinit()
134
+ glutReshapeFunc(myReshape)
135
+ glutDisplayFunc(display)
136
+ glutKeyboardFunc(keyboard)
137
+ glutMainLoop()