2017-10-13 10 views
0

J'ai ce VC où je joue une connexion vidéo de fond. les deux boutons en tant que prises déclenchent un Seise UIStoryboard Push directement à partir du storyboard. Ce que je veux accomplir est: une fois que je vais à l'un des VC de la section, le VC de connexion vidéo vise à éviter d'autres cycles de rétention une fois que je reviens à cela avec le flux normal de mon application.ViewController n'appelant pas la méthode deinit swift 4

merci d'avance.

@IBOutlet weak var loginButton: UIButton! 
@IBOutlet weak var registerButton: UIButton! 
weak var avPlayer: AVPlayer! 
weak var avPlayerLayer: AVPlayerLayer! 

override func viewDidLoad() { 
    super.viewDidLoad() 
    // Do any additional setup after loading the view, typically from a nib. 

    self.loginButton = Util.roundBorderButton(button: self.loginButton, color: UIColor.white.cgColor, radius: 5, width: 1) 
    self.registerButton = Util.roundBorderButton(button: self.registerButton, color: UIColor.white.cgColor, radius: 5, width: 1) 

    if let resourceUrl = Bundle.main.url(forResource: "porsche-trimmed", withExtension: "mp4") { 
     if FileManager.default.fileExists(atPath: resourceUrl.path) { 

      avPlayer = AVPlayer(url: resourceUrl) 
      avPlayerLayer = AVPlayerLayer(player: avPlayer) 
      avPlayerLayer.videoGravity = AVLayerVideoGravity.resizeAspectFill 
      avPlayer.volume = 0 
      avPlayer.actionAtItemEnd = .none 

      avPlayerLayer.frame = view.layer.bounds 
      view.backgroundColor = .clear 
      view.layer.insertSublayer(avPlayerLayer, at: 0) 

      NotificationCenter.default.addObserver(self, 
                selector: #selector(playerItemDidReachEnd(notification:)), 
                name: NSNotification.Name.AVPlayerItemDidPlayToEndTime, 
                object: avPlayer.currentItem) 
     } 
    } 
} 

@objc func playerItemDidReachEnd(notification: Notification) { 
    let p: AVPlayerItem = notification.object as! AVPlayerItem 
    p.seek(to: kCMTimeZero, completionHandler: nil) 
} 

override func viewDidAppear(_ animated: Bool) { 
    super.viewDidAppear(animated) 
    avPlayer.play() 
} 

override func prepare(for segue: UIStoryboardSegue, sender: Any?) { 
    NotificationCenter.default.removeObserver(self) 
} 

deinit { 
    print("deinit video") 
} 

override func didReceiveMemoryWarning() { 
    super.didReceiveMemoryWarning() 
    // Dispose of any resources that can be recreated. 
} 
+0

"pour éviter d'autres cycles de retenue" Que !? Comment l'appel deinit conduit-il à éviter les cycles de retenue? Si vous dites "plus loin", où cela se produit-il? –

Répondre

0

Peut-être que le centre de notifications conserve votre contrôleur? Essayez de commenter l'abonnement à la notification et voyez si le problème disparaît. Si c'est le cas, choisissez un endroit approprié (viewWillDisappear?) Pour vous désabonner.

0

Cas 1:

Essayez d'écrire NotificationCenter.default.removeObserver(self) ligne override func viewWillDisappear(_ animated: Bool). Peut être le centre de notification vous conservant l'objet viewController.

Cas 2: Si vous naviguez depuis votre automate à l'aide de Segue, UIStoryboardSegue vous permet de conserver l'objet viewController en tant que sourceController source. Dans ce cas aussi, le premier cas peut résoudre votre problème.