解析WAV头部信息后,接下来就可以根据相关参数和DATA块数据绘制波形.

1.重新编码(转换为8bits,单声道数据)

  Public Function GetFormatData(ByVal pData() As Byte, ByVal pWaveHeader As waveHeaderStructre) As Byte()
        Dim temp As Integer
        Dim data() As Byte = {}
          Then
            )

                data(i) = pData(i)
            Next
          Then
             - )

                data(i) = pData(i * )
            Next
          Then
             - )

                temp = System.BitConverter.ToInt16(pData, i * ) /  +
                temp = , , temp)
                temp = , , temp)
                data(i) = temp
            Next
          Then
             - )

                temp = System.BitConverter.ToInt16(pData, i * ) /  +
                temp = , , temp)
                temp = , , temp)
                data(i) = temp
            Next
        End If
        Return data
    End Function

2.显示波形

    Public Sub PaintingWave(ByVal pData() As Byte, ByVal pWaveHeader As waveHeaderStructre, ByVal pBox As PictureBox)
        Dim pg As Graphics = pBox.CreateGraphics
        Dim pwidth As Integer = pBox.Width
        Dim pheight As Integer = pBox.Height
        Dim points As New List(Of PointF)
        Dim PImage As Bitmap = New Bitmap(pwidth, pheight)
        pg = Drawing.Graphics.FromImage(PImage)
         To pheight '绘制渐变背景
            pg.DrawLine( + Math.Abs(i / (pheight / ) - ), , , ), ), , i, pwidth, i)
        Next
          '波形的离散数据点
            points.Add()))
        Next
        pg.DrawLines(, , )), points.ToArray)
        pBox.Image = PImage
        pg.Dispose()
    End Sub

3.完整WAV分析封装类

  实现功能:头部信息解析,重新编码,波形可视化

  示例:

Dim SamplesWave As New WaveClass("F:\Music\李宗盛-山丘.wav")

SamplesWave.PaintWave(PictureBox1)

Class WaveClass
    Public waveHeadInf As waveHeaderStructre 'wav文件头部信息
    Dim fileData() As Byte '文件原始数据
    Public waveData() As Byte 'DATA块原始数据
    Structure waveHeaderStructre
        'RiffChunk
        Dim RIFF As String
        Dim FileSize As UInteger
        Dim WAVE As String
        'FormatChunk
        Dim FORMAT As String
        Dim FormatSize As UInteger
        Dim FilePadding As UShort
        Dim FormatChannels As UShort
        Dim SamplesPerSecond As UInteger
        Dim AverageBytesPerSecond As UInteger
        Dim BytesPerSample As UShort
        Dim BitsPerSample As UShort
        Dim FormatExtra As UShort
        'FactChunk
        Dim FACT As String
        Dim FactSize As UInteger
        Dim FactInf As UInteger
        'DataChunk
        Dim DATA As String
        Dim DataSize As UInteger
    End Structure
    Public Sub New(ByVal FileName As String)
        fileData = My.Computer.FileSystem.ReadAllBytes(FileName) '加载wav文件
        SplitWaveData(fileData) '分析头部,并获取DATA块数据
    End Sub
    Public Sub PaintWave(ByVal pBox As PictureBox, Optional ByVal pData() As Byte = Nothing) '指定PictureBox绘制波形
        If pData Is Nothing Then pData = GetFormatData()
        Dim pg As Graphics = pBox.CreateGraphics
        Dim pwidth As Integer = pBox.Width
        Dim pheight As Integer = pBox.Height
        Dim points As New List(Of PointF)
        Dim PImage As Bitmap = New Bitmap(pwidth, pheight)
        pg = Drawing.Graphics.FromImage(PImage)
         To pheight '绘制渐变背景
            pg.DrawLine( + Math.Abs(i / (pheight / ) - ), , , ), ), , i, pwidth, i)
        Next
          '波形的离散数据点
            points.Add()))
        Next
        pg.DrawLines(, , )), points.ToArray)
        pBox.Image = PImage
        pg.Dispose()
    End Sub
    Private Sub SplitWaveData(ByVal data As Byte()) '提取wav文件头部信息

        waveHeadInf.RIFF = , ), String)
        waveHeadInf.FileSize = System.BitConverter.ToUInt32(data, )
        waveHeadInf.WAVE = , ), String)
        'FormatChunk
        waveHeadInf.FORMAT = , ), String)
        waveHeadInf.FormatSize = System.BitConverter.ToUInt32(data, )
        waveHeadInf.FilePadding = System.BitConverter.ToUInt16(data, )
        waveHeadInf.FormatChannels = System.BitConverter.ToUInt16(data, )
        waveHeadInf.SamplesPerSecond = System.BitConverter.ToUInt32(data, )
        waveHeadInf.AverageBytesPerSecond = System.BitConverter.ToUInt32(data, )
        waveHeadInf.BytesPerSample = System.BitConverter.ToUInt16(data, )
        waveHeadInf.BitsPerSample = System.BitConverter.ToUInt16(data, )
         Then
            waveHeadInf.FormatExtra = System.BitConverter.ToUInt16(data, )
        Else
            waveHeadInf.FormatExtra =
        End If
        tempIndex =  + waveHeadInf.FormatSize
        'FactChunk
        waveHeadInf.FACT = ), String)
        If waveHeadInf.FACT = "fact" Then
            waveHeadInf.FactSize = System.BitConverter.ToUInt32(data, tempIndex + )
            waveHeadInf.FactInf = , System.BitConverter.ToUInt16(data, tempIndex + ), System.BitConverter.ToUInt32(data, tempIndex + ))
            tempIndex = tempIndex + waveHeadInf.FactSize +
        Else
            waveHeadInf.FACT = "NULL"
            waveHeadInf.FactSize =
            waveHeadInf.FactInf =
        End If
        'DataChunk
        waveHeadInf.DATA = ), String)
        waveHeadInf.DataSize = System.BitConverter.ToUInt32(data, tempIndex + )
        tempIndex = tempIndex +
        '提取DATA数据块
        ReDim waveData(data.Length - tempIndex)
        Array.Copy(data, tempIndex, waveData, , data.Length - tempIndex)
    End Sub
    Private Function GetFormatData() As Byte() '重新编码
        Dim temp As Integer
        Dim data() As Byte = {}
          Then
            )

                data(i) = waveData(i)
            Next
          Then
             - )

                data(i) = waveData(i * )
            Next
          Then
             - )

                temp = System.BitConverter.ToInt16(waveData, i * ) /  +
                temp = , , temp)
                temp = , , temp)
                data(i) = temp
            Next
          Then
             - )

                temp = System.BitConverter.ToInt16(waveData, i * ) /  +
                temp = , , temp)
                temp = , , temp)
                data(i) = temp
            Next
        End If
        Return data
    End Function
End Class

音频文件解析(二):WAV格式文件波形绘制的更多相关文章

  1. 歌词文件解析(二):LRC格式文件的绘制

    通过对LRC文件的解析,可以轻松实现歌词可视化. 代码实现 函数名: paintLyrics(ByVal pBox As PictureBox, ByVal CurrentPosition As In ...

  2. 歌词文件解析(一):LRC格式文件的解析

    LRC是英文lyric(歌词)的缩写,被用做歌词文件的扩展名.以lrc为扩展名的歌词文件可以在各类数码播放器中同步显示.LRC 歌词是一种包含着“*:*”形式的“标签(tag)”的基于纯文本的歌词专用 ...

  3. Android音频: 怎样使用AudioTrack播放一个WAV格式文件?

    翻译 By Long Luo 原文链接:Android Audio: Play a WAV file on an AudioTrack 译者注: 1. 因为这是技术文章,所以有些词句使用原文,表达更准 ...

  4. WAV格式文件无损合并&帧头数据体解析(python)(原创)

    一,百度百科 WAV为微软公司(Microsoft)开发的一种声音文件格式,它符合RIFF(Resource Interchange File Format)文件规范,用于保存Windows平台的音频 ...

  5. wav格式文件、pcm数据

    wav格式文件是常见的录音文件,是声音波形文件格式之一,wav 文件由文件头和数据体两部分组成. 文件头是我们在做录音保存到文件的时候,要存储的文件的说明信息,播放器要通过文件头的相关信息去读取数据播 ...

  6. 将PCM格式存储成WAV格式文件

    将PCM格式存储成WAV格式文件 WAV比PCM多44个字节(在文件头位置多) 摘自:https://blog.csdn.net/u012173922/article/details/78849076 ...

  7. Unity的Json解析<二>–写Json文件

    本文章由cartzhang编写,转载请注明出处. 所有权利保留. 文章链接:http://blog.csdn.net/cartzhang/article/details/50378805 作者:car ...

  8. 【转】java将excel文件转换成txt格式文件

    在实际应用中,我们难免会遇到解析excel文件入库事情,有时候为了方便,需要将excel文件转成txt格式文件.下面代码里面提供对xls.xlsx两种格式的excel文件解析,并写入到一个新的txt文 ...

  9. DEX文件解析--6、dex文件字段和方法定义解析

    一.前言    前几篇文章链接:       DEX文件解析---1.dex文件头解析       DEX文件解析---2.Dex文件checksum(校验和)解析       DEX文件解析--3. ...

  10. 批量将某一目录下的.py文件改为.txt格式文件

    #!/usr/env/python#-*- coding:utf-8 -*-#批量将某一目录下的.py文件改为.txt格式文件import os,os.pathfile_list = os.listd ...

随机推荐

  1. Portal.MVC —— nopcommerce的简化版

    Portal.MVC 简介 项目是基于MVC4+EF,带有角色,权限,用户中心及账户相关(登录,注册,修改密码,找回密码等)等基本功能.参考的开源项目 nopcommerce,这是一个电商架构的MVC ...

  2. DDD领域驱动设计之领域基础设施层

    1.DDD领域驱动设计实践篇之如何提取模型 2.DDD领域驱动设计之聚合.实体.值对象 其实这里说的基础设施层只是领域层的一些接口和基类而已,没有其他的如日子工具等代码,仅仅是为了说明领域层的一些基础 ...

  3. js实现一个可以兼容PC端和移动端的div拖动效果

    前段时间写了一个简单的div拖动效果,不料昨天项目上正好需要一个相差不多的需求,就正好用上了,但是在移动端的时候却碰到了问题,拖动时候用到的三个事件:mousedown.mousemove.mouse ...

  4. iOS给图片添加滤镜&使用openGLES动态渲染图片

    给图片增加滤镜有这两种方式: CoreImage / openGLES 下面先说明如何使用CoreImage给图片添加滤镜, 主要为以下步骤: #1.导入CIImage格式的原始图片 #2.创建CIF ...

  5. Elasticsearch推荐插件篇(head,sense,marvel)

    安装head head插件可以用来快速查看elasticsearch中的数据概况以及非全量的数据,也支持控件化查询和rest请求,但是体验都不是很好. 一般就用它来看各个索引的数据量以及分片的状态. ...

  6. struts2学习笔记之五:表单数据收集的几种方式

    方法一:struts2对ModelDriven模式的支持(模型驱动模式) Struts2可以采用类似于Struts1中的ActionForm方式收集数据,这样方式叫ModelDriven模式 Acti ...

  7. Atitit Server Side Include  ssi服务端包含规范 csi  esi

    Atitit Server Side Include  ssi服务端包含规范 csi  esi 一.CSI (Client Side Includes)  1 1.1. 客户端包含1 1.2. Ang ...

  8. 最新hadoop+hbase+spark+zookeeper环境安装(vmmare下)

    说明:我这里安装的版本是hadoop2.7.3,hbase1.2.4,spark2.0.2,zookeeper3.4.9 (安装包:链接:http://pan.baidu.com/s/1c25hI4g ...

  9. KendoUI系列:AutoComplete

    1.基本使用 <link href="@Url.Content("~/C ontent/kendo/2014.1.318/kendo.common.min.css" ...

  10. C#搭建足球赛事资料库与预测平台(1) 基本介绍

            本博客所有文章分类的总目录:[总目录]本博客博文总目录-实时更新 开源C#彩票数据资料库系列文章总目录:[目录]C#搭建足球赛事资料库与预测平台与彩票数据分析目录 去年4月到现在,一年 ...