' Gambas class file ' no effect Public Const NoEffect As Integer = 0 Public Const Rotate As Integer = 1 Public Const FadingIn As Integer = 2 Public Const FadingOut As Integer = 3 ' do we animate the page ? Private anim As Boolean Private aEffect As Integer Private nextEffect As Integer ' do we move to previous page ? Private previous As Boolean ' keep trace of zTrans for rotate Private azTrans As Float ' fading Private aColor As Float = 0 ' texture Private textures As New Integer[] Private TextureSize As Integer Private textureShown As Integer ' the size of the shown quad Private qHeight As Float = 1 Private qWidth As Float ' the size of the shown texture Private tHeight As Float Private tWidth As Float Private tX As Float = 0 Private tY As Float = 0 ' document pdf Private hPdf As New PdfDocument Private currentPage As Integer Private quality As Integer = 1 Private initialized As Boolean = False ' camera position Private Ztrans As Float = -2.56 Private Ytrans As Float = 0.0 Private Xtrans As Float = 0.0 Private Zrot As Float = 0.0 Private Yrot As Float = 1.0 Private Xrot As Float = 0.0 Private Angle As Float = 0 Private ZoomFactor As Float = 1.0 Private GotoZoomFactor As Float = ZoomFactor ' flag values Private points As New Float[45, 45, 3] Private hold As Float Private wiggle_count As Integer Private DrawFlag As Boolean = False ' speed factor Private $eSpeed As Float ' properties Property Effect As Integer Property Read Page As Integer ' Image cache 'PRIVATE $cImageCache AS NEW Collection Public Sub _new(file As String, FrameRate As Integer) Dim width, height As Integer Dim x, y As Integer Dim i As Float hPdf.Open(file) aEffect = noEffect currentPage = 1 textureShown = 1 hPdf.Zoom = quality width = hPdf[currentPage].width height = hPdf[currentPage].height qWidth = Width / Height textureSize = getTextureSize(Max(Width, Height)) tWidth = Width / textureSize tHeight = Height / textureSize azTrans = zTrans $eSpeed = 600 / FrameRate music.Load("music.xm") For x = 0 To 44 For y = 0 To 44 Points[x, y, 0] = ((x / 5) - 4.5) Points[x, y, 1] = ((y / 5) - 4.5) Points[x, y, 2] = Sin((((x / 5) * 40) / 360) * Pi * 2) * 0.2 Next Next End Public Sub _free() Gl.DeleteTextures(textures) End Public Sub Draw() If initialized = False Then initialize() initialized = True anim = True aEffect = fadingIn nextEffect = rotate Endif If Anim Then animate() Paint() End Public Sub Resize(W As Integer, H As Integer) ' Width/Height Ratio Dim ratio As Float Dim Height As Integer Height = H ' Protect against a divide by zero If Height = 0 Then Height = 1 ratio = W / Height ' Setup our viewport Gl.Viewport(0, 0, W, H) ' change to the projection matrix AND set our viewing volume. Gl.MatrixMode(Gl.PROJECTION) Gl.LoadIdentity() ' Set our perspective Glu.Perspective(45.0, ratio, 0.1, 100.0) ' Make sure we're changing the model view and not the projection Gl.MatrixMode(Gl.MODELVIEW) GL.LoadIdentity() End Public Sub MoveNext() ' we animate the page, no moves until end ! If anim Then Return ' No more page If currentPage + 1 > hPdf.Count Then Return Inc (currentPage) If currentPage = hPdf.Count Then aEffect = fadingOut music.Play(-1) Endif previous = False anim = True End Public Sub MovePrev() ' we animate the page, no moves until end ! If anim Then Return ' No more page If currentPage = 1 Then Return If currentPage = hPdf.Count Then Return Dec (currentPage) previous = True azTrans = zTrans anim = True End Function Effect_Read() As Integer Return aEffect End Sub Effect_Write(ceffect As Integer) aEffect = ceffect End Function Page_Read() As Integer Return currentPage End '************************ private functions********************** Private Sub initialize() ' Enable texturing Gl.Enable(Gl.TEXTURE_2D) ' Enable smooth shading Gl.ShadeModel(Gl.SMOOTH) ' Set the background black Gl.ClearColor(0.0, 0.0, 0.0, 1.0) ' Depth buffer setup Gl.ClearDepth(1.0) ' Enables Depth Testing Gl.Enable(Gl.DEPTH_TEST) ' The Type OF Depth Test TO DO Gl.DepthFunc(Gl.LESS) ' Really Nice Perspective Calculations Gl.Hint(Gl.PERSPECTIVE_CORRECTION_HINT, Gl.NICEST) Gl.Disable(Gl.BLEND) textures = Gl.GenTextures(3) loadTexture(textures[textureshown], 1) If hPdf.Count > 1 Then loadTexture(textures[textureshown + 1], 2) End Private Sub Paint() Dim x As Integer Dim y As Integer Dim f_x As Float Dim f_y As Float Dim f_xb As Float Dim f_yb As Float If ZoomFactor < GotoZoomFactor Then ZoomFactor = Min(GotoZoomFactor, ZoomFactor * (1.2 ^ (1 / 4))) Else If ZoomFactor > GotoZoomFactor Then ZoomFactor = Max(GotoZoomFactor, ZoomFactor / (1.2 ^ (1 / 4))) Endif gl.Clear(gl.COLOR_BUFFER_BIT Or gl.DEPTH_BUFFER_BIT) ' Reset The View gl.LoadIdentity() If DrawFlag Then gl.Translatef(0.80, -1.9, -8.0) gl.Rotatef(180, 1.0, 0, 0) gl.BindTexture(gl.TEXTURE_2D, textures[textureShown]) gl.Begin(gl.QUADS) For x = 0 To 43 For y = 0 To 43 f_x = x / 44.0 f_y = y / 44.0 f_xb = (x + 1) / 44.0 f_yb = (y + 1) / 44.0 Gl.TexCoordf(f_x, f_y) gl.Vertexf(points[x, y, 0], points[x, y, 1], points[x, y, 2]) Gl.TexCoordf(f_x, f_yb) gl.Vertexf(points[x, y + 1, 0], points[x, y + 1, 1], points[x, y + 1, 2]) Gl.TexCoordf(f_xb, f_yb) gl.Vertexf(points[x + 1, y + 1, 0], points[x + 1, y + 1, 1], points[x + 1, y + 1, 2]) Gl.TexCoordf(f_xb, f_y) gl.Vertexf(points[x + 1, y, 0], points[x + 1, y, 1], points[x + 1, y, 2]) Next Next gl.End() If wiggle_count = 2 Then For y = 0 To 44 hold = points[0, y, 2] For x = 0 To 43 points[x, y, 2] = points[x + 1, y, 2] Next points[44, y, 2] = hold Next wiggle_count = 0 Endif Inc wiggle_count Else gl.Translatef(0, 0, Ztrans * ZoomFactor) gl.Rotatef(angle, 0, Yrot, 0) Gl.BindTexture(Gl.TEXTURE_2D, textures[textureShown]) ' Draw A Quad gl.Begin(gl.QUADS) Gl.TexCoordf(tX, tY) gl.Vertexf(-qWidth, qHeight, 0.0) Gl.TexCoordf(twidth, tY) gl.Vertexf(qWidth, qHeight, 0.0) Gl.TexCoordf(twidth, theight) gl.Vertexf(qWidth, -qHeight, 0.0) Gl.TexCoordf(tX, theight) gl.Vertexf(-qWidth, -qHeight, 0.0) gl.End() Endif End Private Function getTextureSize(size As Integer) As Integer Dim iSize As Integer Dim iCount As Integer While (size > isize) iSize = 2 ^ iCount Inc (iCount) Wend Return iSize End Private Sub loadTexture(texture As Integer, page As Integer) Dim imgPage As Image ' imgPage = $cImageCache[page] ' IF NOT imgPage THEN Debug ("loading pdf page") & " "; page imgPage = hPdf[page].Image imgPage.Resize(textureSize, textureSize) '$cImageCache[page] = imgPage 'ENDIF Gl.BindTexture(Gl.TEXTURE_2D, texture) Gl.TexImage2D(imgPage) Gl.TexParameteri(Gl.TEXTURE_2D, Gl.TEXTURE_MIN_FILTER, Gl.LINEAR) Gl.TexParameteri(Gl.TEXTURE_2D, Gl.TEXTURE_MAG_FILTER, Gl.LINEAR) End Private Sub updatePages() Dim cpage As Integer If previous = False Then cpage = textures[0] textures.Remove(0) textures.Push(cpage) If currentPage < hPdf.Count Then loadTexture(textures[2], currentPage + 1) Endif Return Endif cpage = textures[2] textures.pop() textures.Add(cpage, 0) If currentPage > 1 Then loadTexture(textures[0], currentPage - 1) Endif End Private Sub animate() If aEffect = NoEffect Then animNoEffect() If aEffect = Rotate Then animRotate() If aEffect = FadingIn Then animFadingIn() If aEffect = FadingOut Then animFadingOut() End Private Sub animNoEffect() updatePages() anim = False End Private Sub animRotate() Dim eOldAngle As Float = angle If previous = False Then angle -= 0.5 * $eSpeed If eOldAngle > -90 And If angle <= -90 Then tX = tWidth tWidth = 0 Inc (textureShown) Endif If angle < -180 Then angle = 0 anim = False tWidth = tX tX = 0 zTrans = azTrans updatePages() textureShown = 1 Endif Else angle += 0.5 * $eSpeed If eOldAngle < 90 And If angle >= 90 Then tX = tWidth tWidth = 0 Dec (textureShown) Endif If angle > 180 Then angle = 0 anim = False tWidth = tX tX = 0 zTrans = azTrans updatePages() textureShown = 1 Endif Endif zTrans = azTrans - 2 * Sin(Abs(Rad(angle))) End Private Sub animFadingIn() aColor += 0.02 * $eSpeed If aColor > 1 Then Gl.Colorf(1.0, 1.0, 1.0) aColor = 1 aEffect = nextEffect anim = False Else Gl.Colorf(aColor, aColor, aColor) Endif End Private Sub animFadingOut() aColor -= 0.01 * $eSpeed If aColor < 0 Then Gl.Colorf(0.0, 0.0, 0.0) aColor = 0 aEffect = FadingIn updatePages() DrawFlag = True Else Gl.Colorf(aColor, aColor, aColor) Endif End Public Sub ZoomIn() If GotoZoomFactor <= 0.04 Then Return GotoZoomFactor /= 1.2 End Public Sub ZoomOut() If GotoZoomFactor > 20 Then Return GotoZoomFactor *= 1.2 End