开发者社区> 问答> 正文

关于PCM数据的混音计算

每个样本16bit
该怎么对两路语音进行混音呢?
我的算法很简单,就是让两路先分别除以二,再相加
比如,设两路数据存在ByteBuffer对象byteBuffer1、byteBuffer2里(capacity都为960),则

byteBuffer1.flip();
byteBuffer2.flip();
                
short[] sArray1 = new short[480];
short[] sArray2 = new short[480];
byte[] bArray = new byte[960];
byteBuffer1.asShortBuffer().get(sArray1);
byteBuffer2.asShortBuffer().get(sArray2);
for(int i = 0;i < 480; i++){
    int sumi = sArray1[i]/2 + sArray2[i]/2;
    short num = (short)sumi;
    bArray[i * 2] = (byte) (num >>> 8);
    bArray[i * 2 + 1] = (byte)num;
}

但是这样得到的混音后音频完全是噪音,使用Audition打开发现振幅都很大,推测为产生了溢出
第一路音频波形:
screenshot
第二路音频波形:
screenshot
混音后的音频波形:
screenshot
以上音频文件全部以little-edian方式打开,第一、二路音频播放没有问题
请问问题出在哪?该怎么修改呢?

展开
收起
蛮大人123 2016-02-22 13:49:06 4948 0
1 条回答
写回答
取消 提交回答
  • 我说我不帅他们就打我,还说我虚伪

    short型数据直接相加,再判断是否溢出,就是>32767 就等于32767 或 <-32768就等于-32768.

    2019-07-17 18:46:36
    赞同 展开评论 打赏
问答分类:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载