Я пытаюсь воспроизвести файл 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**
Я вижу, что ВТОРОЕ ВРЕМЯ, player.status
, кажется, содержит 1, что, я думаю, AVPlayerReadyToPlay
.
Что я могу сделать, чтобы игра работала правильно при первом нажатии на игру UIButton
?
(т.е. как я могу убедиться, что AVPlayer
не только создан, но и готов к игре?)