关键词搜索

源码搜索 ×
×

VB.NET实现DirectSound9 (7) 录音

发布2020-12-14浏览529次

详情内容

关键字: VB.NET DirectX 9 DirectSound 录音 riff文件格式 作者:董含君

下午看了微软提供的例子,居然把录音定位成Beginner级别
晕哦,虽说我认为这个例子是微软提供的最”直接”的例子,但是步骤超多.而且还牵扯到多线程开辟缓冲区回调riff文件格式 IO 输出等等.由于录音的复杂性,以及微软这个例子的直接性,坚持原创的我最终还是复制了大量vb.net教程
java基础的代码.(希望不要骂我…)

OK,先来说录音的步骤,里面牵扯到riff或者使用技巧的地方,有注释.我仅仅说步骤.附带截图一张

程序运行截图

首先需要说明与往常不同的概念

1 声卡(或者windows)把音频设备分成2个部分,一个是录音设备(Capture),另一个是回放设备(PlayBack)

2 前面我们用的是Device创建回放设备,这次需要使用Capture创建录音设备,录音设备不像回放,设备的能力往往很关键(回放虽说也很关键,但是设备能力基本上差别不大),所以不能单单使用一个默认就行,需要用户指定,甚至用枚举的办法逐个测试性能(看看是否支持这种格式)

3 利用 Dim CapList As New CaptureDevicesCollection
得到list之后
Dim info As DeviceInformation
‘’‘先得到可以使用的信息
‘’’ 设备信息由这个集合提供

For Each info In CapList
    ListBox1.Items.Add(info.Description)
Next

    枚举出所有设备

    4 创建Capture的时候,需要指定使用那个设备了,(回放的时候也可以指定,但是我们用的是默认的)
    '利用选择的设备
    Cap = New Capture(CapList(ListBox1.SelectedIndex).DriverGuid)

    5 尝试所有支持的类型
    就是一个for 循环里面嵌套下面的try语句
    try
    Cap=new capture(…)
    catch
    ‘’’’'失败的时候继续尝试下一个
    end try

    6 完成设备的准备工作之后,DirectSound初始化完成

    7 录音,
    第一步创建riff(理解成riff即可)
    第二步创建录音用的缓冲区(包括文件缓冲区以及CaptureBuffer)
    第三步创建新的线程用于捕获数据

    8 停止
    停止capture
    讲缓冲区内容写入磁盘
    修改riff的文件信息
    释放资源

    9 播放,利用最简单的办法播放文件

    大体步骤就这些,录音的时候函数之间的关系比较复杂.但是没有更简单的办法.

    注释比较详细,关于riff的文件操作方法内部也有注释.或者直接复制到你的程序直接用也行.

    以下是源代码

    Imports Microsoft.DirectX.DirectSound
    
    Imports System.IO
    
    Imports System.Threading
    
     
    
    Public Class Form1
    
        Inherits System.Windows.Forms.Form
    
     
    
        Private Structure FormatInfo
    
            Public format As WaveFormat
    
     
    
            Public Overrides Function ToString() As String
    
                Return ConvertWaveFormatToString(format)
    
            End Function 'ToString
    
        End Structure 'FormatInfo
    
     
    
        Dim DevPlay As New Device
    
        Dim BufPlay As SecondaryBuffer
    
     
    
        Dim Formats As New ArrayList
    
        Dim Cap As Capture
    
        Dim CapList As New CaptureDevicesCollection
    
        Private InputFormatSupported(19) As Boolean
    
        Public InputFormat As WaveFormat
    
        Private WaveFile As FileStream = Nothing
    
        Private Writer As BinaryWriter = Nothing
    
        Public applicationNotify As Notify = Nothing
    
        Public applicationBuffer As CaptureBuffer = Nothing
    
        Public NotifySize As Integer = 0
    
        Private NotifyThread As Thread = Nothing
    
        Public NotificationEvent As AutoResetEvent = Nothing
    
        Public PositionNotify(NumberRecordNotifications) As BufferPositionNotify
    
        Public Const NumberRecordNotifications As Integer = 16
    
        Public CaptureBufferSize As Integer = 0
    
        Public NextCaptureOffset As Integer = 0
    
        Private SampleCount As Integer = 0
    
     
    
     
    
    #Region " Windows 窗体设计器生成的代码 "
    
     
    
        Public Sub New()
    
            MyBase.New()
    
     
    
            '该调用是 Windows 窗体设计器所必需的。
    
            InitializeComponent()
    
     
    
            '在 InitializeComponent() 调用之后添加任何初始化
    
     
    
        End Sub
    
     
    
        '窗体重写 dispose 以清理组件列表。
    
        Protected Overloads Overrides Sub Dispose(ByVal disposing As Boolean)
    
            If disposing Then
    
                If Not (components Is Nothing) Then
    
                    components.Dispose()
    
                End If
    
            End If
    
            MyBase.Dispose(disposing)
    
        End Sub
    
     
    
        'Windows 窗体设计器所必需的
    
        Private components As System.ComponentModel.IContainer
    
     
    
        '注意: 以下过程是 Windows 窗体设计器所必需的
    
        '可以使用 Windows 窗体设计器修改此过程。
    
        '不要使用代码编辑器修改它。
    
        Friend WithEvents ListBox1 As System.Windows.Forms.ListBox
    
        Friend WithEvents ListBox2 As System.Windows.Forms.ListBox
    
        Friend WithEvents TextBox1 As System.Windows.Forms.TextBox
    
        Friend WithEvents Button1 As System.Windows.Forms.Button
    
        Friend WithEvents Button2 As System.Windows.Forms.Button
    
        Friend WithEvents Button3 As System.Windows.Forms.Button
    
        Friend WithEvents Button4 As System.Windows.Forms.Button
    
        Friend WithEvents Label1 As System.Windows.Forms.Label
    
        <System.Diagnostics.DebuggerStepThrough()> Private Sub InitializeComponent()
    
            Me.ListBox1 = New System.Windows.Forms.ListBox
    
            Me.ListBox2 = New System.Windows.Forms.ListBox
    
            Me.TextBox1 = New System.Windows.Forms.TextBox
    
            Me.Button1 = New System.Windows.Forms.Button
    
            Me.Button2 = New System.Windows.Forms.Button
    
            Me.Button3 = New System.Windows.Forms.Button
    
            Me.Button4 = New System.Windows.Forms.Button
    
            Me.Label1 = New System.Windows.Forms.Label
    
            Me.SuspendLayout()
    
            '
    
            'ListBox1
    
            '
    
            Me.ListBox1.ItemHeight = 12
    
            Me.ListBox1.Location = New System.Drawing.Point(16, 16)
    
            Me.ListBox1.Name = "ListBox1"
    
            Me.ListBox1.Size = New System.Drawing.Size(216, 64)
    
            Me.ListBox1.TabIndex = 1
    
            '
    
            'ListBox2
    
            '
    
            Me.ListBox2.ItemHeight = 12
    
            Me.ListBox2.Location = New System.Drawing.Point(16, 88)
    
            Me.ListBox2.Name = "ListBox2"
    
            Me.ListBox2.Size = New System.Drawing.Size(216, 100)
    
            Me.ListBox2.TabIndex = 2
    
            '
    
            'TextBox1
    
            '
    
            Me.TextBox1.Location = New System.Drawing.Point(24, 208)
    
            Me.TextBox1.Name = "TextBox1"
    
            Me.TextBox1.Size = New System.Drawing.Size(208, 21)
    
            Me.TextBox1.TabIndex = 3
    
            Me.TextBox1.Text = "c:\0001.wav"
    
            '
    
            'Button1
    
            '
    
            Me.Button1.Location = New System.Drawing.Point(24, 240)
    
            Me.Button1.Name = "Button1"
    
            Me.Button1.Size = New System.Drawing.Size(64, 24)
    
            Me.Button1.TabIndex = 4
    
            Me.Button1.Text = "recode"
    
            '
    
            'Button2
    
            '
    
            Me.Button2.Location = New System.Drawing.Point(96, 240)
    
            Me.Button2.Name = "Button2"
    
            Me.Button2.Size = New System.Drawing.Size(72, 24)
    
            Me.Button2.TabIndex = 5
    
            Me.Button2.Text = "stop"
    
            '
    
            'Button3
    
            '
    
            Me.Button3.Location = New System.Drawing.Point(176, 240)
    
            Me.Button3.Name = "Button3"
    
            Me.Button3.Size = New System.Drawing.Size(80, 24)
    
            Me.Button3.TabIndex = 6
    
            Me.Button3.Text = "play"
    
            '
    
            'Button4
    
            '
    
            Me.Button4.Location = New System.Drawing.Point(272, 240)
    
            Me.Button4.Name = "Button4"
    
            Me.Button4.Size = New System.Drawing.Size(96, 24)
    
            Me.Button4.TabIndex = 7
    
            Me.Button4.Text = "disposebuff"
    
            '
    
            'Label1
    
            '
    
            Me.Label1.Location = New System.Drawing.Point(248, 16)
    
            Me.Label1.Name = "Label1"
    
            Me.Label1.Size = New System.Drawing.Size(264, 160)
    
            Me.Label1.TabIndex = 8
    
            Me.Label1.Text = "声音格式"
    
            '
    
            'Form1
    
            '
    
            Me.AutoScaleBaseSize = New System.Drawing.Size(6, 14)
    
            Me.ClientSize = New System.Drawing.Size(536, 277)
    
            Me.Controls.Add(Me.Label1)
    
            Me.Controls.Add(Me.Button4)
    
            Me.Controls.Add(Me.Button3)
    
            Me.Controls.Add(Me.Button2)
    
            Me.Controls.Add(Me.Button1)
    
            Me.Controls.Add(Me.TextBox1)
    
            Me.Controls.Add(Me.ListBox2)
    
            Me.Controls.Add(Me.ListBox1)
    
            Me.Name = "Form1"
    
            Me.Text = "Form1"
    
            Me.ResumeLayout(False)
    
     
    
        End Sub
    
     
    
    #End Region
    
     
    
     
    
        Private Sub Form1_Load(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles MyBase.Load
    
            Dim info As DeviceInformation
    
            '''先得到可以使用的信息
    
            ''' 设备信息由这个集合提供
    
            For Each info In CapList
    
                ListBox1.Items.Add(info.Description)
    
            Next
    
        End Sub
    
     
    
        Private Sub ListBox1_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ListBox1.SelectedIndexChanged
    
            '利用选择的设备
    
            Cap = New Capture(CapList(ListBox1.SelectedIndex).DriverGuid)
    
            '''枚举支持的格式
    
            '''尝试各种格式,只能用try catch 了
    
            Dim fmt As WaveFormat
    
            Dim TestCapture As CaptureBuffer
    
            Dim CaptureDesc As New CaptureBufferDescription
    
            'ListBox2.Items.Clear()
    
            ScanAvailableInputFormats(Cap)
    
            FillFormatListBox()
    
        End Sub
    
        Sub ScanAvailableInputFormats(ByVal cap As Capture)
    
            '-----------------------------------------------------------------------------
    
            ' Name: ScanAvailableInputFormats()
    
            ' Desc: Tests to see if 20 different standard wave formats are supported by
    
            '       the capture device
    
            '-----------------------------------------------------------------------------
    
            Dim format As New WaveFormat
    
            Dim dscheckboxd As New CaptureBufferDescription
    
            Dim pDSCaptureBuffer As CaptureBuffer = Nothing
    
     
    
            ' This might take a second or two, so throw up the hourglass
    
            Cursor = Cursors.WaitCursor
    
     
    
            format.FormatTag = WaveFormatTag.Pcm
    
     
    
            ' Try 20 different standard formats to see if they are supported
    
            Dim iIndex As Integer
    
            For iIndex = 0 To 19
    
                GetWaveFormatFromIndex(iIndex, format)
    
     
    
                ' To test if a capture format is supported, try to create a
    
                ' new capture buffer using a specific format.  If it works
    
                ' then the format is supported, otherwise not.
    
                dscheckboxd.BufferBytes = format.AverageBytesPerSecond
    
                dscheckboxd.Format = format
    
     
    
                Try
    
                    pDSCaptureBuffer = New CaptureBuffer(dscheckboxd, cap)
    
                    InputFormatSupported(iIndex) = True
    
                Catch
    
                    InputFormatSupported(iIndex) = False
    
                End Try
    
                pDSCaptureBuffer.Dispose()
    
            Next iIndex
    
            Cursor = Cursors.Default
    
        End Sub 'ScanAvailableInputFormats
    
        Private Sub GetWaveFormatFromIndex(ByVal Index As Integer, ByRef format As WaveFormat)
    
            '-----------------------------------------------------------------------------
    
            ' Name: GetWaveFormatFromIndex()
    
            ' Desc: Returns 20 different wave formats based on Index
    
            '-----------------------------------------------------------------------------
    
            Dim SampleRate As Integer = Index / 4
    
            Dim iType As Integer = Index Mod 4
    
     
    
            Select Case SampleRate
    
                Case 0
    
                    format.SamplesPerSecond = 48000
    
                Case 1
    
                    format.SamplesPerSecond = 44100
    
                Case 2
    
                    format.SamplesPerSecond = 22050
    
                Case 3
    
                    format.SamplesPerSecond = 11025
    
                Case 4
    
                    format.SamplesPerSecond = 8000
    
            End Select
    
     
    
            Select Case iType
    
                Case 0
    
                    format.BitsPerSample = 8
    
                    format.Channels = 1
    
                Case 1
    
                    format.BitsPerSample = 16
    
                    format.Channels = 1
    
                Case 2
    
                    format.BitsPerSample = 8
    
                    format.Channels = 2
    
                Case 3
    
                    format.BitsPerSample = 16
    
                    format.Channels = 2
    
            End Select
    
     
    
            format.BlockAlign = CShort(format.Channels * (format.BitsPerSample / 8))
    
            format.AverageBytesPerSecond = format.BlockAlign * format.SamplesPerSecond
    
        End Sub 'GetWaveFormatFromIndex
    
        Private Shared Function ConvertWaveFormatToString(ByVal format As WaveFormat) As String
    
            '-----------------------------------------------------------------------------
    
            ' Name: ConvertWaveFormatToString()
    
            ' Desc: Converts a wave format to a text string
    
            '-----------------------------------------------------------------------------
    
            Return format.SamplesPerSecond.ToString() + " Hz, " + format.BitsPerSample.ToString() + "-bit " + IIf(format.Channels = 1, "Mono", "Stereo")
    
        End Function 'ConvertWaveFormatToString
    
        Sub FillFormatListBox()
    
            '-----------------------------------------------------------------------------
    
            ' Name: FillFormatListBox()
    
            ' Desc: Fills the format list box based on the availible formats
    
            '-----------------------------------------------------------------------------
    
            Dim info As New FormatInfo
    
            Dim strFormatName As String = String.Empty
    
            Dim format As New WaveFormat
    
     
    
            Dim iIndex As Integer
    
            For iIndex = 0 To InputFormatSupported.Length - 1
    
                If True = InputFormatSupported(iIndex) Then
    
                    ' Turn the index into a WaveFormat then turn that into a
    
                    ' string and put the string in the listbox
    
                    GetWaveFormatFromIndex(iIndex, format)
    
                    info.format = format
    
                    Formats.Add(info)
    
                End If
    
            Next iIndex
    
            ListBox2.DataSource = Formats
    
        End Sub 'FillFormatListBox
    
        Sub CreateRIFF()
    
            '*************************************************************************
    
            '
    
            '
    
            ' Here is where the file will be created. A
    
            '
    
            ' wave file is a RIFF file, which has chunks
    
            '
    
            ' of data that describe what the file contains.
    
            '
    
            ' A wave RIFF file is put together like this:
    
            '
    
            '
    
            '
    
            ' The 12 byte RIFF chunk is constructed like this:
    
            '
    
            '   Bytes(0 - 3) 'R' 'I' 'F' 'F'
    
            '
    
            ' Bytes 4 - 7 : Length of file, minus the first 8 bytes of the RIFF description.
    
            '
    
            '                   (4 bytes for "WAVE" + 24 bytes for format chunk length +
    
            '
    
            '                   8 bytes for data chunk description + actual sample data size.)
    
            '
    
            '   Bytes(8 - 11) 'W' 'A' 'V' 'E'
    
            '
    
            '
    
            '
    
            ' The 24 byte FORMAT chunk is constructed like this:
    
            '
    
            '   Bytes(0 - 3) 'f' 'm' 't' ' '
    
            '
    
            ' Bytes 4 - 7 : The format chunk length. This is always 16.
    
            '
    
            ' Bytes 8 - 9 : File padding. Always 1.
    
            '
    
            ' Bytes 10- 11: Number of channels. Either 1 for mono,  or 2 for stereo.
    
            '
    
            ' Bytes 12- 15: Sample rate.
    
            '
    
            ' Bytes 16- 19: Number of bytes per second.
    
            '
    
            ' Bytes 20- 21: Bytes per sample. 1 for 8 bit mono, 2 for 8 bit stereo or
    
            '
    
            '                   16 bit mono, 4 for 16 bit stereo.
    
            '
    
            ' Bytes 22- 23: Number of bits per sample.
    
            '
    
            '
    
            '
    
            ' The DATA chunk is constructed like this:
    
            '
    
            '   Bytes(0 - 3) 'd' 'a' 't' 'a'
    
            '
    
            ' Bytes 4 - 7 : Length of data, in bytes.
    
            '
    
            ' Bytes 8 -...: Actual sample data.
    
            '
    
            '
    
            '
    
            '**************************************************************************
    
     
    
            ' Open up the wave file for writing.
    
            WaveFile = New FileStream(TextBox1.Text, FileMode.Create)
    
            Writer = New BinaryWriter(WaveFile)
    
     
    
            ' Set up file with RIFF chunk info.
    
            Dim ChunkRiff As Char() = {"R", "I", "F", "F"}
    
            Dim ChunkType As Char() = {"W", "A", "V", "E"}
    
            Dim ChunkFmt As Char() = {"f", "m", "t", " "}
    
            Dim ChunkData As Char() = {"d", "a", "t", "a"}
    
     
    
            Dim shPad As Short = 1 ' File padding
    
            Dim nFormatChunkLength As Integer = &H10 ' Format chunk length.
    
            Dim nLength As Integer = 0 ' File length, minus first 8 bytes of RIFF description. This will be filled in later.
    
            Dim shBytesPerSample As Short = 0 ' Bytes per sample.
    
            ' Figure out how many bytes there will be per sample.
    
            If 8 = InputFormat.BitsPerSample And 1 = InputFormat.Channels Then
    
                shBytesPerSample = 1
    
            ElseIf 8 = InputFormat.BitsPerSample And 2 = InputFormat.Channels Or (16 = InputFormat.BitsPerSample And 1 = InputFormat.Channels) Then
    
                shBytesPerSample = 2
    
            ElseIf 16 = InputFormat.BitsPerSample And 2 = InputFormat.Channels Then
    
                shBytesPerSample = 4
    
            End If
    
            ' Fill in the riff info for the wave file.
    
            Writer.Write(ChunkRiff)
    
            Writer.Write(nLength)
    
            Writer.Write(ChunkType)
    
     
    
            ' Fill in the format info for the wave file.
    
            Writer.Write(ChunkFmt)
    
            Writer.Write(nFormatChunkLength)
    
            Writer.Write(shPad)
    
            Writer.Write(InputFormat.Channels)
    
            Writer.Write(InputFormat.SamplesPerSecond)
    
            Writer.Write(InputFormat.AverageBytesPerSecond)
    
            Writer.Write(shBytesPerSample)
    
            Writer.Write(InputFormat.BitsPerSample)
    
     
    
            ' Now fill in the data chunk.
    
            Writer.Write(ChunkData)
    
            Writer.Write(CInt(0)) ' The sample length will be written in later.
    
        End Sub 'CreateRIFF
    
        Sub CreateCaptureBuffer()
    
            '-----------------------------------------------------------------------------
    
            ' Name: CreateCaptureBuffer()
    
            ' Desc: Creates a capture buffer and sets the format
    
            '-----------------------------------------------------------------------------
    
            Dim dscheckboxd As New CaptureBufferDescription
    
     
    
            If Not Nothing Is applicationNotify Then
    
                applicationNotify.Dispose()
    
                applicationNotify = Nothing
    
            End If
    
            If Not Nothing Is applicationBuffer Then
    
                applicationBuffer.Dispose()
    
                applicationBuffer = Nothing
    
            End If
    
     
    
            If 0 = InputFormat.Channels Then
    
                Return
    
            End If
    
            ' Set the notification size
    
            NotifySize = IIf(1024 > InputFormat.AverageBytesPerSecond / 8, 1024, InputFormat.AverageBytesPerSecond / 8)
    
            NotifySize -= NotifySize Mod InputFormat.BlockAlign
    
     
    
            ' Set the buffer sizes
    
            CaptureBufferSize = NotifySize * NumberRecordNotifications
    
     
    
            ' Create the capture buffer
    
            dscheckboxd.BufferBytes = CaptureBufferSize
    
            InputFormat.FormatTag = WaveFormatTag.Pcm
    
            dscheckboxd.Format = InputFormat ' Set the format during creatation
    
            applicationBuffer = New CaptureBuffer(dscheckboxd, Cap)
    
            NextCaptureOffset = 0
    
     
    
            InitNotifications()
    
        End Sub 'CreateCaptureBuffer
    
     
    
        Sub InitNotifications()
    
            '-----------------------------------------------------------------------------
    
            ' Name: InitNotifications()
    
            ' Desc: Inits the notifications on the capture buffer which are handled
    
            '       in the notify thread.
    
            '-----------------------------------------------------------------------------
    
            If Nothing Is applicationBuffer Then
    
                Throw New ArgumentNullException
    
            End If
    
            ' Create a thread to monitor the notify events
    
            If Nothing Is NotifyThread Then
    
                NotifyThread = New Thread(New ThreadStart(AddressOf WaitThread))
    
                NotifyThread.Start()
    
     
    
                ' Create a notification event, for when the sound stops playing
    
                NotificationEvent = New AutoResetEvent(False)
    
            End If
    
     
    
            ' Setup the notification positions
    
            Dim i As Integer
    
            For i = 0 To NumberRecordNotifications - 1
    
                PositionNotify(i).Offset = NotifySize * i + NotifySize - 1
    
                PositionNotify(i).EventNotifyHandle = NotificationEvent.Handle
    
            Next i
    
     
    
            applicationNotify = New Notify(applicationBuffer)
    
     
    
            ' Tell DirectSound when to notify the app. The notification will come in the from
    
            ' of signaled events that are handled in the notify thread.
    
            applicationNotify.SetNotificationPositions(PositionNotify, NumberRecordNotifications)
    
        End Sub 'InitNotifications
    
        Private Sub WaitThread()
    
            While Created
    
                'Sit here and wait for a message to arrive
    
                NotificationEvent.WaitOne(Timeout.Infinite, True)
    
                RecordCapturedData()
    
            End While
    
        End Sub 'WaitThread
    
        Sub RecordCapturedData()
    
            '-----------------------------------------------------------------------------
    
            ' Name: RecordCapturedData()
    
            ' Desc: Copies data from the capture buffer to the output buffer
    
            '-----------------------------------------------------------------------------
    
            Dim CaptureData As Byte() = Nothing
    
            Dim ReadPos As Integer
    
            Dim CapturePos As Integer
    
            Dim LockSize As Integer
    
     
    
            If Nothing Is applicationBuffer Or Nothing Is WaveFile Then
    
                Return
    
            End If
    
            applicationBuffer.GetCurrentPosition(CapturePos, ReadPos)
    
            LockSize = ReadPos - NextCaptureOffset
    
            If LockSize < 0 Then
    
                LockSize += CaptureBufferSize
    
            End If
    
            ' Block align lock size so that we are always write on a boundary
    
            LockSize -= LockSize Mod NotifySize
    
     
    
            If 0 = LockSize Then
    
                Return
    
            End If
    
            ' Read the capture buffer.
    
            CaptureData = CType(applicationBuffer.Read(NextCaptureOffset, GetType(Byte), LockFlag.None, LockSize), Byte())
    
     
    
            ' Write the data into the wav file
    
            Writer.Write(CaptureData, 0, CaptureData.Length)
    
     
    
            ' Update the number of samples, in bytes, of the file so far.
    
            SampleCount += CaptureData.Length
    
     
    
            ' Move the capture offset along
    
            NextCaptureOffset += CaptureData.Length
    
            NextCaptureOffset = NextCaptureOffset Mod CaptureBufferSize ' Circular buffer
    
        End Sub 'RecordCapturedData
    
     
    
        Private Sub ListBox2_SelectedIndexChanged(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles ListBox2.SelectedIndexChanged
    
            InputFormat = CType(Formats(ListBox2.SelectedIndex), FormatInfo).format
    
            Label1.Text = CType(ListBox2.SelectedItem, FormatInfo).format.ToString
    
        End Sub
    
        Sub StartOrStopRecord(ByVal StartRecording As Boolean)
    
            '-----------------------------------------------------------------------------
    
            ' Name: StartOrStopRecord()
    
            ' Desc: Starts or stops the capture buffer from recording
    
            '-----------------------------------------------------------------------------
    
            If StartRecording Then
    
                ' Create a capture buffer, and tell the capture
    
                ' buffer to start recording  
    
                CreateCaptureBuffer()
    
                applicationBuffer.Start(True)
    
            Else
    
                ' Stop the capture and read any data that
    
                ' was not caught by a notification
    
                If Nothing Is applicationBuffer Then
    
                    Return
    
                End If
    
                ' Stop the buffer, and read any data that was not
    
                ' caught by a notification
    
                applicationBuffer.Stop()
    
     
    
                RecordCapturedData()
    
     
    
                Writer.Seek(4, SeekOrigin.Begin) ' Seek to the length descriptor of the RIFF file.
    
                Writer.Write(CInt(SampleCount + 36)) ' Write the file length, minus first 8 bytes of RIFF description.
    
                Writer.Seek(40, SeekOrigin.Begin) ' Seek to the data length descriptor of the RIFF file.
    
                Writer.Write(SampleCount) ' Write the length of the sample data in bytes.
    
                Writer.Close() ' Close the file now.
    
                Writer = Nothing ' Set the writer to null.
    
                WaveFile = Nothing ' Set the FileStream to null.
    
            End If
    
        End Sub 'StartOrStopRecord
    
     
    
     
    
        Private Sub Button1_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button1.Click
    
            CreateRIFF()
    
            StartOrStopRecord(True)
    
     
    
        End Sub
    
     
    
        Private Sub Button2_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button2.Click
    
            StartOrStopRecord(False)
    
     
    
        End Sub
    
     
    
        Private Sub Button3_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button3.Click
    
            DevPlay.SetCooperativeLevel(Me, CooperativeLevel.Priority)
    
            BufPlay = New SecondaryBuffer(TextBox1.Text, DevPlay)
    
            BufPlay.Play(0, BufferPlayFlags.Default)
    
     
    
        End Sub
    
     
    
        Private Sub Button4_Click(ByVal sender As System.Object, ByVal e As System.EventArgs) Handles Button4.Click
    
            BufPlay.Stop()
    
            BufPlay.Dispose()
    
     
    
        End Sub
    
        Private Sub MainForm_Closing(ByVal sender As Object, ByVal e As System.ComponentModel.CancelEventArgs) Handles MyBase.Closing
    
            If Not Nothing Is NotificationEvent Then
    
                NotificationEvent.Set()
    
            End If
    
            If Not Nothing Is applicationBuffer Then
    
                If applicationBuffer.Capturing Then
    
                    StartOrStopRecord(False)
    
                End If
    
            End If
    
            End
    
        End Sub 'MainForm_Closing
    
     
    
    End Class
    
      4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
    • 100
    • 101
    • 102
    • 103
    • 104
    • 105
    • 106
    • 107
    • 108
    • 109
    • 110
    • 111
    • 112
    • 113
    • 114
    • 115
    • 116
    • 117
    • 118
    • 119
    • 120
    • 121
    • 122
    • 123
    • 124
    • 125
    • 126
    • 127
    • 128
    • 129
    • 130
    • 131
    • 132
    • 133
    • 134
    • 135
    • 136
    • 137
    • 138
    • 139
    • 140
    • 141
    • 142
    • 143
    • 144
    • 145
    • 146
    • 147
    • 148
    • 149
    • 150
    • 151
    • 152
    • 153
    • 154
    • 155
    • 156
    • 157
    • 158
    • 159
    • 160
    • 161
    • 162
    • 163
    • 164
    • 165
    • 166
    • 167
    • 168
    • 169
    • 170
    • 171
    • 172
    • 173
    • 174
    • 175
    • 176
    • 177
    • 178
    • 179
    • 180
    • 181
    • 182
    • 183
    • 184
    • 185
    • 186
    • 187
    • 188
    • 189
    • 190
    • 191
    • 192
    • 193
    • 194
    • 195
    • 196
    • 197
    • 198
    • 199
    • 200
    • 201
    • 202
    • 203
    • 204
    • 205
    • 206
    • 207
    • 208
    • 209
    • 210
    • 211
    • 212
    • 213
    • 214
    • 215
    • 216
    • 217
    • 218
    • 219
    • 220
    • 221
    • 222
    • 223
    • 224
    • 225
    • 226
    • 227
    • 228
    • 229
    • 230
    • 231
    • 232
    • 233
    • 234
    • 235
    • 236
    • 237
    • 238
    • 239
    • 240
    • 241
    • 242
    • 243
    • 244
    • 245
    • 246
    • 247
    • 248
    • 249
    • 250
    • 251
    • 252
    • 253
    • 254
    • 255
    • 256
    • 257
    • 258
    • 259
    • 260
    • 261
    • 262
    • 263
    • 264
    • 265
    • 266
    • 267
    • 268
    • 269
    • 270
    • 271
    • 272
    • 273
    • 274
    • 275
    • 276
    • 277
    • 278
    • 279
    • 280
    • 281
    • 282
    • 283
    • 284
    • 285
    • 286
    • 287
    • 288
    • 289
    • 290
    • 291
    • 292
    • 293
    • 294
    • 295
    • 296
    • 297
    • 298
    • 299
    • 300
    • 301
    • 302
    • 303
    • 304
    • 305
    • 306
    • 307
    • 308
    • 309
    • 310
    • 311
    • 312
    • 313
    • 314
    • 315
    • 316
    • 317
    • 318
    • 319
    • 320
    • 321
    • 322
    • 323
    • 324
    • 325
    • 326
    • 327
    • 328
    • 329
    • 330
    • 331
    • 332
    • 333
    • 334
    • 335
    • 336
    • 337
    • 338
    • 339
    • 340
    • 341
    • 342
    • 343
    • 344
    • 345
    • 346
    • 347
    • 348
    • 349
    • 350
    • 351
    • 352
    • 353
    • 354
    • 355
    • 356
    • 357
    • 358
    • 359
    • 360
    • 361
    • 362
    • 363
    • 364
    • 365
    • 366
    • 367
    • 368
    • 369
    • 370
    • 371
    • 372
    • 373
    • 374
    • 375
    • 376
    • 377
    • 378
    • 379
    • 380
    • 381
    • 382
    • 383
    • 384
    • 385
    • 386
    • 387
    • 388
    • 389
    • 390
    • 391
    • 392
    • 393
    • 394
    • 395
    • 396
    • 397
    • 398
    • 399
    • 400
    • 401
    • 402
    • 403
    • 404
    • 405
    • 406
    • 407
    • 408
    • 409
    • 410
    • 411
    • 412
    • 413
    • 414
    • 415
    • 416
    • 417
    • 418
    • 419
    • 420
    • 421
    • 422
    • 423
    • 424
    • 425
    • 426
    • 427
    • 428
    • 429
    • 430
    • 431
    • 432
    • 433
    • 434
    • 435
    • 436
    • 437
    • 438
    • 439
    • 440
    • 441
    • 442
    • 443
    • 444
    • 445
    • 446
    • 447
    • 448
    • 449
    • 450
    • 451
    • 452
    • 453
    • 454
    • 455
    • 456
    • 457
    • 458
    • 459
    • 460
    • 461
    • 462
    • 463
    • 464
    • 465
    • 466
    • 467
    • 468
    • 469
    • 470
    • 471
    • 472
    • 473
    • 474
    • 475
    • 476
    • 477
    • 478
    • 479
    • 480
    • 481
    • 482
    • 483
    • 484
    • 485
    • 486
    • 487
    • 488
    • 489
    • 490
    • 491
    • 492
    • 493
    • 494
    • 495
    • 496
    • 497
    • 498
    • 499
    • 500
    • 501
    • 502
    • 503
    • 504
    • 505
    • 506
    • 507
    • 508
    • 509
    • 510
    • 511
    • 512
    • 513
    • 514
    • 515
    • 516
    • 517
    • 518
    • 519
    • 520
    • 521
    • 522
    • 523
    • 524
    • 525
    • 526
    • 527
    • 528
    • 529
    • 530
    • 531
    • 532
    • 533
    • 534
    • 535
    • 536
    • 537
    • 538
    • 539
    • 540
    • 541
    • 542
    • 543
    • 544
    • 545
    • 546
    • 547
    • 548
    • 549
    • 550
    • 551
    • 552
    • 553
    • 554
    • 555
    • 556
    • 557
    • 558
    • 559
    • 560
    • 561
    • 562
    • 563
    • 564
    • 565
    • 566
    • 567
    • 568
    • 569
    • 570
    • 571
    • 572
    • 573
    • 574
    • 575
    • 576
    • 577
    • 578
    • 579
    • 580
    • 581
    • 582
    • 583
    • 584
    • 585
    • 586
    • 587
    • 588
    • 589
    • 590
    • 591
    • 592
    • 593
    • 594
    • 595
    • 596
    • 597
    • 598
    • 599
    • 600
    • 601
    • 602
    • 603
    • 604
    • 605
    • 606
    • 607
    • 608
    • 609
    • 610
    • 611
    • 612
    • 613
    • 614
    • 615
    • 616
    • 617
    • 618
    • 619
    • 620
    • 621
    • 622
    • 623
    • 624
    • 625
    • 626
    • 627
    • 628
    • 629
    • 630
    • 631
    • 632
    • 633
    • 634
    • 635
    • 636
    • 637
    • 638
    • 639
    • 640
    • 641
    • 642
    • 643
    • 644
    • 645
    • 646
    • 647
    • 648
    • 649
    • 650
    • 651
    • 652
    • 653
    • 654
    • 655
    • 656
    • 657
    • 658
    • 659
    • 660
    • 661
    • 662
    • 663
    • 664
    • 665
    • 666
    • 667
    • 668
    • 669
    • 670
    • 671
    • 672
    • 673
    • 674
    • 675
    • 676
    • 677
    • 678
    • 679
    • 680
    • 681
    • 682
    • 683
    • 684
    • 685
    • 686
    • 687
    • 688
    • 689
    • 690
    • 691
    • 692
    • 693
    • 694
    • 695
    • 696
    • 697
    • 698
    • 699
    • 700
    • 701
    • 702
    • 703
    • 704
    • 705
    • 706
    • 707
    • 708
    • 709
    • 710
    • 711
    • 712
    • 713
    • 714
    • 715
    • 716
    • 717
    • 718
    • 719
    • 720
    • 721
    • 722
    • 723
    • 724
    • 725
    • 726
    • 727
    • 728
    • 729
    • 730
    • 731
    • 732
    • 733
    • 734
    • 735
    • 736
    • 737
    • 738
    • 739
    • 740
    • 741
    • 742
    • 743
    • 744
    • 745
    • 746
    • 747
    • 748
    • 749
    • 750
    • 751
    • 752
    • 753
    • 754
    • 755
    • 756
    • 757
    • 758
    • 759
    • 760
    • 761
    • 762
    • 763
    • 764
    • 765
    • 766
    • 767
    • 768
    • 769
    • 770
    • 771
    • 772
    • 773
    • 774
    • 775
    • 776
    • 777
    • 778
    • 779
    • 780
    • 781
    • 782
    • 783
    • 784
    • 785
    • 786
    • 787
    • 788
    • 789
    • 790
    • 791
    • 792
    • 793
    • 794
    • 795
    • 796
    • 797
    • 798
    • 799
    • 800
    • 801
    • 802
    • 803
    • 804
    • 805
    • 806
    • 807
    • 808
    • 809
    • 810
    • 811
    • 812
    • 813
    • 814
    • 815
    • 816
    • 817
    • 818
    • 819
    • 820
    • 821
    • 822
    • 823
    • 824
    • 825
    • 826
    • 827
    • 828
    • 829
    • 830
    • 831
    • 832
    • 833
    • 834
    • 835
    • 836
    • 837
    • 838
    • 839
    • 840
    • 841
    • 842
    • 843
    • 844
    • 845
    • 846
    • 847
    • 848
    • 849
    • 850
    • 851
    • 852
    • 853
    • 854
    • 855
    • 856
    • 857
    • 858
    • 859
    • 860
    • 861
    • 862
    • 863
    • 864
    • 865
    • 866
    • 867
    • 868
    • 869
    • 870
    • 871
    • 872
    • 873
    • 874
    • 875
    • 876
    • 877
    • 878
    • 879
    • 880
    • 881
    • 882
    • 883
    • 884
    • 885
    • 886
    • 887
    • 888
    • 889
    • 890
    • 891
    • 892
    • 893
    • 894
    • 895
    • 896
    • 897
    • 898
    • 899
    • 900
    • 901
    • 902
    • 903
    • 904
    • 905
    • 906
    • 907
    • 908
    • 909
    • 910
    • 911
    • 912
    • 913
    • 914
    • 915
    • 916
    • 917
    • 918
    • 919
    • 920
    • 921
    • 922
    • 923
    • 924
    • 925
    • 926
    • 927
    • 928
    • 929
    • 930
    • 931
    • 932
    • 933
    • 934
    • 935
    • 936
    • 937
    • 938
    • 939
    • 940
    • 941
    • 942
    • 943
    • 944
    • 945
    • 946
    • 947
    • 948
    • 949
    • 950
    • 951
    • 952
    • 953
    • 954
    • 955
    • 956
    • 957
    • 958
    • 959
    • 960
    • 961
    • 962
    • 963
    • 964
    • 965
    • 966
    • 967
    • 968
    • 969
    • 970
    • 971
    • 972
    • 973
    • 974
    • 975
    • 976
    • 977
    • 978
    • 979
    • 980
    • 981
    • 982
    • 983
    • 984
    • 985
    • 986
    • 987
    • 988
    • 989
    • 990
    • 991
    • 992
    • 993
    • 994
    • 995
    • 996
    • 997
    • 998
    • 999
    • 1000
    • 1001
    • 1002
    • 1003
    • 1004
    • 1005
    • 1006
    • 1007
    • 1008
    • 1009
    • 1010
    • 1011
    • 1012
    • 1013
    • 1014
    • 1015
    • 1016
    • 1017
    • 1018
    • 1019
    • 1020
    • 1021
    • 1022
    • 1023
    • 1024
    • 1025
    • 1026
    • 1027
    • 1028
    • 1029
    • 1030
    • 1031
    • 1032
    • 1033
    • 1034
    • 1035
    • 1036
    • 1037
    • 1038
    • 1039
    • 1040
    • 1041
    • 1042
    • 1043
    • 1044
    • 1045
    • 1046
    • 1047
    • 1048
    • 1049
    • 1050
    • 1051
    • 1052
    • 1053
    • 1054
    • 1055
    • 1056
    • 1057
    • 1058
    • 1059
    • 1060
    • 1061
    • 1062
    • 1063
    • 1064
    • 1065
    • 1066
    • 1067
    • 1068
    • 1069
    • 1070
    • 1071
    • 1072
    • 1073
    • 1074
    • 1075
    • 1076
    • 1077
    • 1078
    • 1079
    • 1080
    • 1081
    • 1082
    • 1083
    • 1084
    • 1085
    • 1086
    • 1087
    • 1088
    • 1089
    • 1090
    • 1091
    • 1092
    • 1093
    • 1094
    • 1095
    • 1096
    • 1097
    • 1098
    • 1099
    • 1100
    • 1101
    • 1102
    • 1103
    • 1104
    • 1105
    • 1106
    • 1107
    • 1108
    • 1109
    • 1110
    • 1111
    • 1112
    • 1113
    • 1114
    • 1115
    • 1116
    • 1117
    • 1118
    • 1119
    • 1120
    • 1121
    • 1122
    • 1123
    • 1124
    • 1125
    • 1126
    • 1127
    • 1128
    • 1129
    • 1130
    • 1131
    • 1132
    • 1133
    • 1134
    • 1135
    • 1136
    • 1137
    • 1138
    • 1139
    • 1140
    • 1141
    • 1142
    • 1143
    • 1144
    • 1145
    • 1146
    • 1147
    • 1148
    • 1149
    • 1150
    • 1151
    • 1152
    • 1153
    • 1154
    • 1155
    • 1156
    • 1157
    • 1158
    • 1159
    • 1160
    • 1161

    =======================================
    OK DirectSound最后的部分写完了.总体感觉微软的封装还是有道理的

    既要体现出易用性,而且还要充分发挥硬件的能力.如果你觉得某些特性用不到(很多其实都用不到)

    你可以自己在DirectSound的基础上制作自己的声效引擎方便自己使用.

    现在也存在不少优秀的声效引擎(在模拟器里面经常见到),至于是否自己开发,就要看你的兴趣了

    如果您对DirectSound感兴趣,可以来我的Blog或者留言版发表看法.

    http://Blog.csdn.net/a11s

    下一个目标,托管的DirectPlay
    (可能跟DSound中间插入DDraw一样,DPlay的时候顺便搞定DInput)

    End DirectSound 9========

    相关技术文章

    点击QQ咨询
    开通会员
    返回顶部
    ×
    微信扫码支付
    微信扫码支付
    确定支付下载
    请使用微信描二维码支付
    ×

    提示信息

    ×

    选择支付方式

    • 微信支付
    • 支付宝付款
    确定支付下载