庞大资源库的计算机教程网站!
设为首页
加入收藏
总编信箱
投稿或申请专栏请先 [登 陆]
首页 操作系统 程序设计 图形图像 媒体动画 机械电子 WEB开发 数 据 库 办公系列 路由技术 网络原理 网络应用
认证考试 安全技术
首页>程序设计>VB专区>控件集锦>正文
资料搜索
Google搜索
Google
返回上级列表

推荐文章

快速保存网页中所有图片的方法
Windows中让光驱巧妙“隐身”技
防范非法用户入侵Win 2000/XP系
两款比较典型的ASP木马防范方法
有关表格边框的css语法整理
Windows XP中可以被禁用的服务
SQL Server导出导入数据方法
Javascript所有对象的属性的获
网页(HTML)中的特殊字符
与篮球共舞,尽显模式本色
QQ病毒的手工清除方法
Photoshop为极品美女打造性感睫
天衣无缝:IIS与PHP水火也相容
SQL Server存储过程编写和优化

用MMControl控件播放M3U文件的实现

 作者:土人    日期:2005-8-4 11:23:35
字号选择〖 〗/ 双击滚屏 单击停止   
在以前,VB程序员大都以为MMControl控件在应付媒体文件方面不是很争气,笔者甚至在一些颇有权威的书籍上看到在探讨完这个控件之后建议读者:如欲编制一个能播放MP3文件的播放器,请去找相关控件。其实,这是对MMControl的误解。MMControl作为能对系统硬件进行操作和控制的控件,其功能是强大的,它对付MP3也不在话下!不信?我以前也不信——专家都这么以为嘛。可现在我信了:我在VB6.0、PWin98下试验成功!播放质量?呵呵,比Mediaplayer好不了多少。Bill的东西嘛,让人又爱又无奈……
遗憾的是,MMCtrol控件不支持M3U列表文件。这得处理一下。谁叫M3u那么方便呢?
我们知道,M3U其实是和TXT文件性质一样的东西,都是文本文件。M3U文件所存储的内容是一系列的媒体文件所在的二进制地址,如将M3U文件打开并把各个媒体文件所在位置的标志存入数组,就可以叫MMControl一一地播放了。考虑到资源的占用问题,笔者以下的实例将M3U文件的内容打开后添加到列表框,然后让MMControl进行处理,有兴趣的朋友可以试一下数组。
本例需要:按钮若干;列表框一个;Timer一个;ProgressBar(进度条)一个;老M当然不能少了。
详细代码如下:

Option Explicit

Dim MaxVal As Long '进度条Max值变量
Dim MyInd As Integer '播讲的文件索引变量
Dim sF As String '要播放的M3U文件

Private Sub cmdNext_Click() '“下一首”按钮代码
PlayNext
List1.SetFocus '让按钮好看点,下同
End Sub

Private Sub cmdPause_Click() '“暂停”按钮代码
MMControl1.Command = "Pause"
List1.SetFocus
End Sub

Private Sub cmdPlay_Click() '“播放”按钮代码
List1.SetFocus
If MMControl1.Command = "Stop" Or MMControl1.Command = "Pause" Then
MMControl1.Command = "Play"
Else
Call PlayMe '交给PlayMe处理
End If
End Sub

Private Sub cmdExit_Click() '“退出”按钮代码
MMControl1.Command = "close" '关闭以释放资源
End
End Sub

Private Sub cmdPre_Click() '“前一首”按钮代码
Timer1.Enabled = False
List1.SetFocus
If MyInd = 0 Then '当前是第一首则播放最后一首
List1.ListIndex = List1.ListCount - 1
Else '否则播放前一首
List1.ListIndex = MyInd - 1
End If
MyInd = List1.ListIndex '这个变量要记得改哟
Call PlayMe
End Sub

Private Sub Form_Load() '程序加载
Timer1.Enabled = False
Timer1.Interval = 1000
List1.BackColor = vbBlack
List1.ForeColor = vbYellow
MMControl1.Visible = False
MyInd = 0
cmdOpen.Value = True '“打开”按钮被按下
'OpenM3u '打开M3U文件
'PlayMe '播放
End Sub

Private Sub cmdOpen_Click() '“打开”按钮代码
On Error GoTo openerr:
List1.Clear
CommonDialog1.Filter = "(*.m3u)|*.m3u" '这个不用说了吧
CommonDialog1.ShowOpen
sF = CommonDialog1.FileName
OpenM3u '打开M3U文件
Exit Sub
openerr:
Timer1.Enabled = False '出错则不能让计时器工作
'出错信息自己写吧
End Sub

'当点击右上角的“×”按钮时
Private Sub Form_Unload(Cancel As Integer)
MMControl1.Command = "Close" '关闭设备以释放资源
End Sub

Private Sub List1_dblClick() '双击列表框事件
MyInd = List1.ListIndex
cmdPlay.Value = True
End Sub

'判断是否要播放下一首
Private Sub MMControl1_StatusUpdate()
If MMControl1.Position = MMControl1.Length Then
PlayNext
End If
End Sub

Private Sub PlayMe() '播放媒体文件
With MMControl1 '以下语句是不是有点罗嗦?
.FileName = List1.List(MyInd)
.Command = "stop"
.Command = "close"
.Command = "Open"
.Command = "play"
End With
MaxVal = MMControl1.Length
Timer1.Enabled = True
Me.Caption = List1.List(MyInd) '显示正在播放的文件名称
ProgressBar1.ToolTipText = "播放总数:" & List1.ListCount & "首"
''显示播放文件总数
End Sub

Private Sub Timer1_Timer()
'进度条的Max和Value值
ProgressBar1.Max = MaxVal
ProgressBar1.Value = MMControl1.Position
End Sub

Private Sub PlayNext() '播放下一首
Timer1.Enabled = False
ProgressBar1.Value = 0
MyInd = MyInd + 1 '当然加1了
If MyInd >= List1.ListCount Then MyInd = 0
Call PlayMe '呵呵,偷懒一下吧
List1.ListIndex = MyInd
End Sub

Private Sub OpenM3u() '打开M3U文件并存入内存
On Error GoTo M3uErr
Dim AllLines As New Collection '内存中集全
Dim CurrentLine As Long '当前行集合索引
Dim nextLine As String '从文件中读出的每一行
Dim InFile As Integer '文件的描述符
InFile = FreeFile
Open sF For Input As InFile '打开文件
While Not EOF(InFile)
Line Input #InFile, nextLine
AllLines.Add nextLine
Wend
Close InFile
Dim i As Integer
'以下为提取各行
For i = 0 To AllLines.Count - 1
CurrentLine = CurrentLine + 1
If AllLines.Count < CurrentLine Then
CurrentLine = 1
End If
If AllLines.Count > 0 Then '当然要加入列表框啦
List1.AddItem AllLines.Item(CurrentLine)
End If
Next i
MMControl1.FileName = List1.List(0) '老M终于有文件要处理了
List1.ListIndex = 0
' 列表框第一项高亮——老M就是靠它来判断下一首是什么
Exit Sub
M3uErr:
'......我累了
End Sub

最后想提醒一下:由于MMControl控件直接对MCI发出各种指令,在编程时需要格外谨慎,否则……去尝试一下吧!
上一篇:一劳永逸让VB自动改变控件大小    下一篇:用MediaPlayer控件做一个完全属于自己的MP3播放器  
[发送给好友]  [关闭窗口]  [返回顶部]   转载请注明来源:www.it00.com   
特别声明: 本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
责任编辑: 原点 投稿作者: 土人
信息来源: 网络 录入时间: 2005-8-4 11:23:35
关于我们 - 广告服务 - 版权申明 - 网站地图 - 联系方式 - 总编信箱 - 会员投稿