AVAudioEngine: нет звука

Я пытаюсь протестировать AVAudioEngine, смотрел конференции WWDC по этому поводу и делал все по инструкции, чтобы попытаться воспроизвести простой файл.

Несмотря на то, что все точно так же, как в образцах, которые я нашел (WWDC и несколько других мест), несмотря на то, что все выглядит нормально (нет ошибок, кажется работает), у меня нет звука.

Вот код:

NSError *error = Nil;

[AVAudioSession.sharedInstance setCategory:AVAudioSessionCategoryPlayback withOptions:AVAudioSessionCategoryOptionMixWithOthers error: &error];
[AVAudioSession.sharedInstance setActive:YES error:&error];

AVAudioEngine *engine = [[AVAudioEngine alloc] init];

AVAudioPlayerNode *player = [[AVAudioPlayerNode alloc] init];
[engine attachNode:player];

NSURL *fileURL = [[NSBundle mainBundle] URLForResource:@"piano" withExtension:@"wav"];
AVAudioFile *file = [[AVAudioFile alloc] initForReading:fileURL error:&error];

AVAudioMixerNode *mainMixer = [engine mainMixerNode];
AVAudioOutputNode *outputNode = engine.outputNode;

[engine connect:player to:mainMixer format:file.processingFormat];
[engine connect:engine.mainMixerNode to:outputNode format:nil];
[engine prepare];

if (!engine.isRunning) {
    if (![engine startAndReturnError:&error]) {
        //TODO
    }
}

[player scheduleFile:file atTime:nil completionHandler:nil];
[player play];

NSLog(@"Engine description: %@", [engine description]);

Вот результат вызова журнала:

Engine description: 
________ GraphDescription ________
AVAudioEngineGraph 0x10100d820: initialized = 1, running = 1, number of nodes = 3

     ******** output chain ********

     node 0x28388d200 {'auou' 'rioc' 'appl'}, 'I'
         inputs = 1
             (bus0, en1) <- (bus0) 0x2838a0880, {'aumx' 'mcmx' 'appl'}, [ 2 ch,  44100 Hz, 'lpcm' (0x00000029) 32-bit little-endian float, deinterleaved]

     node 0x2838a0880 {'aumx' 'mcmx' 'appl'}, 'I'
         inputs = 1
             (bus0, en1) <- (bus0) 0x282a8df00, {'augn' 'sspl' 'appl'}, [ 2 ch,  44100 Hz, 'lpcm' (0x00000029) 32-bit little-endian float, deinterleaved]
         outputs = 1
             (bus0, en1) -> (bus0) 0x28388d200, {'auou' 'rioc' 'appl'}, [ 2 ch,  44100 Hz, 'lpcm' (0x00000029) 32-bit little-endian float, deinterleaved]

     node 0x282a8df00 {'augn' 'sspl' 'appl'}, 'I'
         outputs = 1
             (bus0, en1) -> (bus0) 0x2838a0880, {'aumx' 'mcmx' 'appl'}, [ 2 ch,  44100 Hz, 'lpcm' (0x00000029) 32-bit little-endian float, deinterleaved]
______________________________________

Я понятия не имею, как это диагностировать, и не могу найти ни одной ошибки или причины, по которой это не сработает.

Есть идеи?


person Stéphane    schedule 18.01.2021    source источник
comment
Может быть, это поможет вам? stackoverflow.com/questions/54670067/avaudioengine-no-sound   -  person koen    schedule 18.01.2021


Ответы (1)


Сохраняю вопрос на случай, если у кого-то возникнет эта проблема: когда я тестировал, все мои переменные были локальными переменными в тестовом методе, и как только метод был завершен, вероятно, это был GC с помощью ARC или что-то в этом роде.

Наличие внешней переменной AVAudioEngine (сохранение ссылки на нее) исправило это.

person Stéphane    schedule 18.01.2021