Это то, что я делаю сейчас:Как реализовать UIViewControllerTransitioningDelegate в UIStoryboardSegue?
func presentOverlayController(controller: UIViewController) {
controller.modalPresentationStyle = .Custom
controller.transitioningDelegate = self
presentViewController(controller, animated: true, completion: nil)
}
//MARK: - UIViewControllerTransitioningDelegate
public func presentationControllerForPresentedViewController(presented: UIViewController, presentingViewController presenting: UIViewController, sourceViewController source: UIViewController) -> UIPresentationController? {
return OverlayPresentationController(presentedViewController: presented, presentingViewController: presenting)
}
Он работает довольно удивительным. Сначала я получаю контроллер из раскадровки, используя .instantiateViewControllerWithIdentifier:
. Контроллер представлен правильный путь:
Но тот же результату, мне нужно, чтобы достичь с моим пользовательским Segue:
class OverlaySegue: UIStoryboardSegue, UIViewControllerTransitioningDelegate {
override func perform() {
destinationViewController.modalPresentationStyle = .Custom
destinationViewController.transitioningDelegate = self
}
//MARK: - UIViewControllerTransitioningDelegate
func presentationControllerForPresentedViewController(presented: UIViewController, presentingViewController presenting: UIViewController, sourceViewController source: UIViewController) -> UIPresentationController? {
return OverlayPresentationController(presentedViewController: presented, presentingViewController: presenting)
}
}
, но он не работает. Зачем?
Конечно, как я мог забыть об этом? –