PCM数据格式

1. 8 Bit 单声道:  

1. 8 Bit 单声道:

采样1采样2
数据1数据2

2. 8 Bit 双声道

采样1采样2
声道1数据1声道2数据1声道1数据2声道2数据2

1. 16 Bit 单声道:

采样1采样2
数据1低字节数据1高字节数据2低字节数据2高字节

2. 16 Bit 双声道

采样1 
声道1数据1低字节声道1数据1高字节声道2数据1低字节声道2数据1高字节
采样2   
声道1数据2低字节声道1数据2高字节声道2数据2低字节声道2数据2高字节



对于ffmpeg来说,音频数据会保存在AVFrame中extended_data数组中,如果是打包模式(packed),就只用extended_data[0],如果是planar模式,则每个channel分别保存在extended_data[i]中。对于音频,只有linesize[0]有效,打包模式保存整个音频帧的buff大小,planar模式保存每个channel的buff大小。

ffmpeg中对两种模式(planar和packed)的说明(在frame.h文件中有详细说明):

     * For planar audio, each channel has a separate data pointer, and
     * linesize[0] contains the size of each channel buffer.
     * For packed audio, there is just one data pointer, and linesize[0]
     * contains the total size of the buffer for all channels.


下面是一个小例子来存储格式数据(利用ffmpeg):




short *sample_buffer_L = pFrame->extended_data[0];//存放着左声道的数据
short *sample_buffer_R = pFrame->extended_data[1];//存放着右声道的数据

两者都是16bit,而裸的PCM文件里的数据是按照 LRLRLRLR  这样存储的,所以我们需要按照这种格式存储16bit的数据:

//Left channel
data[i] = (char)(sample_buffer_L[j] & 0xff);//左声道低8位
data[i+1] = (char)((sample_buffer_L[j]>>8) & 0xff);;//左声道高8位
//Right channel
data[i+2] = (char)(sample_buffer_R[j] & 0xff);//右声道低8位
data[i+3] = (char)((sample_buffer_R[j]>>8) & 0xff);;//声道高8位


PCM一帧多少字节:

Somehow i remember that normally 2048 samples refer as a frame. PCM data generally is PCM16, that means one sample is 2 bytes, so one frame is 4096 bytes.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值