PLUICameraViewController 拍照页面崩溃

2018-06-04  本文已影响90人  Harry_Lee
未命名.gif

在拍照页面中双指捏合后会出现CMKZoomSlider,这个view出现后会在5s后自动消失。如果在它消失前的一刹那点击“取消”将拍照页面dismiss掉的话就会出现crash。

Exception Type:  EXC_BAD_ACCESS (SIGBUS)
Exception Codes: KERN_INVALID_TASK at 0x0000000000000010
Crashed Thread:  0

Thread 0 Crashed:
0   libobjc.A.dylib                 objc_msgSend + 16
1   Foundation                      __NSFireDelayedPerform + 428
2   CoreFoundation                  __CFRUNLOOP_IS_CALLING_OUT_TO_A_TIMER_CALLBACK_FUNCTION__ + 28
3   CoreFoundation                  __CFRunLoopDoTimer + 884
4   CoreFoundation                  __CFRunLoopRun + 1520
5   CoreFoundation                  CFRunLoopRunSpecific + 384
6   GraphicsServices                GSEventRunModal + 180
7   UIKit                           UIApplicationMain + 204
8   moma                            main (main.m:14)
9   libdyld.dylib                   0x00000001823028b8 0x182300000 + 10424

然而,卵用没有~

从crash出现时的页面记录中发现了线索:

2018-04-20 18:26:47 [APPEAR]DEFMultipleImagePickerTableViewController
2018-04-20 18:26:47 [APPEAR]DEFAlbumPickerViewController
2018-04-20 18:26:47 [DISAPPEAR]PLUICameraViewController
2018-04-20 18:26:47 [ACTION]PLCropOverlay(_tappedBottomBarCancelButton:)
2018-04-20 18:26:39 [APPEAR]PLUICameraViewController
2018-04-20 18:26:39 [DISAPPEAR]DEFAlbumPickerViewController
2018-04-20 18:26:39 [LOADED]PLUICameraViewController
2018-04-20 18:26:38 [DISAPPEAR]DEFMultipleImagePickerTableViewController
2018-04-20 18:26:38 [ACTION]DEFMultipleImageTableViewCell(cameraButtonClicked:)
2018-04-20 18:26:33 [APPEAR]DEFMultipleImagePickerTableViewController

最后是在系统的拍照页面PLUICameraViewController消失之后崩溃的,借着这个线索在SO上找到了复现步骤:
https://stackoverflow.com/questions/26844432/how-to-find-out-what-causes-a-didhidezoomslider-error-on-ios-8/29959695

IMG_0583.PNG IMG_0582.PNG

Hook PLUICameraViewController类的viewWillDisappear方法,将CMKZoomSliderdelegate设为nil。详见SO

上一篇 下一篇

猜你喜欢

热点阅读