AVPlayer not synchronized

I’m really out of ideas so I’ll have to ask you guys again…

I’m building an iPhone application which uses three instances of AVPlayer. They all play at the same time and it’s very important that they do so. I used to run this code:

  • Write array of floats to a wav audio file in swift
  • AVPlayerItemDidPlayToEndTime notification not working on iOS 11
  • m3u8 file AVAssetImageGenerator error
  • How to play movie files with no file extension on iOS with MPMoviePlayerController or AVPlayer?
  • AVPlayer stop UIActivityIndicator before playing
  • reading samples with AVAssetReader and timeRange in real time
  • CMClockRef syncTime = CMClockGetHostTimeClock();
    CMTime hostTime = CMClockGetTime(hostTime);
    [self.playerOne setRate:1.0f time:kCMTimeInvalid atHostTime:hostTime];
    [self.playerTwo setRate:1.0f time:kCMTimeInvalid atHostTime:hostTime];
    [self.playerThree setRate:1.0f time:kCMTimeInvalid atHostTime:hostTime];

    which worked perfectly. But a few days ago it just stopped working, the three players are delayed by about 300-400ms (which is way to much, everything under 100ms would be okay). Two of these AVPlayer have some Audio processing, which takes some time more than the “normal” AVPlayer, but it used to work before and the currentTime property tells me, that these players are delayed, so the syncing seems to fail.

    I have no idea why it stopped working, I didn’t really changed something, but I’m using an observer where i can ask the self.playerX.currentTime property, which gives me a delay of about .3-.4 seconds… I already tried to resync the players if delay>.1f but the delay is still there. So I think the audio processing of player1 and 2 can’t be responsable for the delay, as the currentTime property does know they are delayed (i hope you know what I mean). Maybe someone of you guys know why I’m having such a horrible delay, or is able to provide me another idea.

    Thanks in advance!

    Solutions Collect From Internet About “AVPlayer not synchronized”

    So, I found the solution. I forgot to [self.playerX prerollAtRate:]. I thought if the observer is AVPlayerReadyToPlay it means, that the player is “really” ready. In fact, it does not. After AVPlayer is readyToPlay, it has to be pre rolled. Once that is done you can sync your placer. The delay is now somewhere at 0.000006 seconds.