我感觉声音的播放比较简单。我们从播放声音开始。为什么我这么觉得?我也不知道。
这里是展示最简单的directx播放声音的例子,我尽量省略了无关的代码。最后的代码只有19行,够简单了吧?
准备工作:
1.安装了directx sdk(有9个dll文件)。这里我们只用到microsoft.directx.dll 和 microsoft.directx.directsound.dll
2.一个wav文件。(这样的文件比较好找,在qq的目录里就不少啊。这里就不多说了。)名字叫snd.wav,放在最后目标程序的同个目录下面
开始写程序啦。随便用个ultraedit就好了。
1.引入directx 的dll文件的名字空间:
using microsoft.directx;
using microsoft.directx.directsound;
2.建立设备。在我们导入的microsoft.directx.directsound空间中,有个device的类。这个是表示系统中的声音设备。
device dv=new device();
3.设置cooperativelevel。因为windows是多任务的系统,设备不是独占的,所以在使用设备前要为这个设备设置cooperativelevel。调用device的setcooperativelevel方法:其中,第一个参数是一个control,第二个参数是个枚举类型。
在这个程序中,control我随便弄了个参数塞进去(很汗吧!)。如果在windows程序中,可以用this代替。第二个参数就是优先级别,这里表示优先播放。
dv.setcooperativelevel((new uf()),cooperativelevel.priority);
4.开辟缓冲区。对于上面的声音设备,他有个自己的缓冲区,叫主缓冲区。系统中,一个设备有唯一的主缓冲区。由于windows是多任务(又是这个!),所以可以有几个程序同时利用一个设备播放声音,所以每个程序都自己开辟一个二级缓冲区,放自己的声音。
系统根据各个程序的优先级别,按照相应的顺序分别去各个二级缓冲区中读取内容到主缓冲区中播放。这里,我们为snd.wav开辟一个缓冲区。
其中,第一个参数表示文件名(傻瓜都看出来了!),第二个就是需要使用的设备。
secondarybuffer buf=new secondarybuffer(@"snd.wav",dv);
5.接下来就可以播放啦。第一个参数表示优先级别,0是最低的。第2个参数是播放方式,这里是循环播放。
buf.play(0,bufferplayflags.looping);
6.由于命令行程序没有消息循环,执行完代码就退出了,所以,我们需要暂停程序。
console.read();
7.关键的部分已经完了,这里只是交代一下刚才的那个倒霉的new uf() 是什么东西。这个完全是为了应付setcooperativelevel的参数要求。我不知道这样做有什么附作用(各位如果因此把声卡烧了…………)
class uf:form{}
8.代码写完啦~~~。下面可以编译了,这里编译比较复杂点。
csc /r:directx/microsoft.directx.dll;directx/microsoft.directx.directsound.dll dxsnd.cs
这里,我把2个dll文件放在当前目录的directx目录下(这个是我自己建的,你只需要指出这2个文件的位置就可以了。)
顺便把我的目录结构说明一下:
|
|--dxsnd.cs
|--snd.wav
|--<directx>
|
|--microsoft.directx.dll
|--microsoft.directx.dll
下面是完整代码:
//dxsnd.cs
using system;
using microsoft.directx;
using microsoft.directx.directsound;
using system.windows.forms;
namespace test1
{
class test
{
public static void main(string [] args)
{
device dv=new device();
dv.setcooperativelevel((new uf()),cooperativelevel.priority);
secondarybuffer buf=new secondarybuffer(@"snd.wav",dv);
buf.play(0,bufferplayflags.looping);
console.readline();
}
class uf:form{}
}
}