AVURLAsset *urlAsset = (AVURLAsset *)asset崩溃

PHVideoRequestOptions *options = [[PHVideoRequestOptions alloc] init];

options.version = PHImageRequestOptionsVersionCurrent;

//如果是选择icloud里面的视频,则要在options里打开允许下载的属性

[manager requestAVAssetForVideo:PHAsset options:videoRequestOptions resultHandler:^(AVAsset * avasset, AVAudioMix * audioMix, NSDictionary * info) {

AVURLAsset *urlAsset = (AVURLAsset *)asset;

NSURL *url = urlAsset.URL;

NSData *data = [NSData dataWithContentsOfURL:url];

//当在这个方法里获得的avasset为视频文件,但是有可能会发生这个错误

//-[AVComposition URL]: unrecognized selector sent to instance 0x138d17f40

//这是因为有些视频可能不存在这个url(比如慢视频)

//错误在AVURLAsset *urlAsset = (AVURLAsset *)asset;这一行代码。

//因为asset可能是个基类,他可能是AVComposition而不是AVURLAsset,这样就得不到视频的url了这样程序就会崩啦。

//<这里是解决办法1>

//options.version = PHVideoRequestOptionsVersionOriginal;

//但是这个方法有个缺点是如果是慢视频,则提交后播放就和正常视频一样了

//这是因为,默认的 version 属性是 PHVideoRequestOptionsVersionCurrent 这项将纳入慢动作、 用户编辑、 修剪等,更改这个属相就改变了视频的格式了。

//<所以完美解决的方法出来了>

//给定一个地址URL

NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES);

NSString *documentsDirectory = paths.firstObject;NSString *myPathDocs =  [documentsDirectory stringByAppendingPathComponent:[NSString stringWithFormat:@"mergeSlowMoVideo-%d.mov",arc4random() % 1000]];

NSURL *url = [NSURL fileURLWithPath:myPathDocs];

//将这个地址设为视频的输出地址

AVAssetExportSession *exporter = [[AVAssetExportSession alloc] initWithAsset:asset presetName:AVAssetExportPresetHighestQuality];

exporter.outputURL = url;

exporter.outputFileType = AVFileTypeQuickTimeMovie;

exporter.shouldOptimizeForNetworkUse = YES;

[exporter exportAsynchronouslyWithCompletionHandler:^{dispatch_async(dispatch_get_main_queue(), ^{if (exporter.status == AVAssetExportSessionStatusCompleted) {

NSURL*URL = exporter.outputURL;

NSData *videoData = [NSData dataWithContentsOfURL:URL];

// Upload

[self uploadSelectedVideo:video data:videoData];

}});

}];

//注意排版可能根据你的代码来进行了,我这里将这几种写法都放在一起了,如果你要选择视频的话,请直接使用这个完美的解决方法。

}];

先说一下我的需页面 以9宫格的形式显示我手机相册里面的视频 ,我开始的方法是

每个视频都要获取到AVURLAsset再显示,要等的时间很长 

[manager requestAVAssetForVideo:PHAsset options:videoRequestOptions resultHandler:^(AVAsset * avasset, AVAudioMix * audioMix, NSDictionary * info) {

AVURLAsset *urlAsset = (AVURLAsset *)asset;

NSURL *url = urlAsset.URL;

NSData *data = [NSData dataWithContentsOfURL:url];

可以先获取每个视频的缩略图

PHVideoRequestOptions *options = [[PHVideoRequestOptions alloc] init];

            options.version = PHVideoRequestOptionsVersionOriginal;

            options.deliveryMode = PHVideoRequestOptionsDeliveryModeFastFormat;

            options.networkAccessAllowed=true;

            sellcount++;

            PHAssetModel* model = [[PHAssetModelalloc]init];

            model.asset= phAsset;

            PHImageRequestOptions *option = [[PHImageRequestOptions alloc] init];

            option.resizeMode = PHImageRequestOptionsResizeModeFast;

            [[PHImageManager defaultManager] requestImageForAsset:phAsset targetSize:CGSizeMake(600, 600) contentMode:PHImageContentModeAspectFill options:option resultHandler:^(UIImage *result, NSDictionary *info) {

                if(result) {

                    model.thumbnail=result;

                    [self.pictureArraddObject:model];

                }



                dispatch_async(dispatch_get_main_queue(), ^{


                                           [self->mainCollectionViewreloadData];

                                       });

              }];

这个很快,这样子显示列表页面不费时间;


这里要注意一点区分一下Download image from iCloud / 从iCloud下载图片

if([infoobjectForKey:PHImageResultIsInCloudKey]&&networkAccessAllowed ) {

            PHImageRequestOptions *options = [[PHImageRequestOptions alloc] init];

            options.progressHandler= ^(doubleprogress,NSError*error,BOOL*stop,NSDictionary*info) {

                dispatch_async(dispatch_get_main_queue(), ^{

                    if(progressHandler) {

                        progressHandler(progress, error, stop, info);

                    }

                });

            };

            options.networkAccessAllowed=YES;

            options.resizeMode = PHImageRequestOptionsResizeModeFast;

            [[PHImageManager defaultManager] requestImageDataForAsset:asset options:options resultHandler:^(NSData *imageData, NSString *dataUTI, UIImageOrientation orientation, NSDictionary *info) {

                UIImage*resultImage = [UIImageimageWithData:imageData];

做一下判断去获取Image;

当点击collectionView didSelectItem时候 在加载

PHVideoRequestOptions* options = [[PHVideoRequestOptions alloc] init];

    options.version = PHVideoRequestOptionsVersionOriginal;

    options.deliveryMode = PHVideoRequestOptionsDeliveryModeAutomatic;

    options.networkAccessAllowed = YES;

    [[PHImageManager defaultManager] requestAVAssetForVideo:model.asset options:options resultHandler:^(AVAsset* avasset, AVAudioMix* audioMix, NSDictionary* info){

        // NSLog(@"Info:\n%@",info);

        AVURLAsset*videoAsset = (AVURLAsset*)avasset;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,313评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,369评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,916评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,333评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,425评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,481评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,491评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,268评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,719评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,004评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,179评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,832评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,510评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,153评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,402评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,045评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,071评论 2 352

推荐阅读更多精彩内容