UIVideoEditorController 在 iPad 上崩溃

Posted

技术标签:

【中文标题】UIVideoEditorController 在 iPad 上崩溃【英文标题】:UIVideoEditorController crashes on iPad 【发布时间】:2017-04-02 12:29:07 【问题描述】:

我正在尝试使用UIVideoEditorController 编辑存储在应用程序文档目录中的视频。 它可以在 iPhone(ios 10.x)上运行,但在 iPad(iOS 9.2)上崩溃。

我可能需要补充一点,该应用程序在横向模式下运行。如文档中所述,UIVideoEditorController 仅在纵向模式下运行。但既然它可以在 iPhone 上运行,我猜这应该不是问题?

这是我做的(委托方法都实现了,但这里没有提到):

NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);
    NSString *documentsDirectory = [paths objectAtIndex:0];
NSString *filePath = [NSString stringWithString: [documentsDirectory stringByAppendingPathComponent:[NSString stringWithFormat: @"myMovie_%li.MOV", (long)self.editMovie]]];

UIVideoEditorController *vec = [[UIVideoEditorController alloc] init];

vec.delegate = self;

NSLog(@"Editing video %@", vec);

if ( [UIVideoEditorController canEditVideoAtPath:filePath] )
           
    [self presentViewController:vec animated:NO completion:nil];

else

    NSLog( @"can't edit video at %@", filePath );

这是崩溃日志:

objc[6507]: EXCEPTIONS: throwing 0x17648b30 (object 0x17648a90, a NSException)
objc[6507]: EXCEPTIONS: searching through frame [ip=0xffffffff sp=0x559900] for exception 0x17648b10
objc[6507]: EXCEPTIONS: searching through frame [ip=0x2 sp=0x55a880] for exception 0x17648b10
objc[6507]: EXCEPTIONS: unwinding through frame [ip=0xffffffff sp=0x559900] for exception 0x17648b10
objc[6507]: EXCEPTIONS: unwinding through frame [ip=0x2 sp=0x55a880] for exception 0x17648b10
objc[6507]: EXCEPTIONS: handling exception 0x17648b10 at 0x2236b2f9
objc[6507]: EXCEPTIONS: rethrowing current exception
objc[6507]: EXCEPTIONS: searching through frame [ip=0x6 sp=0x55a880] for exception 0x17648b10
objc[6507]: EXCEPTIONS: searching through frame [ip=0x3 sp=0x55aa20] for exception 0x17648b10
objc[6507]: EXCEPTIONS: catch(NSException)
objc[6507]: EXCEPTIONS: unwinding through frame [ip=0x6 sp=0x55a880] for exception 0x17648b10
objc[6507]: EXCEPTIONS: finishing handler
objc[6507]: EXCEPTIONS: unwinding through frame [ip=0xffffffff sp=0x55a880] for exception 0x17648b10
objc[6507]: EXCEPTIONS: unwinding through frame [ip=0x3 sp=0x55aa20] for exception 0x17648b10
objc[6507]: EXCEPTIONS: handling exception 0x17648b10 at 0x11175f
2017-04-02 14:17:20.281 myApp[6507:5048337] (
    0   CoreFoundation                      0x2245b933 <redacted> + 150
    1   libobjc.A.dylib                     0x21bf6e17 objc_exception_throw + 38
    2   CoreFoundation                      0x2245b861 <redacted> + 0
    3   PhotoLibrary                        0x2be83587 <redacted> + 186
    4   PhotoLibrary                        0x2be7f97f <redacted> + 1458
    5   PhotoLibrary                        0x2be9e897 <redacted> + 42
    6   UIKit                               0x269d6a1f <redacted> + 150
    7   UIKit                               0x26a94683 <redacted> + 38
    8   UIKit                               0x26a94575 <redacted> + 376
    9   UIKit                               0x26a93929 <redacted> + 96
    10  UIKit                               0x26a9355f <redacted> + 834
    11  UIKit                               0x26a6bbf1 <redacted> + 2048
    12  UIKit                               0x26d61485 <redacted> + 444
    13  UIKit                               0x26d437eb <redacted> + 114
    14  UIKit                               0x26a6b2db <redacted> + 370
    15  UIKit                               0x26faa5cd <redacted> + 112
    16  UIKit                               0x26faa1a3 <redacted> + 62
    17  UIKit                               0x269ef0e5 <redacted> + 568
    18  UIKit                               0x269eee87 <redacted> + 146
    19  UIKit                               0x26d2606d <redacted> + 1080
    20  UIKit                               0x26c7f4c9 <redacted> + 268
    21  UIKit                               0x26c8b7db <redacted> + 90
    22  UIKit                               0x269c9b1d <redacted> + 84
    23  CoreFoundation                      0x2241d6c9 <redacted> + 20
    24  CoreFoundation                      0x2241b9cd <redacted> + 280
    25  CoreFoundation                      0x2241bdff <redacted> + 958
    26  CoreFoundation                      0x2236b229 CFRunLoopRunSpecific + 520
    27  CoreFoundation                      0x2236b015 CFRunLoopRunInMode + 108
    28  GraphicsServices                    0x2395bac9 GSEventRunModal + 160
    29  UIKit                               0x26a3f189 UIApplicationMain + 144
    30  myApp                        0x0011173b main + 198
    31  libdyld.dylib                       0x22013873 <redacted> + 2
)
objc[6507]: EXCEPTIONS: finishing handler
objc[6507]: EXCEPTIONS: releasing completed exception 0x17648b30 (object 0x17648a90, a NSException)

有什么想法吗?

【问题讨论】:

我会尽快添加最终答案。首先,我忘记将 videoPath 和几乎所有属性添加到 Editor-Controller。然后我不得不将它作为 iPad 上的弹出框控制器呈现。现在它起作用了......那是一个«duh»时刻...... 【参考方案1】:

解决方法如下:

UIVideoEditorController *vec = [[UIVideoEditorController alloc] init];

    vec.delegate = self;
    vec.videoPath = filePath;
    vec.videoQuality = UIImagePickerControllerQualityTypeHigh;

    if ( UI_USER_INTERFACE_IDIOM() == UIUserInterfaceIdiomPad )
        vec.modalPresentationStyle = UIModalPresentationPopover;
        vec.popoverPresentationController.sourceView = vec.view;
    

    NSLog(@"Editing video %@", filePath);

    if ( [UIVideoEditorController canEditVideoAtPath:filePath] )
    
        [self presentViewController:vec animated:YES completion:nil];
    
    else
    
        NSLog( @"can't edit video at %@", filePath );
    

编辑器需要在 iPad 上以弹出框的形式呈现。否则会报错。

【讨论】:

以上是关于UIVideoEditorController 在 iPad 上崩溃的主要内容,如果未能解决你的问题,请参考以下文章

UIVideoEditorController 丢失视频分辨率

当我正在处理的模块只是类时,如何在React Native中为UIVideoEditorController分配一个委托

来自 String 的 NSURL 被截断,UIVideoEditorController 的视频路径上的点 Swift 2 iOS 8

iOS - 使用苹果自带的UIVideoEditController进行视频编辑

使用 MPMoviePlayer 播放视频

分配的变量引用在哪里,在堆栈中还是在堆中?