Пользовательская анимация UINavigationController

Я пытаюсь реализовать пользовательскую анимацию перехода вот что у меня есть

class NavDelegate: NSObject, UINavigationControllerDelegate {
    private let animator = Animator()

    func navigationController(_ navigationController: UINavigationController,
                              animationControllerFor operation: UINavigationControllerOperation,
                              from fromVC: UIViewController,
                              to toVC: UIViewController) -> UIViewControllerAnimatedTransitioning? {
        return animator
    }
}

class Animator: NSObject, UIViewControllerAnimatedTransitioning {
    func transitionDuration(using context: UIViewControllerContextTransitioning?) -> TimeInterval {
        return 10.0
    }

    func animateTransition(using context: UIViewControllerContextTransitioning) {
        let fromViewController = context.viewController(forKey: UITransitionContextViewControllerKey.from)!
        let toViewController = context.viewController(forKey: UITransitionContextViewControllerKey.to)!
        if fromViewController is ViewController {
            self.pushAnimation(from: fromViewController as! ViewController,
                               to: toViewController as! VC2ViewController,
                               with: context)
        }

        if toViewController is ViewController {
            print("pop")
        }

    }

    func pushAnimation(from viewController: ViewController,
                       to destinationViewController: VC2ViewController,
                       with context: UIViewControllerContextTransitioning) {

        context.containerView.addSubview(destinationViewController.view)


        //block 1
        for cell in viewController.tableView1.visibleCells {
            if let castCell = cell as? VC1TableViewCell {
                castCell.contentViewToLeft.constant = -UIScreen.main.bounds.width
                castCell.contentViewToRight.constant = UIScreen.main.bounds.width
                let duration = Double(viewController.tableView1.visibleCells.index(of: cell)!)/Double(viewController.tableView1.visibleCells.count) + 0.2
                UIView.animate(withDuration: duration, animations: {
                    castCell.layoutIfNeeded()
                }) { animated in
                }
            }
        }

        //block 2
        for cell in destinationViewController.tableView2.visibleCells {
            if let castCell = cell as? VC2TableViewCell {
                castCell.contentViewToLeft.constant = -UIScreen.main.bounds.width
                castCell.contentViewToRight.constant = UIScreen.main.bounds.width
                let duration = Double(destinationViewController.tableView2.visibleCells.index(of: cell)!)/Double(destinationViewController.tableView2.visibleCells.count) + 0.2
                UIView.animate(withDuration: duration, animations: {
                    castCell.layoutIfNeeded()
                }) { animated in
                    if duration > 1.1 {
                        context.completeTransition(!context.transitionWasCancelled)
                    }
                }
            }
        }
    }
}

Проблема в том, что анимация ограничений контроллера назначения (блок 2) никогда не анимируется, layoutIfNeeded() выполняется без анимации, хотя блок 1 работает. В чем может быть проблема?

1 ответ

Решение

Я потратил пару дней на тестирование

transitionDuration(using context: UIViewControllerContextTransitioning?)

и узнайте, что это все о вызове некоторых блоков toViewController анимации внутри DispatchQueue.main.async {}, Не уверен, как это работает, но я заставил свой код работать так, как планировал.

Другие вопросы по тегам