_uiqueusingScrollViewによってスローされた無効なパラメータ例外例
-
20-12-2019 - |
質問
uipageViewControllerに埋め込まれているUiverViewControllerを含むマイアプリは、この例外を時々発生します。
Invalid parameter not satisfying: [views count] == 3
.
バックトレース:
* 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
.
誰もがすでにこれを見たことがあるか、理由が何であるかという考えを持っているか?
解決
編集:この修正を増やした後、私はまだそのバグを見ることができますので、これは完全な修正ではありません(まあ...それは常にハックのようなものでした)。私はそれを見つけたら実際の解決策で更新します。
UIPageViewControllerを使用してこの同じエラーを発生させました。時間をデバッグした後、UIPageViewControllerのSetViewControllersの完了ハンドラ内でUIViewアニメーションを使用していたことがわかりました。方向:アニメーション:完了:。
その段階でアニメーションをアニメーション化するのはアサーションエラーを引き起こします(私はUIPageViewControllerまたはその子ビューコントローラをアニメートしていませんでした)が、メインキューのDispatch_Asyncを使用してコードブロックをラッピングすると問題が解決され、クラッシュするのを停止します。。
他のヒント
プログラムで新しいページに移行しようとすると、このクラッシュを見ました。私にとって理にかなった答えは、遷移中にページビューに触れることを許可することではありません。
__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
}
}];
. あなたが戻ってきたコントローラのViewDidAppear内でアニメーションをしていないことを確認してください。または、ビューが表示されたら、遅延後にやらなければならない場合は
uipageViewControllerをドットで使用します。ユーザーがドットをスワイプした後、Delegate DidFinishAnimatingは呼び出され、他のアニメーションを起動してからクラッシュします。しかし、それはユーザーがドットをスワイプするときにのみ起こる。
- (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];
})
}
}
. 私はUiveweviewControllerに埋め込まれたUiviewControllerと同じエラーが発生しました。私の場合では、私の子コントローラがviewWillAppear
を呼び出すことなく、viewDidAppear
とsuper
をオーバーライドさせたことに気付いた。私は詳細を推測することができるが、それはそうすることがビュー管理をめちゃくちゃにすることができることは理にかなっている。問題を作成しました。
私の場合の問題は、UIPageViewControllerDelegate
の実装にありました:
INSの制約を更新します
pageViewController(_ pageViewController:, didFinishAnimating:, previousViewControllers:, transitionCompleted:)
dispatch_async
のメインキューでこの問題を解決する