Настройки записи звука в iPhone, похоже, не работают - PullRequest
0 голосов
/ 04 ноября 2011

При настройке частоты дискретизации в аудиозаписи кажется, что, хотя IOS говорит, что это дискретизация на 8000k, она, похоже, возвращает данные для 44100k. Это из IOS 5 iPHone, но то же самое происходит на IOS 4.x

Кодовые части следующие:

 NSLog(@"Requested Sample Rate is %f",F64sampleRate);            
 u.propertyResult = AudioSessionSetProperty (  kAudioSessionProperty_PreferredHardwareSampleRate ,sizeof(F64sampleRate) , &F64sampleRate );
 NSLog(@"Set Error Set Sample Rate %ld %lx %c%c%c%c",u.propertyResult,u.propertyResult,u.a[3],u.a[2],u.a[1],u.a[0]);

 u.propertyResult = AudioSessionGetProperty ( kAudioSessionProperty_CurrentHardwareSampleRate , &F64datasize, &F64realSampleRate );
 NSLog(@"Set Error Get Sample Rate %ld %lx %c%c%c%c",u.propertyResult,u.propertyResult,u.a[3],u.a[2],u.a[1],u.a[0]);
 NSLog(@"Sample Rate is %f",F64realSampleRate);

Вывод отладки выглядит следующим образом

2011-11-04 09:57:46.003 MyCode[634:707] Set Error Get Sample Rate 0 0 
2011-11-04 09:57:46.063 MyCode[634:707] Sample Rate is 8000.000000
2011-11-04 09:57:46.067 MyCode[634:707] Requested Sample Rate is 8000.000000
2011-11-04 09:57:46.085 MyCode[634:707] Set Error Set Sample Rate 0 0 
2011-11-04 09:57:46.105 MyCode[634:707] Set Error Get Sample Rate 0 0 
2011-11-04 09:57:46.109 MyCode[634:707] Sample Rate is 8000.000000
2011-11-04 09:57:46.112 MyCode[634:707] Sample Rate Will Be 8000
2011-11-04 09:57:46.115 MyCode[634:707] Set Error Get Property 0 0 
2011-11-04 09:57:46.119 MyCode[634:707] Category 1919247201 72656361 reca
2011-11-04 09:57:46.122 MyCode[634:707] Set Error Get Sample Rate 0 0 
2011-11-04 09:57:46.126 MyCode[634:707] IO Buffer Duration is 0.023000

Обратные вызовы данных следующие, обратите внимание на длину буфера, игнорируйте другие номера.

 2011-11-04 09:57:47.808 MyCode[634:707] buffsize 16000, bytesleftinbuffer 16000, bytestocopy 2048, bufferlength 2048
 2011-11-04 09:57:47.812 MyCode[634:707] buffsize 16000, bytesleftinbuffer 13952, byte stocopy 2048, bufferlength 2048
 2011-11-04 09:57:47.818 MyCode[634:707] buffsize 16000, bytesleftinbuffer 11904, bytestocopy 2048, bufferlength 2048
 2011-11-04 09:57:47.824 MyCode[634:707] buffsize 16000, bytesleftinbuffer 9856, bytestocopy 2048, bufferlength 2048
 2011-11-04 09:57:47.829 MyCode[634:707] buffsize 16000, bytesleftinbuffer 7808, bytestocopy 2048, bufferlength 2048
 2011-11-04 09:57:47.834 MyCode[634:707] buffsize 16000, bytesleftinbuffer 5760, bytestocopy 2048, bufferlength 2048
 2011-11-04 09:57:47.839 MyCode[634:707] buffsize 16000, bytesleftinbuffer 3712, bytestocopy 2048, bufferlength 2048
 2011-11-04 09:57:47.843 MyCode[634:707] buffsize 16000, bytesleftinbuffer 1664, bytestocopy 1664, bufferlength 2048

Итак, давайте сделаем некоторые вычисления здесь ...

Время обратного вызова буфера (время выборки) составляет 0,023 с или примерно 43,5 раза в секунду

  • Это подтверждается временем отладки и информацией о свойствах get

Размер выборки обратного вызова буфера равен 1024 (короткий, поэтому общий размер буфера равен 2048)

То есть 1024 * 43 = 44032 близко к 44100

Итак, если я что-то здесь не упустил, хотя IOS говорит, что он на 8000k, он, похоже, перезванивает с 44100k.

У кого-нибудь есть опыт?

...