Я пытаюсь воспроизвести файл 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
не только создан, но также готов к воспроизведению?)