C# wav语音文件合并
开发完成语音播报产品,由于客户所使用的播放产品种类繁多,在使用HDMI接口播放音频时,由于采用的声卡不同,个别机器会出现播报声音过小,或者不播报的情况。所以采用将语音文件合并播放的方式,来解决此问题。
/// <summary>
/// 合并语音流
/// </summary>
/// <param name="pPlayStreamsList">语音流集合</param>
public void MergeAndPlayWavFile(ObservableCollection<Stream> pPlayStreamsList)
{
try
{
if (pPlayStreamsList.Count > 0)
{
int dataFileBeginIndex = 0;
int formatSize;
List<byte[]> bInfoList = new List<byte[]>();
List<int> fileSizeList = new List<int>();
List<int> dataSizeList = new List<int>();
foreach (Stream fs in pPlayStreamsList)
{
fs.Position = 0;
byte[] bInfo = new byte[46];
fs.Read(bInfo, 0, 46);
formatSize = BitConverter.ToInt32(bInfo, 16);
//Wave = RIFF_WAVE_Chunk + Format_Chunk + Data_Chunk(RIFF)/Fact_Chunk(FACT)
//RIFF_WAVE_Chunk(文件头,12个字节)+
//Format_Chunk(声音内容定义,根据第16到20个字节得到剩下区块大小,16或者18个字节)+
//Data_Chunk(数据区)
dataFileBeginIndex = formatSize + 20 + 4;
bInfoList.Add(bInfo);
fileSizeList.Add(System.BitConverter.ToInt32(bInfo, 4));
dataSizeList.Add(System.BitConverter.ToInt32(bInfo, dataFileBeginIndex));
}
//计算所有WAV文件大小
int fileSize = 0;
foreach (int fSize in fileSizeList)
{
fileSize += fSize;
}
byte[] totalFileSize = System.BitConverter.GetBytes(fileSize);
//计算所有WAV数据大小
int dataSize = 0;
foreach (int dSize in dataSizeList)
{
dataSize += dSize;
}
byte[] totalDataSize = System.BitConverter.GetBytes(dataSize);
using (Stream toFile = new MemoryStream())
{
//Stream toFile = new MemoryStream();
BinaryWriter bWriter = new BinaryWriter(toFile);
//获取最后一个wav文件的详细内容
int lastWaveFile = pPlayStreamsList.Count - 1;
for (int i = 4, j = 0; i < 8; i++, j++)
{
bInfoList[lastWaveFile][i] = totalFileSize[j];
}
for (int i = dataFileBeginIndex, j = 0; i < dataFileBeginIndex + 4; i++, j++)
{
bInfoList[lastWaveFile][i] = totalDataSize[j];
}
bWriter.Write(bInfoList[lastWaveFile]);
int k = 0;
foreach (Stream fs in pPlayStreamsList)
{
int readLength;
fs.Position = dataFileBeginIndex + 4;
if (k < dataSizeList.Count)
{
readLength = dataSizeList[k] - 40;
byte[] dushu = new byte[readLength];
fs.Read(dushu, 0, readLength);
bWriter.Write(dushu, 0, readLength);
k++;
}
}
SoundPlayer player = new SoundPlayer();
if (toFile != null)
{
player.Stream = null;
player.Stream = toFile;
toFile.Position = 0;
player.LoadAsync();
for (int i = 0; i < playTimes; i++)
{ player.PlaySync(); }
}
bWriter.Flush();
bWriter.Close();
toFile.Flush();
toFile.Close();
player.Dispose();
bWriter.Dispose();
toFile.Dispose();
}
}
}
catch (Exception e)
{
LogInfo.saveLog("合并语音流报错,方法MergeAndPlayWavFile():" + e.Message);
}
}
C# wav语音文件合并的更多相关文章
- [Audio processing] wav音频文件合并
合并多个文件,需要包含1.文件读取和写入功能,2.数组合并 package com.audioprocessingbox.myfunc; import java.io.File; import jav ...
- 多个wav音频文件合并(连接)成一个文件
场景:一段声音从浏览器麦克风缓冲上一段一段发给服务器,按照时间戳生成很多文件. 目的:把他们按时间顺序连到一个时间轴上. 命令如下: ffmpeg -f concat -i list.txt out. ...
- Python网页正文转换语音文件的操作方法
天气真的是越来越冷啦,有时候我们想翻看网页新闻,但是又冷的不想把手拿出来,移动鼠标翻看.这时候,是不是特别想电脑像讲故事一样,给我们念出来呢?人生苦短,我有python啊,试试用 Python 来朗读 ...
- WAV格式文件无损合并&帧头数据体解析(python)(原创)
一,百度百科 WAV为微软公司(Microsoft)开发的一种声音文件格式,它符合RIFF(Resource Interchange File Format)文件规范,用于保存Windows平台的音频 ...
- C# 使用NAudio合并mp3、wav音频文件
1.什么是wav格式 WAV为微软公司(Microsoft)开发的一种声音文件格式,它符合RIFF(Resource Interchange File Format)文件规范,用于保存Windo ...
- asp.net使用SpeechSynthesizer类生成语音文件部署到iis遇到的几个坑
首先需要引入命名空间System.Speech.Synthesis,代码如下: using (var speechSyn = new SpeechSynthesizer()) { speechSyn. ...
- 解析WAV音频文件----》生成WAV音频文件头
前言:请各大网友尊重本人原创知识分享,谨记本人博客:南国以南i WAV音频文件介绍: WAV文件是在PC机平台上很常见的.最经典的多媒体音频文件,最早于1991年8月出现在Windows3.1操作系统 ...
- CDN的combo技术能把多个资源文件合并引用,减少请求次数
CDN的combo技术能把多个资源文件合并引用,减少请求次数.比如淘宝的写法: <link rel="stylesheet" href="//g.alicdn.co ...
- linux 两个文件合并
可以使用cat命令,有两种实现的方式,一种将两个文件合并的到一个新的文件,另一种将一个文件追加到另一个文件的末尾. 方法一:使用cat命令从文件中读入两个文件,然后将重定向到一个新的文件.这种方法可以 ...
随机推荐
- AJAX入门第一篇就够了
什么是Ajax Ajax(Asynchronous JavaScript and XML) 异步JavaScript和XML Ajax实际上是下面这几种技术的融合: (1)XHTML和CSS的基于标准 ...
- 对Javascript到底了解多少,一测便知道
笔者在这里附上一段代码,请读者思考一下程序的运行结果: console.log(a); //??? a(); var a=3; function a(){ console.log(10); } con ...
- JSONP && CORS
前天面试被问到了跨域的问题,自我感觉回答的并不理想,下面我就分享一下整理后的总结分享给大家 一.为什么要跨域 安全限制 JavaScript或Cookie只能访问同域下的内容——同源策略 同源策略 下 ...
- vi代码智能提示功能及相关配置
vim是一款支持插件.功能无比强大的编辑器,无论你的系统是linux.unix.mac还是windows,都能够选择他来编辑文件或是进行工程级别 的coding.如果能把vim用好了,不仅编程效率能得 ...
- 安装gitlab8.0在reconfigure报错
现象: https://gitlab.com/gitlab-org/omnibus-gitlab/issues/303 参考方法: https://forum.gitlab.com/t/gitlab- ...
- TKCPP
volume one: http://book.huihoo.com/thinking-in-cpp-2nd-ed-vol-one/ volume2 : http://book.huihoo.com/ ...
- 12小时格式Xcode的-在一个“TimePicker”24 NSDate的设置
我正在使用的NSDate对象,和好了,我的iPhone与24小时格式,所以当我在测试我的应用程序,一切正常,但是,我的一个朋友试图在他的iPhone上的应用程序 CodeGo.net,但12小时格式, ...
- python进阶学习笔记(一)
python进阶部分要学习的内容: 学习目标: 1.函数式编程 1.1,什么是函数式编程 函数式编程是一种抽象计算的编程模式 不同语言的抽象层次不同: 函数式编程的特点: python支持的函数式编程 ...
- FreeImage库如何转换图片格式?
FreeImage下载地址:http://freeimage.sourceforge.net/ //freeimagemain.h #ifndef FREEIMAGEMAIN_H #define FR ...
- UVA - 11636 Hello World! (贪心)
思路:复制次数最少并且可以部分复制,那么贪心地让当前尽量多的复制,如果最后一次复制会超过n,那就部分复制.即满足并且x尽量小. AC代码 #include <stdio.h> const ...