Я пытаюсь воспроизвести файл MP3, который передается в UIView из предыдущего UIView (сохраняется в переменной NSURL *fileURL).
Я инициализирую AVPlayer с помощью:
player = [AVPlayer playerWithURL:fileURL];
NSLog(@"Player created:%d",player.status);
NSLog печатает Player created:0,, который, как я понял, означает, что он еще не готов играть.
Когда я нажимаю кнопку воспроизведения UIButton, я запускаю код:
-(IBAction)playButtonClicked
{
NSLog(@"Clicked Play. MP3:%@",[fileURL absoluteString]);
if(([player status] == AVPlayerStatusReadyToPlay) && !isPlaying)
// if(!isPlaying)
{
[player play];
NSLog(@"Playing:%@ with %d",[fileURL absoluteString], player.status);
isPlaying = YES;
}
else if(isPlaying)
{
[player pause];
NSLog(@"Pausing:%@",[fileURL absoluteString]);
isPlaying = NO;
}
else {
NSLog(@"Error in player??");
}
}
Когда я запускаю это, я всегда получаю Error in player?? в консоли.
Если я, однако, заменил условие if, которое проверяет, готова ли игра AVPlayer, с простым if(!isPlaying)..., тогда музыка воспроизводит ВТОРОЕ ВРЕМЯ Я нажимаю кнопку воспроизведения UIButton.
Журнал консоли:
Clicked Play. MP3:http://www.nimh.nih.gov/audio/neurogenesis.mp3
Playing:http://www.nimh.nih.gov/audio/neurogenesis.mp3 **with 0**
Clicked Play. MP3:http://www.nimh.nih.gov/audio/neurogenesis.mp3
Pausing:http://www.nimh.nih.gov/audio/neurogenesis.mp3
Clicked Play. MP3:http://www.nimh.nih.gov/audio/neurogenesis.mp3
2011-03-23 11:06:43.674 Podcasts[2050:207] Playing:http://www.nimh.nih.gov/audio/neurogenesis.mp3 **with 1**
Я вижу, что SECOND TIME, player.status, кажется, содержит 1, что, я думаю, AVPlayerReadyToPlay.
Что я могу сделать, чтобы игра правильно работала в первый раз, когда я нажимаю кнопку воспроизведения UIButton?
(т.е. как я могу убедиться, что AVPlayer не только создан, но также готов к воспроизведению?)