gambas-source-code/app/examples/OpenGL/NeHeTutorial/.src/Example25.module

244 lines
8.9 KiB
Text
Raw Normal View History

' Gambas module file
' To set up opengl window in Gambas choose New Project -> SDL Application
' mark OpenGL Programming IN Settings, give it a name AND that 's it.
Const num_points As Integer = 486
Private xrot As Float
Private yrot As Float
Private zrot As Float 'X, Y & Z Rotation
Private xspeed As Float
Private yspeed As Float
Private zspeed As Float 'X, Y & Z Spin Speed
Private cx As Float
Private cy As Float
Private cz As Float = -15 'X, Y & Z Position
Private keey As Integer = 1 'Used TO Make Sure Same Morph Key IS Not Pressed
Private stepp As Integer = 0
Private steps As Integer = 200 'STEP Counter AND Maximum Number OF Steps
Private morphing As Boolean = False 'DEFAULT morph TO FALSE(NOT Morphing)
Private morph As New Float[6, 486, 3]
Public read_line As String
Public verts As String[]
Public actual As Integer = 0
Public post As Integer = 0
Private screen As New Window(True) As "Screen"
Public Sub Main()
Randomize
With screen
.Width = 640
.Height = 480
.Title = MMain.Title
.Show()
End With
End
Public Sub load_objects()
Dim shape_file As File
Dim i, p As Integer
Dim coords As String
shape_file = Open "Sphere.txt" For Input
For p = 0 To num_points - 1
i = 0
Line Input #shape_file, read_line
verts = Split(read_line, ",")
For Each coords In verts
morph[0, p, i] = coords
morph[4, p, i] = coords
i = i + 1
Next
Next
Close shape_file
shape_file = Open "Torus.txt" For Input
For p = 0 To num_points - 1
i = 0
Line Input #shape_file, read_line
verts = Split(read_line, ",")
For Each coords In verts
morph[1, p, i] = coords
i = i + 1
Next
Next
Close shape_file
shape_file = Open "Tube.txt" For Input
For p = 0 To num_points - 1
i = 0
Line Input #shape_file, read_line
verts = Split(read_line, ",")
For Each coords In verts
morph[2, p, i] = coords
i = i + 1
Next
Next
Close shape_file
For p = 0 To num_points - 1
For i = 0 To 2
morph[3, p, i] = Rnd(12) - 7
Next
Next
End
Public Sub calculate(i As Integer, sourc As Integer, desti As Integer)
morph[5, i, 0] = (morph[sourc, i, 0] - morph[desti, i, 0]) / steps
morph[5, i, 1] = (morph[sourc, i, 1] - morph[desti, i, 1]) / steps
morph[5, i, 2] = (morph[sourc, i, 2] - morph[desti, i, 2]) / steps
End
Public Sub Screen_Open()
Gl.ClearDepth(100.0) 'Enables Clearing Of The Depth Buffer
gl.ClearColor(0.0, 0.0, 0.0, 0.0) 'This Will Clear The Background Color To Black
gl.DepthFunc(gl.LESS) 'The Type Of Depth Test To Do
gl.Enable(gl.DEPTH_TEST) 'Enables Depth Testing
gl.ShadeModel(gl.SMOOTH) 'Enables Smooth Color Shading
gl.MatrixMode(gl.PROJECTION)
gl.LoadIdentity() 'Reset The Projection Matrix
glu.Perspective(45.0, screen.Width / screen.Height, 0.1, 100.0) 'Calculate The Aspect Ratio Of The Window
gl.MatrixMode(gl.MODELVIEW)
Init()
End
Public Sub Screen_resize()
Gl.Viewport(0, 0, Screen.Width, Screen.Height)
Gl.MatrixMode(Gl.PROJECTION)
Gl.LoadIdentity() 'Reset The Projection Matrix
glu.Perspective(45.0, screen.Width / screen.Height, 0.1, 100.0) 'Calculate The Aspect Ratio Of The Window
Gl.MatrixMode(Gl.MODELVIEW)
End
Public Sub Init() 'All Setup FOR OpenGL Goes Here
gl.BlendFunc(gl.SRC_ALPHA, gl.ONE) 'Set The Blending FUNCTION For Translucency
gl.clearColor(0.0, 0.0, 0.0, 0.0) 'This Will Clear The Background Color TO Black
gl.clearDepth(1.0) 'Enables Clearing OF The Depth Buffer
gl.DepthFunc(gl.LESS) 'The Type OF Depth Test TO DO
gl.Enable(gl.DEPTH_TEST) 'Enables Depth Testing
gl.ShadeModel(gl.SMOOTH) 'Enables Smooth Color Shading
gl.Hint(gl.PERSPECTIVE_CORRECTION_HINT, gl.NICEST) 'Really Nice Perspective Calculations
load_objects()
End
Public Sub Screen_Draw()
Dim tx, ty, tz As Float '/ / Temp X, Y & Z Variables
Dim i, j, k, p As Integer
gl.Clear(gl.COLOR_BUFFER_BIT Or gl.DEPTH_BUFFER_BIT) 'Clear The Screen And The Depth Buffer
gl.LoadIdentity() 'Reset The View
gl.Translatef(cx, cy, cz) 'Translate The The Current Position TO Start Drawing
gl.Rotatef(xrot, 1, 0, 0) 'Rotate On The X Axis By xrot
gl.Rotatef(yrot, 0, 1, 0) 'Rotate On The Y Axis By yrot
gl.Rotatef(zrot, 0, 0, 1) 'Rotate On The Z Axis By zrot
xrot += xspeed
yrot += yspeed
zrot += zspeed 'Increase xrot, yrot & zrot by xspeed, yspeed & zspeed
'VERTEX q; / / Holds Returned Calculated Values FOR One Vertex
gl.begin(gl.POINTS) 'Begin Drawing Points
For i = 0 To num_points - 1 'Loop Through All The Verts Of morph
If (morphing) Then
calculate(i, actual, post)
Else
morph[5, i, 0] = 0
morph[5, i, 1] = 0
morph[5, i, 2] = 0
Endif
morph[4, i, 0] -= morph[5, i, 0] 'Subtract q.x Units FROM helper.points[i].x( MOVE On X Axis)
morph[4, i, 1] -= morph[5, i, 1] 'Subtract q.y Units FROM helper.points[i].y( MOVE On Y Axis)
morph[4, i, 2] -= morph[5, i, 2] 'Subtract q.z Units FROM helper.points[i].z( MOVE On Z Axis)
tx = morph[4, i, 0] 'Make Temp X Variable Equal TO Helper 's X Variable
ty = morph[4, i, 1] 'Make Temp Y Variable Equal TO Helper 's Y Variable
tz = morph[4, i, 2] 'Make Temp Z Variable Equal TO Helper 's Z Variable
gl.Color3f(0, 1, 1) 'Set Color TO A Bright Shade OF Off Blue
gl.Vertex3f(tx, ty, tz) 'Draw A Point At The Current Temp Values(Vertex)
gl.Color3f(0, 0.5, 1) 'Darken Color A Bit
tx -= 2 * morph[5, i, 0]
ty -= 2 * morph[5, i, 0]
ty -= 2 * morph[5, i, 0] 'Calculate Two Positions Ahead
gl.Vertex3f(tx, ty, tz) 'Draw A Second Point At The Newly Calculate Position
gl.Color3f(0, 0, 1) 'Set Color TO A Very Dark Blue
tx -= 2 * morph[5, i, 0]
ty -= 2 * morph[5, i, 0]
ty -= 2 * morph[5, i, 0] 'Calculate Two More Positions Ahead
gl.Vertex3f(tx, ty, tz) 'Draw A Third Point At The Second NEW Position
Next 'This Creates A Ghostly Tail AS Points MOVE
gl.End() 'Done Drawing Points
If (morphing And (stepp <= steps)) Then
stepp += 1
Else
morphing = False
actual = post
stepp = 0
Endif
End
Public Sub Screen_KeyPress()
Debug Key.Code;; Key.Text
If (key.code = key.F1) Then screen.Fullscreen = Not screen.Fullscreen
If (key.Code = key.Esc) Then Screen.Close()
If (key.code = key.PageUp) Then zspeed += 0.01 'MOVE the cube into the distance.
If (key.code = key.Pagedown) Then zspeed -= 0.01 'MOVE the cube closer.
If (key.code = key.UP) Then xspeed -= 0.01 'decrease x rotation speed;
If (key.code = key.DOWN) Then xspeed += 0.01 'increase x rotation speed;
If (key.code = key.LEFT) Then yspeed -= 0.01 'decrease y rotation speed;
If (key.code = key.RIGHT) Then yspeed += 0.01 'increase y rotation speed;
If (key.text = "q") Then cz -= 0.01 'Is Q Key Being Pressed? Move Object Away From Viewer
If (key.text = "z") Then cz += 0.01 'Is Z Key Being Pressed? MOVE Object Towards Viewer
If (key.text = "w") Then cy += 0.01 'Is W Key Being Pressed? MOVE Object Up
If (key.text = "s") Then cy -= 0.01 'Is S Key Being Pressed? MOVE Object Down
If (key.text = "d") Then cx += 0.01 'Is D Key Being Pressed? MOVE Object Right
If (key.text = "a") Then cx -= 0.01 'Is A Key Being Pressed? MOVE Object Left
If (key.text = "1") Then
If ((keey <> 1) And morphing = False) Then
keey = 1 'Sets key TO 1( TO Prevent Pressing 1 2 x IN A Row)
morphing = True 'Set morph TO TRUE(Starts Morphing Process)
post = 0 'Destination Object TO Morph TO Becomes morph1
Endif
Endif
If (key.text = "2") Then
If ((keey <> 2) And morphing = False) Then
keey = 2 'Sets key TO 1( TO Prevent Pressing 1 2 x IN A Row)
morphing = True 'Set morph TO TRUE(Starts Morphing Process)
post = 1 'Destination Object TO Morph TO Becomes morph1
Endif
Endif
If (key.text = "3") Then
If ((keey <> 3) And morphing = False) Then
keey = 3 'Sets key TO 1( TO Prevent Pressing 1 2 x IN A Row)
morphing = True 'Set morph TO TRUE(Starts Morphing Process)
post = 2 'Destination Object TO Morph TO Becomes morph1
Endif
Endif
If (key.text = "4") Then
If ((keey <> 4) And morphing = False) Then
keey = 4 'Sets key TO 1( TO Prevent Pressing 1 2 x IN A Row)
morphing = True 'Set morph TO TRUE(Starts Morphing Process)
post = 3 'Destination Object TO Morph TO Becomes morph1
Endif
Endif
End