gambas-source-code/app/examples/OpenGL/Md2Model/.src/FMain.class

244 lines
5.4 KiB
Text
Raw Normal View History

' Gambas class file
Private $aModel As Md2Model[]
Private $aObject As Md2Object[]
Private $iFrames As Integer
Private $fTime As Single
Private $fFramerate As Float
Private $iEndWidth As Integer
Private $iEndZ As Integer
Private $iDisk As Integer
Private $hQuadric As GluQuadric
Private $nDraw As Integer
' Private $fRotX As Float
' Private $fRotY As Float
' Private $fStartX As Float
' Private $fStartY As Float
Public Sub glaScreen_Open()
Init()
Gl.ClearDepth(100.0) ' Enables clearing of the depth buffer
Glu.ClearColor(&H3398C3) ' This will clear the background color to blue
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
$fTime = Timer
timAnim.Enabled = True
End
Public Sub glaScreen_Resize()
Gl.Viewport(0, 0, glaScreen.Width, glaScreen.Height)
Gl.MatrixMode(Gl.PROJECTION)
Gl.LoadIdentity() 'Reset The Projection Matrix
Glu.Perspective(45.0, glaScreen.Width / glaScreen.Height, 0.1, 3000.0) 'Calculate The Aspect Ratio Of The Window
Glu.LookAt(0, 100, 120, 0, 0, -300, 0, 100, 0)
Gl.MatrixMode(Gl.MODELVIEW)
End
Public Sub Init()
Dim X, D, Z As Float
Dim sModel As String
Dim hModel As Md2Model
Dim I As Integer
Dim aModel As String[] = ["bauul", "goblin", "knight", "ogro", "rat", "rhino"]
Dim hObject As Md2Object
'Randomize 1972
$aModel = New Md2Model[]
$aObject = New Md2Object[]
For Each sModel In aModel
$aModel.Add(Md2Model.Load(sModel & ".md2"))
$aModel[$aModel.Max].Texture = LoadTexture(sModel & ".jpg")
Next
D = 100
X = - D
Z = -100
Do
hModel = $aModel[Int(Rnd(0, aModel.Count))]
hObject = New Md2Object(hModel)
$aObject.Add(hObject)
$aObject[$aObject.Max].Move(X, -10, Z)
X += 50
If X > D Then
D += 100
X = - D
Z -= 100
Inc I
If I = 10 Then Break
Endif
Loop
Print $aObject.Count; " objects"
$iEndWidth = D
$iEndZ = Z
sldFrame.MinValue = 0
sldFrame.MaxValue = $aModel[0].Count
$iDisk = Gl.GenLists(1)
$hQuadric = Glu.NewQuadric()
Gl.NewList($iDisk, Gl.COMPILE)
Gl.Rotatef(90, 1, 0, 0)
Glu.Disk($hQuadric, 0, 20, 30, 1)
Gl.EndList
End
Public Sub glaScreen_Draw()
Dim fTime As Float = Timer
Dim I, N As Integer
Gl.Clear(Gl.COLOR_BUFFER_BIT Or Gl.DEPTH_BUFFER_BIT) ' Clear The Screen And The Depth Buffer
Gl.PushMatrix
Gl.Disable(Gl.TEXTURE_2D)
Glu.Color(&HD96800&)
Gl.Begin(Gl.QUADS)
Gl.Vertex3f(-100, -34.2, -100)
Gl.Vertex3f(100, -34.2, -100)
Gl.Vertex3f($iEndWidth, -34.2, $iEndZ)
Gl.Vertex3f(- $iEndWidth, -34.2, $iEndZ)
Gl.End
Glu.Color(Color.Lighter(&HD96800&))
For I = 0 To $aObject.Max
Gl.PushMatrix()
Gl.Translatef($aObject[I].X, -34, $aObject[I].Z)
Gl.CallList($iDisk)
Gl.PopMatrix()
Next
Gl.Enable(Gl.TEXTURE_2D)
Gl.Color3f(1, 1, 1)
For I = 0 To $aObject.Max
N += $aObject[I].Draw()
Next
' You can use this code to get FPS printed in terminal
Inc $iFrames
If Timer >= ($fTime + 1) Then
$fFrameRate = $iFrames / (Timer - $fTime)
$iFrames = 0
Inc $fTime
Endif
lblInfo.Text = Format($aObject[0].Frame, "0.00") & " / " & $aObject[0].Model.Count & " ( " & CInt($fFramerate) & " FPS )"
Gl.PopMatrix
Inc $nDraw
Print "\r"; Format($nDraw, "#####0"); ": "; N; " vertices in "; Format(Timer - fTime, "0.000000"); " seconds";
End
Public Sub Form_KeyPress()
If Key.code = Key.F1 Then
Me.FullScreen = Not Me.FullScreen
sldFrame.Visible = Not Me.FullScreen
Else If Key.Code = Key.Esc Then
Me.Close
Else If Key.code = Key.Space Then
timAnim.Enabled = Not timAnim.Enabled
Else If LCase(Key.Text) = "w" Then
Gl.PolygonMode(Gl.FRONT_AND_BACK, Gl.LINE)
Else If LCase(Key.Text) = "f" Then
Gl.PolygonMode(Gl.FRONT_AND_BACK, Gl.FILL)
Endif
End
Public Sub timAnim_Timer()
' At every timer call we increase interpolation. It makes Frame number increase every 10 calls.
' You can control frame flow any way you want. The smaller incrementation, the smoother movement.
Dim I As Integer
For I = 0 To $aObject.Max
With $aObject[I]
.Frame += 0.1
If .Frame >= .Count Then .Frame = 0
End With
Next
Object.Lock(sldFrame)
sldFrame.Value = CInt($aObject[0].Frame)
Object.Unlock(sldFrame)
glaScreen.Refresh
End
' Just the subroutine to load textures for our models
Private Sub LoadTexture(sPath As String) As Integer
Dim iTex As Integer
Dim hImage As Image
iTex = Gl.GenTextures(1)[0]
hImage = Image.Load(sPath)
Gl.BindTexture(Gl.TEXTURE_2D, iTex)
Gl.TexImage2D(hImage)
Glu.Build2DMipmaps(hImage)
Gl.Texparameteri(Gl.TEXTURE_2D, Gl.TEXTURE_MIN_FILTER, Gl.LINEAR_MIPMAP_LINEAR)
Gl.Texparameteri(Gl.TEXTURE_2D, Gl.TEXTURE_MAG_FILTER, Gl.LINEAR)
Return iTex
End
Public Sub sldFrame_Change()
$aObject[0].Frame = sldFrame.Value
End
' Public Sub glaScreen_MouseMove()
'
' $fRotX = $fStartX + 180 * (Mouse.X - Mouse.StartX) / glaScreen.Width
' $fRotY = $fStartY + 180 * (Mouse.Y - Mouse.StartY) / glaScreen.Height
' glaScreen.Refresh
'
' End
'
' Public Sub glaScreen_MouseDown()
'
' $fStartX = $fRotX
' $fStartY = $fRotY
'
' End
' Public Sub Form_Activate()
'
' While $nDraw < 10
' glaScreen.Refresh
' Wait 1
' Wend
' Me.Close
'
' End