140 lines
2.6 KiB
Plaintext
140 lines
2.6 KiB
Plaintext
' Gambas class file
|
|
|
|
' Simple CDplayer
|
|
' Carlier Laurent - (c) 2005
|
|
' Under GNU GPL V2 or Later
|
|
'
|
|
' Done for Testing the sdl component
|
|
' CDROM part
|
|
|
|
Static mycd As CDRom
|
|
Static HaveCD As Boolean
|
|
|
|
Public Sub Form_open()
|
|
If CDRoms.Count > 0 Then
|
|
Try mycd = New CDRom
|
|
If Not IsNull(mycd) Then
|
|
Volume.Value = Abs(mycd.Volume - Volume.MaxValue)
|
|
TrackPos.Value = 0
|
|
Me.Center
|
|
Timer1.Enabled = True
|
|
Else
|
|
Message.Warning(("I Could not load cd-rom drive"))
|
|
Me.Close
|
|
Endif
|
|
Else
|
|
Message.Warning(("Your PC does not have cd-rom drive"))
|
|
Me.Close
|
|
Endif
|
|
|
|
End
|
|
|
|
Public Sub SButton_Click()
|
|
|
|
mycd.Stop()
|
|
PButton.Text = ("&Play")
|
|
TrackPos.Value = 0
|
|
|
|
End
|
|
|
|
Public Sub PTButton_Click()
|
|
|
|
If Not HaveCD Then
|
|
Return
|
|
Endif
|
|
|
|
mycd.Tracks[TrackInfo.Index + 1].Play()
|
|
|
|
End
|
|
|
|
Public Sub Timer1_Timer()
|
|
|
|
Dim trckloop As Integer
|
|
Dim string1 As String
|
|
Dim string2 As String
|
|
|
|
If Not mycd.Ready Then
|
|
TrackInfo.Clear()
|
|
TextBox1.Text = ("No CD in Drive")
|
|
HaveCD = False
|
|
Return
|
|
Endif
|
|
|
|
If mycd.Stopped Then
|
|
string1 = mycd.Tracks.Count & " " & ("Tracks")
|
|
string2 = ("Total Length :") & " " & ToTime(mycd.Length)
|
|
TextBox1.Text = string1 & Space$(41 - (Len(string1) + Len(string2))) & string2
|
|
TrackPos.Value = 0
|
|
Endif
|
|
|
|
If mycd.Playing Or mycd.Paused Then
|
|
TrackPos.Value = (mycd.Tracks[mycd.Tracks.Current].Position) / mycd.Tracks[mycd.Tracks.Current].length
|
|
TextBox1.Text = ("Playing Track") & " " & mycd.Tracks.Current
|
|
Endif
|
|
|
|
If HaveCD Then
|
|
Return
|
|
Endif
|
|
|
|
TrackInfo.Clear()
|
|
For trckloop = 1 To mycd.Tracks.Count
|
|
string1 = ("Track") & " " & trckloop
|
|
string2 = "<" & ToTime(mycd.Tracks[trckloop].Length) & ">"
|
|
TrackInfo.Add(string1 & Space$(49 - (Len(string1) + Len(string2))) & string2)
|
|
Next
|
|
|
|
Volume.Value = Abs(mycd.Volume - 255)
|
|
HaveCD = True
|
|
|
|
End
|
|
|
|
Public Function ToTime(length As Integer) As String
|
|
|
|
Dim myString As String
|
|
|
|
mystring = Format$(length \ 60, "00") & ":" & Format$((length Mod 60), "00")
|
|
Return myString
|
|
|
|
End
|
|
|
|
Public Sub Volume_Change()
|
|
|
|
mycd.Volume = Abs(Volume.Value - Volume.MaxValue)
|
|
|
|
End
|
|
|
|
Public Sub PButton_Click()
|
|
|
|
If Not HaveCD Then
|
|
PButton.Text = ("&Play")
|
|
Return
|
|
Endif
|
|
|
|
If mycd.Stopped Then
|
|
mycd.Play()
|
|
PButton.Text = ("&Pause")
|
|
Return
|
|
Endif
|
|
|
|
If mycd.Playing Then
|
|
mycd.Pause()
|
|
PButton.Text = ("&Resume")
|
|
Return
|
|
Endif
|
|
|
|
If mycd.Paused Then
|
|
mycd.Resume()
|
|
PButton.Text = ("&Pause")
|
|
Endif
|
|
|
|
End
|
|
|
|
Public Sub EButton_Click()
|
|
|
|
Try mycd.Eject
|
|
HaveCD = False
|
|
PButton.Text = ("&Play")
|
|
TrackPos.Value = 0
|
|
|
|
End
|