音频文件解析(二):WAV格式文件波形绘制
解析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格式文件波形绘制的更多相关文章
- 歌词文件解析(二):LRC格式文件的绘制
通过对LRC文件的解析,可以轻松实现歌词可视化. 代码实现 函数名: paintLyrics(ByVal pBox As PictureBox, ByVal CurrentPosition As In ...
- 歌词文件解析(一):LRC格式文件的解析
LRC是英文lyric(歌词)的缩写,被用做歌词文件的扩展名.以lrc为扩展名的歌词文件可以在各类数码播放器中同步显示.LRC 歌词是一种包含着“*:*”形式的“标签(tag)”的基于纯文本的歌词专用 ...
- Android音频: 怎样使用AudioTrack播放一个WAV格式文件?
翻译 By Long Luo 原文链接:Android Audio: Play a WAV file on an AudioTrack 译者注: 1. 因为这是技术文章,所以有些词句使用原文,表达更准 ...
- WAV格式文件无损合并&帧头数据体解析(python)(原创)
一,百度百科 WAV为微软公司(Microsoft)开发的一种声音文件格式,它符合RIFF(Resource Interchange File Format)文件规范,用于保存Windows平台的音频 ...
- wav格式文件、pcm数据
wav格式文件是常见的录音文件,是声音波形文件格式之一,wav 文件由文件头和数据体两部分组成. 文件头是我们在做录音保存到文件的时候,要存储的文件的说明信息,播放器要通过文件头的相关信息去读取数据播 ...
- 将PCM格式存储成WAV格式文件
将PCM格式存储成WAV格式文件 WAV比PCM多44个字节(在文件头位置多) 摘自:https://blog.csdn.net/u012173922/article/details/78849076 ...
- Unity的Json解析<二>–写Json文件
本文章由cartzhang编写,转载请注明出处. 所有权利保留. 文章链接:http://blog.csdn.net/cartzhang/article/details/50378805 作者:car ...
- 【转】java将excel文件转换成txt格式文件
在实际应用中,我们难免会遇到解析excel文件入库事情,有时候为了方便,需要将excel文件转成txt格式文件.下面代码里面提供对xls.xlsx两种格式的excel文件解析,并写入到一个新的txt文 ...
- DEX文件解析--6、dex文件字段和方法定义解析
一.前言 前几篇文章链接: DEX文件解析---1.dex文件头解析 DEX文件解析---2.Dex文件checksum(校验和)解析 DEX文件解析--3. ...
- 批量将某一目录下的.py文件改为.txt格式文件
#!/usr/env/python#-*- coding:utf-8 -*-#批量将某一目录下的.py文件改为.txt格式文件import os,os.pathfile_list = os.listd ...
随机推荐
- C#中使用OpenSSL的公钥加密/私钥解密
在C#中进行公钥加密/私钥解密,需要用RSACryptoServiceProvider,但是它不支持由OpenSSL生成的公钥/私钥字符串. 比如这样的公钥/私钥对( 公私钥生成方法见 http:// ...
- [.net 面向对象编程基础] (20) LINQ使用
[.net 面向对象编程基础] (20) LINQ使用 通过上节LINQ的基础知识的学习,我们可以开始使用LINQ来进行内存数据的查询了,我们上节说了LINQ的定义为:Language Integr ...
- json-smart 使用示例(推荐fastjson)
关于json库,请使用fastjson,这是我用过的最好用的json库! 地址:https://github.com/alibaba/fastjson ======================== ...
- [安卓] 17、一个简单的例子学安卓侧滑设计——用开源slidingmenu
效果如下: 下面是工程结构: 整个工程包括android-v7.SlidingMenu-lib和主工程SlidingMenuTest部分 其中前两个作为lib,后一个为主工程 主工程包含两个lib工程 ...
- [ACM_几何] The Deadly Olympic Returns!!! (空间相对运动之最短距离)
http://acm.hust.edu.cn/vjudge/contest/view.action?cid=28235#problem/B 题目大意: 有两个同时再空间中匀速运动的导弹,告诉一个时间以 ...
- 第二章 深入 C# 数据类型
第二章 深入 C# 数据类型 1.封装又称信息隐藏,是指利用抽象数据类型将数据和数据的操作结合在一起,使其构成一个不可分割的独立实体,尽可能的隐藏内部的细节,只保留一些对外接口,使之于外部发生联系. ...
- Oracle VM VirtualBox配置文件
Linux 虚拟机配置文件分为两处. windows下: 1.用户名/.VirtualBox/ 这里面有2个配置文件: VirtualBox.xml 和 VirtualBox.xml-prev. 后面 ...
- 带你走近AngularJS - 体验指令实例
带你走近AngularJS系列: 带你走近AngularJS - 基本功能介绍 带你走近AngularJS - 体验指令实例 带你走近AngularJS - 创建自定义指令 ------------- ...
- Atitit sql执行计划
Atitit sql执行计划 1.1. 首先要搞明白什么叫执行计划? 执行计划是数据库根据SQL语句和相关表的统计信息作出的一个查询方案,这个方案是由查询优化器自动分析产生的 Oracle中的执行计划 ...
- Jquery判断数组中是否包含某个元素$.inArray()的用法
判断数组里面是否包含某个元素可以使用 $.inArray("元素(字符串)",数组名称) 进行判断 ,当存在该元素(字符串)时,返回该元素在数组的下标,不存在时返回 -1 示例代码 ...