当音频的声道数多于一个时,音频数据的存放有两种格式,即交织的(interleave)和非交织的(non-interleave)。以最常见的双声道为例,交织和非交织的音频数据存放如下图:

上图中L表示左声道数据,R表示右声道数据,整数1、2等表示第几个采样点,这样L1就表示左声道的第一个采样点数据。从上图看出,所谓交织的是指一个采样点的两个声道的数据依次放在一起,非交织的是指先放左声道的所有采样点的数据,再放右声道的所有采样点的数据。
在音频处理时,有时需要交织的数据,而有时又需要非交织的数据,这样就存在两种数据格式之间的转换。本文就讲讲这两种数据格式转换的两种方法,第一种是常规的简单的方法,第二种是巧妙的省memory的方法。
1, 常规方法
1.1 interleave 转 non-interleave
先动态申请一块memory(大小等于采样点数),把右声道的数据放在这块动态申请的memory上,同时把左声道的数据放在原buffer的前一半。然后再把动态memory上的右声道的数据放到原buffer的后一半,这样就完成了interleave到non-interleave的转换。C语言的实现代码如下:

int interleave2noninterleave(short *buf, int count)
{
int i;
short *temp;
if(buf == NULL) {
printf("input point buf is NULL \n");

本文介绍音频数据在交织(interleave)和非交织(non-interleave)格式间的转换方法,包括常规和省memory的技巧,适用于不同硬件环境。
最低0.47元/天 解锁文章
430

被折叠的 条评论
为什么被折叠?



