Я пытаюсь преобразовать наше приложение в раскадровки и попал в то, что, по моему мнению, является ошибкой при обработке развязанных сегментов при работе с пользовательскими контроллерами контейнеров. У нас есть контроллер представлений, который отображает другой, и для этого используется оболочка управления view view, я подключаю segue в IB, затем выбираю пользовательский класс для реализации. Метод выполнения выглядит примерно так:
-(void) perform {
UIViewController *container = [self sourceViewController];
UIViewController *child = [self destinationViewController];
[container addChildViewController:child];
[container.view addSubview:child.view];
child.view.center = container.view.center;
[UIView transitionWithView:container.view
duration:0.35
options:UIViewAnimationOptionCurveEaseInOut
animations:^{
child.view.alpha = 1;
} completion:^(BOOL finished) {
[child didMoveToParentViewController:container];
}];
}
Это работает отлично, однако я не могу заставить его выполнить разматывание назад к контроллеру контейнера. Я переопределяю viewControllerForUnwindSegueAction: fromViewController: withSender: и убедитесь, что он возвращает правильное значение:
-(UIViewController *) viewControllerForUnwindSegueAction:(SEL)action fromViewController:(UIViewController *)fromViewController withSender:(id)sender {
id default = [super viewControllerForUnwindSegueAction:action fromViewController:fromViewController withSender:sender];
NSAssert1(default == self, @"Expected the default view controller to be self but was %@", default);
return default;
}
Я также могу подтвердить, что canPerformUnwindSegueAction: fromViewController: withSender вызывается и делает правильную вещь, но, чтобы быть уверенным, что он переназначил его, чтобы вернуть YES
-(BOOL) canPerformUnwindSegueAction:(SEL)action fromViewController:(UIViewController *)fromViewController withSender:(id)sender {
return YES;
}
Следующим шагом, который я ожидал бы, будет для segueForUnwindingToViewController: fromViewController: identifier: для вызова, однако это никогда не будет. Вместо этого приложение выходит из строя с помощью исключения NSInternalInconsistencyException.
2012-10-01 10:56:33.627 UnwindSegues[12770:c07] *** Assertion failure in -[UIStoryboardUnwindSegueTemplate _perform:], /SourceCache/UIKit_Sim/UIKit-2372/UIStoryboardUnwindSegueTemplate.m:78
2012-10-01 10:56:33.628 UnwindSegues[12770:c07] *** Terminating app due to uncaught exception 'NSInternalInconsistencyException', reason: 'Could not find a view controller to execute unwinding for <USCustomContainerViewController: 0x75949a0>'
*** First throw call stack:
(0x1c8e012 0x10cbe7e 0x1c8de78 0xb61f35 0x581711 0x45ab54 0x10df705 0x16920 0x168b8 0xd7671 0xd7bcf 0xd6d38 0x4633f 0x46552 0x243aa 0x15cf8 0x1be9df9 0x1be9ad0 0x1c03bf5 0x1c03962 0x1c34bb6 0x1c33f44 0x1c33e1b 0x1be87e3 0x1be8668 0x1365c 0x1e7d 0x1da5)
libc++abi.dylib: terminate called throwing an exception
Кто-нибудь успешно использовал unind segues в сочетании с API-интерфейсами API-интерфейса контроллера? Любая идея, какой шаг мне не хватает? Я загрузил демонстрационный проект в github, который показывает проблему в простейшем демонстрационном проекте, который я мог бы придумать.