主题:菜鸟请教:能不能把做好的VB程序加上背景音乐呀?
大懒猫
[专家分:220] 发布于 2008-12-07 09:31:00
能不能把做好的VB程序加上背景音乐呀?比如:手上现有《铃儿响钉铛》的歌曲
回复列表 (共19个回复)
沙发
一江秋水 [专家分:9680] 发布于 2008-12-07 11:27:00
当然可以,用API函数mciSendString
板凳
大懒猫 [专家分:220] 发布于 2008-12-07 18:42:00
[quote]当然可以,用API函数mciSendString[/quote]
能不能具体一点儿呀?另外可以用嵌入吗?
3 楼
一江秋水 [专家分:9680] 发布于 2008-12-09 17:06:00
mciSendString的使用
Declare Function mciSendString Lib "winmm.dll" Alias "mciSendStringA" _
(ByVal lpstrCommand As String, ByVal lpstrReturnString As String, _
ByVal uReturnLength As Long, ByVal hwndCallback As Long) As Long
mciSendString是用来播放多媒体文件的API指令,可以播放MPEG,AVI,WAV,MP3,等等,下面介绍一
下它的使用方法:
该函数有四个参数:
第一个参数:要发送的命令字符串。字符串结构是:[命令][设备别名][命令参数].
第二个参数:返回信息的缓冲区,为一指定了大小的字符串变量.
第三个参数:缓冲区的大小,就是字符变量的长度.
第四个参数:回调方式,一般设为零
返回值:函数执行成功返回零,否则返回错误代码
一、常用命令
1.打开(Open),格式:Open 设备名 [type 设备型式][alias 别名]
Dim mName as string
mName = "f:\\mpeg\\mpeg1.avi"
mciSendString "open mName type MPEGVideo Alias movie parent %u Style %u notify",0&, 0, 0
其中:
open 操作命令
mName 全路径文件名
type MPEGVideo 是指打开MPEG,AVI等类型,如果不加这一句,就是打开WAV,MP3等
Alias movie 定义了该操作的别名为movie,后续操作只要指明别名即可
parent %u 源
Style %u 风格、样式
notify 通知
2.播放(Play),格式:Play 设备名 [from 起点][to 终点]
mciSendString "play movie", 0&, 0, 0
mciSendString "play movie fullscreen", 0&, 0, 0 '全屏播放
3.暂停(Pause):
mciSendString "pause movie", 0&, 0, 0
4.继续(Resume):
mciSendString "resume movie", 0&, 0, 0
5.停止(Stop):
mciSendString "stop movie", 0&, 0, 0
6.关闭(Colse):
mciSendString "close movie", 0&, 0, 0
7.前进到下一个位置:
mciSendString "step movie", 0&, 0, 0
8.后退到上一个位置:
mciSendString "step movie reverse", 0&, 0, 0
9.前进或后退 N 個位置(其中 N<0 即表示后退)
mciSendString "step movie by " & str(N), 0&, 0, 0
10.获取当前播放位置:
Dim ST As String*64
mciSendString "status movie position", st, len(st), 0
11. 获取媒体的总长度:
mciSendString "status movie length", st, len(st), 0
l=val(st) 'L就是所播放文件的长度
12.获取播放信息:
Dim ST As String*64
mciSendString "status movie mode", ST, Len(ST), 0
If Left(ST, 7) = "stopped" Then (处理代码) '播放完毕
13.循环播放:
mciSendString "play movie repeat", 0&, 0, 0
二、控制声音大小:
Dim V As Long
mciSendString "status movie volume", V, 0, 0 'V是获取的音量大小值。
V = 50
mciSendString "setaudio movie volume to " & V, &0, 0, 0 'V是设置的音量值
三、设置播放位置.(需事先设定时间格式),格式:Seek 设备名 [to 位置 | to start | to end]
Dim P1 as Long, P2 as Long
P1 = 100: P2 = 3000
mciSendString "seek movie to ", P1, 0, 0 'P1是当前起始位置,单位:毫秒
mciSendString "seek movie to start", 0&, 0, 0 '定位到开头位置
mciSendString "play movie", 0&, 0, 0 '定位后再播放
或者:
mciSendString "play movie FROM P1 to P2",0&, 0, 0 'P1是起始位置,P2是停止位置。单位:毫秒
mciSendString "seek movie to end", 0&, 0, 0 '定位到最后位置
四、在指定控件上播放视频:
mciSendString "open AVI 文件名 parent hWnd style child", 0&, 0, 0
其中,hWnd 是控件的句柄
执行上述命令之后,影片会被放置在控件的左上角,且影片的大小不受控件大小的影响,如果想要改变
影片播放的位置及大小,可以在執行 play 指令前先执行 put 指令,格式如下:
mciendString "put AVI 文件名 window at X Y [Width Height]", 0&, 0, 0
其中:X、Y为影片左上角坐标,Width、Height为影片的宽高度
五、如果播放视频还可控制亮度
Dim B As Long
mciSendString "status movie brightness", B, 0, 0 'B是获取的亮度值。
B = 50
mciSendString "setvideo movie brightness to " & B, &0, 0, 0 'B是设置的亮度值
六、录音设置:
录音前,用以下语句初始化
1.设为8位:
mciSendString "set wave bitpersample 8", "", 0, 0
2.设为11025Hz
mciSendString "set wave samplespersec 11025", "", 0, 0
3.设为立体声:
mciSendString "set wave channels 2", "", 0, 0
4.实现PCM格式(不一定正确):
MCISENDSTRING "set wave format tag pcm","", 0, 0
5.开始录音:
mciSendString "close movie",0&,0,0
mciSendString "open new type WAVEAudio alias movie",0&,0,0
mciSendString "record movie",0&,0,0
6.保存录音到c:\123.wav
mciSendString "stop movie",0&,0,0
mciSendString "save movie C:\\123.wav",0&,0,0
mciSendString "close movie",0&,0,0
4 楼
一江秋水 [专家分:9680] 发布于 2008-12-09 17:07:00
七、开关光驱:
mciSendString "set cdaudio door open", "", 0, 0 '打开
mciSendString "set cdaudio door close", "", 0, 0 '关闭
八、其它
1.设置设备的各种状态(Set)
Set alias_name[audio all off][audio all on][time format ms]:
Set命令用来设置设备的各种状态.如:静音,有声音,时间格式为毫秒等.
2.取得设备的状态(Status)
Status alias_name[length][mode][position]:
Status命令用来取得设备的状态.如:该媒体文件的长度,该媒体文件所处状态,该媒体文件的当前位置等.
由于篇幅有限这里就不再说更多的命令集了.有兴趣的朋友可到我的网址详细的查询.
程式范例:
一、播放mp3、wav、mid等音乐
Private Declare Function mciSendString Lib "winmm.dll" Alias "mciSendStringA" _
(ByVal lpstrCommand As String, ByVal lpstrReturnString As String, _
ByVal uReturnLength As Long, ByVal hwndCallback As Long) As Long
Private Sub Form_Load()
Dim musicName As String
musicName = "(全路径音乐文件名)" '注意:路径和文件名决不能有空格
mciSendString "open " & musicName & " alias mymusic", 0&, 0, 0
End Sub
Private Sub Command1_Click() '开始播放
mciSendString "play mymusic", "", 0, 0
End Sub
Private Sub Command2_Click() '暂停
mciSendString "pause mymusic", "", 0, 0
End Sub
Private Sub Command3_Click() '继续
mciSendString "resume mymusic", 0&, 0, 0
End Sub
Private Sub Command4_Click() '停止
mciSendString "stop mymusic", 0&, 0, 0
End Sub
Private Sub Command5_Click() '关闭
mciSendString "close mymusic", 0&, 0, 0
End Sub
二、播放其它
Sub PlaySound(filename)
Dim cmd As String
Call mciSendString("close MyWav", 0, 0, 0) ' MyWav 这个名称可依需要来修改
cmd = "open " & filename & " type WAVEAudio alias MyWav"
'去掉 上面中的 type WAVEAudio, 则该副程式便可用来播放 midi 音乐档。
Call mciSendString(cmd, 0, 0, 0)
Call mciSendString("play MyWav", 0, 0, 0)
End Sub
' 假设要拨放 "c:\windows\Tada.wav"
PlaySound "c:\windows\Tada.wav"
播放 .flc 动画档案的方法与 .wav 及 .midi 并没有什麽不同,最後完成的程式大致如下:
Sub PlaySound(filename)
Dim cmd As String
Call mciSendString("close MyFlc", 0, 0, 0) ' MyFlc 这个名称可依需要来修改
cmd = "open " & filename & " alias MyFlc"
Call mciSendString(cmd, 0, 0, 0)
Call mciSendString("play MyFlc", 0, 0, 0)
End Sub
注:有些机器可能会因为没有安装 .flc 的驱动程式而无法播放,欲检查机器中是否安装有
播放 .flc 的驱动程式, 可先利用 Windows 提供的媒体播放程式播放 .flc 档案看看。
假设我们想将 .flc 放在 Picture1 之中播放, 则必须将 open MCI 指令由原先的:
"open " & filename & " alias MyFlc" 改成:
"open " & filename & " alias MyFlc parent " & Picture1.hWnd & " style " & WS_CHILD
则 .flc 就会在 Picture1 之中播放。
注:WS_CHILD = &H40000000
十、有关播放CD的格式:
´设定时间格式为 Tracks(磁轨), 单位是:毫秒
lRet = mciSendString("set cd time format tmsf", 0&, 0, 0)
´从头开始播放
lRet = mciSendString("play cd", 0&, 0, 0)
´也可以指定从第几首歌 (Track) 开始播放,例如以下指定从第 3 首歌开始播放
´nCurrentTrack = 3
lRet = mciSendString("play cd from" & Str(nCurrentTrack), 0&, 0, 0)
5 楼
javake [专家分:910] 发布于 2008-12-09 18:00:00
那要看原来的程序是不是你做的!
6 楼
大懒猫 [专家分:220] 发布于 2008-12-10 15:12:00
天呀,我就是做了个简单程序,想在上面加个背景音乐(如:铃儿响叮铛.mp3),犯得着这么复杂吗?太难呐,还是不懂![em8]
7 楼
一江秋水 [专家分:9680] 发布于 2008-12-11 17:31:00
呵呵,真是只大懒猫,要学到一点东西,必须多作实验!
Private Sub Form_Load()
mciSendString "open D:\铃儿响钉铛.mp3 alias myMusic", 0&, 0, 0
mciSendString "play myMusic FROM 0", 0&, 0, 0
End Sub
Private Sub Form_Unload(Cancel As Integer)
mciSendString "close myMusic", 0&, 0, 0
End Sub
如果你的歌曲不是MP3,或者路径不对,可能就要稍微改动一下,根据我提供的资料自己想一下就知道了。
8 楼
bcahzvip [专家分:6040] 发布于 2008-12-14 16:33:00
E:\Program Files\vb6mini\Template\Classes\声音播放.cls
9 楼
大懒猫 [专家分:220] 发布于 2008-12-16 08:27:00
[quote]呵呵,真是只大懒猫,要学到一点东西,必须多作实验!
Private Sub Form_Load()
mciSendString "open D:\铃儿响钉铛.mp3 alias myMusic", 0&, 0, 0
mciSendString "play myMusic FROM 0", 0&, 0, 0
End Sub
Private Sub Form_Unload(Cancel As Integer)
mciSendString "close myMusic", 0&, 0, 0
End Sub
如果你的歌曲不是MP3,或者路径不对,可能就要稍微改动一下,根据我提供的资料自己想一下就知道了。[/quote]
先谢谢一江秋水GG,然后放声大哭~~~我试了一下,可系统出错,提示没有这个函数!我用的是精简版,是不是和这有关呀?
[em21]
10 楼
天天学习 [专家分:4570] 发布于 2008-12-16 08:42:00
额的个神啊~~~
估计楼主还不知道有API这么一回事?
在代码里添加函数声明:
Declare Function mciSendString Lib "winmm.dll" Alias "mciSendStringA" _
(ByVal lpstrCommand As String, ByVal lpstrReturnString As String, _
ByVal uReturnLength As Long, ByVal hwndCallback As Long) As Long
我来回复