参考博客:
每个ADTS frame之间通过0xFFF(二进制“111111111111”)分割。
上图为ACC数据:蓝框为需要分析数据
1. 红框为分割符-----0xFFF
2. 紧跟着的50是一个16进制的表示-------0x50,其二进制位1010000,通过下面的计算取得ACC的profile
// 0xC0------11000000
// 假如, aacframe[2]=0x50;
// 取前两位,eg 01010000 & 0xC0 =01000000
unsigned char profile=aacframe[2]&0xC0;
// 右移6位,01000000 >> 6 =01(转换为10进制为1)
profile=profile>>6;
switch(profile){
case 0: sprintf(profile_str,"Main");break;
case 1: sprintf(profile_str,"LC");break;
case 2: sprintf(profile_str,"SSR");break;
default:sprintf(profile_str,"unknown");break;
}
3. 同上面算法,取0x50的中间4位,然后向右移2位,获得ACC的采样率。
// 0x3C------00111100
unsigned char sampling_frequency_index=aacframe[2]&0x3C;
sampling_frequency_index=sampling_frequency_index>>2;
switch(sampling_frequency_index){
case 0: sprintf(frequence_str,"96000Hz");break;
case 1: sprintf(frequence_str,"88200Hz");break;
case 2: sprintf(frequence_str,"64000Hz");break;
case 3: sprintf(frequence_str,"48000Hz");break;
case 4: sprintf(frequence_str,"44100Hz");break;
......
default:sprintf(frequence_str,"unknown");break;
}
4.最后三个字节通过下面的计算取得一个ACC的长度(eg,80,2E,7F,经过该计算该ACC有371个字节的数据,包括了蓝框 中的字节数)
//判断是不是0xFFF开头
if((buffer[0] == 0xff) && ((buffer[1] & 0xf0) == 0xf0) ){
// 取出ACC长度size
//eg buffer[3]=0x80-------10000000
// 0x03------00000011
size |= ((buffer[3] & 0x03) <<11); //high 2 bit
//size = 0
//eg buffer[4]=0x2E-------00101110
// buffer[4]<<3--------101110000 =(int)368
size |= buffer[4]<<3; //middle 8 bit
//size =368
//eg buffer[5]=0x7F-------01111111
// buffer[5] & 0xe0-----01100000
// (buffer[5] & 0xe0)>>5-----011 =(int)3
// 0xe0------11100000
size |= ((buffer[5] & 0xe0)>>5); //low 3bit
//size-----101110011=(int)371
break;
}