登录社区:用户名: 密码: 忘记密码 网页功能:加入收藏 设为首页 网站搜索  

文档

下载

图书

论坛

安全

源码

硬件

游戏
首页 | 信息 | 空间 | VB | VC | Delphi | Java | Flash | 补丁 | 控件 | 安全 | 黑客 | 电子书 | 笔记本 | 手机 | MP3 | 杀毒 | QQ群 | 产品库 | 分类信息 | 编程网站
  立华软件园 - Visual Basic 专区 - 技术文档 - 多媒体 技术文章 | VB源代码 | 电子图书 | VB网站 | 相关下载 | 在线论坛 | QQ群组 | 搜索   
 VB技术文档
  · 窗体界面
  · 系统控制
  · VB.Net
  · 多媒体
  · 网络编程
  · API函数
  · 游戏编程
  · 数据报表
  · 其他文档
 VB源代码
  · 窗体界面
  · 文件目录
  · 多媒体
  · 网络编程
  · 系统API
  · 数据报表
  · 游戏编程
  · VBA办公
  · 其他代码
 VB论坛
  · Visual Basic 讨论区
  · VB.Net 讨论区
  · VB数据库开发讨论区
  · VB系统API讨论区
 其他VB资源
  · VB下载资源
  · VB电子图书
  · VB QQ群组讨论区
  · VB 其他网站资源




在Visual Basic 6.0中实现自动播放VCD
发表日期:2005-06-08作者:[转贴] 出处:  

作者:陈沛


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

 

我来说两句】 【发送给朋友】 【加入收藏】 【返加顶部】 【打印本页】 【关闭窗口
中搜索 在Visual Basic 6.0中实现自动播放VCD

 ■ [欢迎对本文发表评论]
用  户:  匿名发出:
您要为您所发的言论的后果负责,故请各位遵纪守法并注意语言文明。

关于我们 / 合作推广 / 给我留言 / 版权举报 / 意见建议 / 广告投放 / 友情链接  
Copyright ©2001-2006 Lihuasoft.net webmaster(at)lihuasoft.net
网站编程QQ群   京ICP备05001064号 页面生成时间:0.00202