会员: 密码:  免费注册 | 忘记密码 | 会员登录 网页功能: 加入收藏 设为首页 网站搜索  
技术文档 > VB文档 > 多媒体
在Visual Basic 6.0中实现自动播放VCD
发表日期:2005-06-08 23:53:15作者: 出处:  

作者:陈沛


《超级解霸》等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上通过。

 

返回顶部】 【打印本页】 【关闭窗口

关于我们 / 给我留言 / 版权举报 / 意见建议 / 网站编程QQ群   
Copyright ©2003- 2024 Lihuasoft.net webmaster(at)lihuasoft.net 加载时间 0.00406