Parâmetro inválido exceção lançada pelo _UIQueuingScrollView
-
20-12-2019 - |
Pergunta
Meu aplicativo que contém um UITableViewController incorporado em UIPageViewController levanta esta excepção do tempo:
Invalid parameter not satisfying: [views count] == 3
Backtrace:
* thread #1: tid = 0x6239fa, 0x03d1d88a libobjc.A.dylib`objc_exception_throw, queue = 'com.apple.main-thread, stop reason = breakpoint 25.3
frame #0: 0x03d1d88a libobjc.A.dylib`objc_exception_throw
frame #1: 0x0404f448 CoreFoundation`+[NSException raise:format:arguments:] + 136
frame #2: 0x03428fee Foundation`-[NSAssertionHandler handleFailureInMethod:object:file:lineNumber:description:] + 116
frame #3: 0x01e7c535 UIKit`-[_UIQueuingScrollView _replaceViews:updatingContents:adjustContentInsets:animated:] + 185
frame #4: 0x01e800ca UIKit`-[_UIQueuingScrollView _didScrollWithAnimation:force:] + 1231
frame #5: 0x01e7bb57 UIKit`-[_UIQueuingScrollView _scrollViewAnimationEnded:finished:] + 104
frame #6: 0x0190583c UIKit`-[UIScrollView(UIScrollViewInternal) animator:stopAnimation:fraction:] + 62
frame #7: 0x0197096e UIKit`-[UIAnimator stopAnimation:] + 533
frame #8: 0x0197100a UIKit`-[UIAnimator(Static) _advanceAnimationsOfType:withTimestamp:] + 325
frame #9: 0x01970b76 UIKit`-[UIAnimator(Static) _LCDHeartbeatCallback:] + 67
frame #10: 0x01663b8a QuartzCore`CA::Display::DisplayLinkItem::dispatch() + 48
frame #11: 0x01663a46 QuartzCore`CA::Display::DisplayLink::dispatch_items(unsigned long long, unsigned long long, unsigned long long) + 310
frame #12: 0x01663f6b QuartzCore`CA::Display::TimerDisplayLink::callback(__CFRunLoopTimer*, void*) + 123
frame #13: 0x0400dbd6 CoreFoundation`__CFRUNLOOP_IS_CALLING_OUT_TO_A_TIMER_CALLBACK_FUNCTION__ + 22
frame #14: 0x0400d5bd CoreFoundation`__CFRunLoopDoTimer + 1181
frame #15: 0x03ff5628 CoreFoundation`__CFRunLoopRun + 1816
frame #16: 0x03ff4ac3 CoreFoundation`CFRunLoopRunSpecific + 467
frame #17: 0x03ff48db CoreFoundation`CFRunLoopRunInMode + 123
frame #18: 0x0533b9e2 GraphicsServices`GSEventRunModal + 192
frame #19: 0x0533b809 GraphicsServices`GSEventRun + 104
frame #20: 0x01874d3b UIKit`UIApplicationMain + 1225
Alguém já viu isso ou já tem uma idéia do que a razão poderia ser?
Solução
Editar:depois de utilizar esta correcção se por mais tempo, eu ainda posso ver o erro na ocasião, então esta não é a correção completa (bem...ele sempre foi uma espécie de hack).Eu vou atualizar com a solução real uma vez eu vou encontrá-lo.
Eu encontrei esse mesmo erro usando UIPageViewController.Depois de horas de depuração o problema, eu descobri que a causa estava usando a uiview animações dentro do manipulador de conclusão de UIPageViewController do setViewControllers:direção:animação:conclusão:.
Eu não sei por que a animação em que fase faz com que o erro de asserção (eu não estava animando o UIPageViewController ou seu filho ler controladores), mas quebra o bloco de código com dispatch_async na fila principal resolve o problema e parar a queda.
Outras dicas
Eu vi isso falhar quando tentar programaticamente transição para uma nova página.Uma resposta que fazia sentido para mim é a de não permitir que eles tocassem o modo de exibição de página durante a transição.
__block UIView *pageView = pageViewController.view;
// Disable page view to not allow the user to interrupt the page view animation and cause crash
pageView.userInteractionEnabled = NO;
[pageViewController setViewControllers:@[viewController] direction:UIPageViewControllerNavigationDirectionForward animated:YES completion:^(BOOL finished) {
if (finished) {
pageView.userInteractionEnabled = YES; // re-enable
}
}];
Apenas certifique-se de que você não está fazendo qualquer animações dentro de viewDidAppear no controlador que você está indo de volta para.Ou se você tiver que fazê-lo depois de alguma demora, uma vez que o vista apareceu.
Eu uso UIPageViewController com Pontos.Depois que o usuário passar sobre os pontos, o delegado didFinishAnimating chamado e eu desencadear outras de animação e, em seguida, falha.Mas isso só acontecerá quando o usuário passa o dedo sobre os pontos.
- (void)pageViewController:(UIPageViewController *)pageViewController didFinishAnimating:(BOOL)finished previousViewControllers:(NSArray<UIViewController *> *)previousViewControllers transitionCompleted:(BOOL)completed
{
if (completed && finished)
{
dispatch_async(dispatch_get_main_queue(), ^{
[self animateSomeView];
})
}
}
Eu encontrei o mesmo erro com um UIViewController eu tinha incorporado em um UIPageViewController.No meu caso, eu percebi que meu filho controlador tinha substituído viewWillAppear
e viewDidAppear
sem chamar através de super
.Embora eu posso apenas imaginar os detalhes, faz sentido que isso pode atrapalhar a visão de gestão.Adicionar a super
chamadas feitas o problema desaparecer.
No meu caso o problema era na implementação de UIPageViewControllerDelegate
:
Eu atualização de restrições
pageViewController(_ pageViewController:, didFinishAnimating:, previousViewControllers:, transitionCompleted:)
dispatch_async
na fila principal resolver este problema