Специально для iOS 8.4: AVPlayer не воспроизводит видео и аудио и нет ошибок

РЕДАКТИРОВАТЬ: протестировано и в симуляторе 8.3, та же проблема.

У меня есть приложение, которое отлично работает в iOS 9.0 и выше (все версии). Однако для iOS 8.4 AVPlayer ничего не воспроизводит. Нет аудио и видео.

Встречается как на iPad, так и на iPhone.

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

Я также проверил свойство ошибки avplayer, и оно везде равно нулю.

- (void)observeValueForKeyPath:(NSString *)keyPath ofObject:(id)object
                        change:(NSDictionary *)change context:(void *)context {
    if (object == ((AppDelegate*)[[UIApplication sharedApplication] delegate]).avplayer) {
        if ( [keyPath isEqualToString:@"status"]) {
            NSLog(@"Status changed: %@, %@",change,((AppDelegate*)[[UIApplication sharedApplication] delegate]).avplayer.error.localizedDescription);


        }
        else if ([keyPath isEqualToString:@"rate"] && ((AppDelegate*)[[UIApplication sharedApplication] delegate]).avplayer.status == AVPlayerStatusReadyToPlay ) {
            NSLog(@"Rate changed: %@",change);
        }
    }
}

Вывод:

2016-03-13 15:01:47.152 XXXXX[47910:2113657] Status changed: {
    kind = 1;
    new = 1;
}, (null)
2016-03-13 15:01:47.153 XXXXX[47910:2113567] Rate changed: {
    kind = 1;
    new = 1;
}
2016-03-13 15:01:47.160 XXXXX[47910:2113567] Rate changed: {
    kind = 1;
    new = 1;
}

person sudoExclaimationExclaimation    schedule 13.03.2016    source источник


Ответы (1)


Я исправил проблему, хотя я не уверен, почему это происходило в iOS 8, а не в iOS 9.

Завершение loadValuesAsynchronouslyForKeys не возвращалось в основной поток. Я проверил это, поставив [NSThread isMainThread], и заметил, что это ложь.

Я исправил это, переключившись на основной поток перед выполнением «replaceCurrentItemWithPlayerItem».

AVAsset *asset = [AVAsset assetWithURL:url];
        [asset loadValuesAsynchronouslyForKeys:@[@"duration"] completionHandler:^{
            NSLog(@"Main: %d",[NSThread isMainThread]);
            dispatch_async(dispatch_get_main_queue(), ^{
                AVPlayerItem *newItem = [[AVPlayerItem alloc] initWithAsset:asset];
                [((AppDelegate*)[[UIApplication sharedApplication] delegate]).avplayer replaceCurrentItemWithPlayerItem:newItem];
                [self addObserversToPlayer];
                [((AppDelegate*)[[UIApplication sharedApplication] delegate]).avplayer play];
            });
        }];
person sudoExclaimationExclaimation    schedule 13.03.2016