作者:陈沛
《超级解霸》等VCD播放软件一般都有个按钮或菜单选项,叫做“播放VCD”, 单击即可自动播放VCD影片。如果文件路径是固定的, 那只用多媒体控件( mmcontrol) 即可实现,但对于不同电脑来说,因为硬盘的逻辑分区数量不同,光盘机的路径很 可能是不同的。它到底是怎样实现的呢?下面,请看我详细分析:
用“regedit.exe”查看Windows98的注册表中光盘机的属性项( hkey_local_machine, enum, scsi),比较硬盘机的属性项(hkey_local_machine, enum, esdi)和软盘 机 的属性项(hkey_local_machine, enum, flop),就可发现:不同的盘体,是用 “devicetype”这个参数来区别的,硬盘的devicetype是“0”, 软盘是“0a”, 光盘机是“5”。再用“devicetype”为关键字,查找有关win32 API的编程手册, 就可得到辨别不同盘体的函数“getdevicetype”了。
有了这个函数,使用以下句子,即可得到光盘机盘符:
If GetDriveType(\"d:\") <> 5 Then If GetDriveType(\"e:\") <> 5 Then If GetDriveType(\"f:\") <> 5 Then If GetDriveType(\"g:\") <> 5 Then drivecd = \"H\" GoTo getcdfiles End If drivecd = \"G\" GoTo getcdfiles End If drivecd = \"F\" GoTo getcdfiles End If drivecd = \"E\" GoTo getcdfiles Else drivecd = \"D\" End If getcdfiles:
程序使用穷举法,依次判断D、E、F、G盘的devicetype是否为“5”,都不是 则光盘机 为H(盘符超过H的机器不多,所以穷举到此为止),得到的“drivecd”就是光盘机 盘符。
因为所有VCD影片的路径都是mpegav,所以用VB函数\"Dir()\"便可得到完整的 播放路径: MMControl1.FileName = drivecd & \":Mpegav\" & Dir(drivecd & \":Mpegav*. dat\")。
以下源程序,具体实现了自动播放VCD。程序窗体中只有一个多媒体控件—— MMcontrol1, 程序一旦运行即从第一个文件开始自动播放,按多媒体控件上的“next”键,播放 下一个文件。
\'声明GetDriveType函数 Private Declare Function GetDriveType Lib \"kernel32\" Alias \" GetDriveTypeA\" _ (ByVal nDrive As String) As Long Dim files() As String Dim drivecd As String Dim i As Integer Dim j As Integer
Private Sub Form_Load() \'判断光盘机盘符 If GetDriveType(\"d:\") <> 5 Then If GetDriveType(\"e:\") <> 5 Then If GetDriveType(\"f:\") <> 5 Then If GetDriveType(\"g:\") <> 5 Then drivecd = \"H\" GoTo getcdfiles End If drivecd = \"G\" GoTo getcdfiles End If drivecd = \"F\" GoTo getcdfiles End If drivecd = \"E\" GoTo getcdfiles Else drivecd = \"D\" End If
\'将所有VCD文件放入数组files() getcdfiles: On Error GoTo cderr: s = Dir(drivecd & \":Mpegav*.dat\") i = 1 While s <> \"\" ReDim Preserve files(i) As String files(i) = s i = i + 1 s = Dir() Wend j = 1 Call vcdplay
On Error GoTo 0 Exit Sub cderr: MsgBox \"CD is not ready!\" Unload Me End Sub
\'判断是否播放下一个文件 Private Sub MMControl1_StatusUpdate() If MMControl1.Position = MMControl1.Length Then j = j + 1 If j > i - 1 Then j = 1 Call vcdplay End If End Sub
\'播放VCD文件 Private Sub vcdplay() MMControl1.Command = \"stop\" MMControl1.Command = \"close\" MMControl1.FileName = drivecd & \":Mpegav\" & files(j) MMControl1.Command = \"open\" MMControl1.Command = \"play\" End Sub
以上程序在中文Windows98,Visual Basic 6.0上通过。
|