iOS 视屏压缩

2019-01-07  本文已影响0人  A_sura

iOS 8.0 相册使用的新的框架 Photos。

一、获取权限

[PHPhotoLibrary requestAuthorization:^(PHAuthorizationStatus status) {
        if (status == PHAuthorizationStatusRestricted || status == PHAuthorizationStatusNotDetermined) {
            //未授权
        }else if (status == PHAuthorizationStatusDenied){
            //授权
        }
    }];

二、获取视屏元数据

PHFetchResult *result = [PHAsset fetchAssetsWithMediaType:PHAssetMediaTypeVideo options:nil];
    [result enumerateObjectsUsingBlock:^(id  _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
        //包含视屏信息的元数据
        PHAsset *asset = (PHAsset *)obj;
    }];

PHFetchResult 为一个管理类,获取实例所传入的参数第一个为枚举类型,有

PHAssetMediaTypeUnknown
PHAssetMediaTypeImage
PHAssetMediaTypeVideo
PHAssetMediaTypeAudio

而第二个参数则是一些配置,如排序等。遍历获取到的 obj 则为 PHAsset 类的实例,包含一个数据的信息。

三、压缩

PHFetchResult *result = [PHAsset fetchAssetsWithMediaType:PHAssetMediaTypeVideo options:nil];
    [result enumerateObjectsUsingBlock:^(id  _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
        //包含视屏信息的元数据
        PHAsset *asset = (PHAsset *)obj;
        PHVideoRequestOptions *options = [[PHVideoRequestOptions alloc] init];
        options.version = PHVideoRequestOptionsVersionCurrent;
        
        [[PHImageManager defaultManager] requestAVAssetForVideo:asset options:options resultHandler:^(AVAsset * _Nullable asset, AVAudioMix * _Nullable audioMix, NSDictionary * _Nullable info) {
            if ([asset isKindOfClass:[AVURLAsset class]]) {
                AVURLAsset* urlAsset = (AVURLAsset*)asset;
                AVAssetExportSession * exportSession = [AVAssetExportSession exportSessionWithAsset:urlAsset presetName:AVAssetExportPresetMediumQuality];
                exportSession.outputFileType = AVFileTypeMPEG4;
                NSString *outPath = [[NSSearchPathForDirectoriesInDomains(NSCachesDirectory, NSUserDomainMask, YES) firstObject] stringByAppendingPathComponent:@"zip.mov"];
                exportSession.outputURL = [NSURL fileURLWithPath:outPath];
                [exportSession exportAsynchronouslyWithCompletionHandler:^{
                    switch (exportSession.status) {
                        case AVAssetExportSessionStatusUnknown:
                            NSLog(@"exportSession.status AVAssetExportSessionStatusUnknown");
                            break;
                        case AVAssetExportSessionStatusWaiting:
                            NSLog(@"exportSession.status AVAssetExportSessionStatusWaiting");
                            break;
                        case AVAssetExportSessionStatusExporting:
                            NSLog(@"exportSession.status AVAssetExportSessionStatusExporting");
                            break;
                        case AVAssetExportSessionStatusCompleted:{
                            NSLog(@"exportSession.status AVAssetExportSessionStatusCompleted");
                            /*压缩大小*/
                            NSDictionary *fileAttributes = [[NSFileManager defaultManager] attributesOfItemAtPath:outPath error:nil];
                            float fileSize = [[fileAttributes objectForKey:NSFileSize] unsignedLongLongValue];
                            NSLog(@"size : %f",fileSize);
                            NSData *data = [NSData dataWithContentsOfURL:[NSURL fileURLWithPath:outPath]];
                            [[NSFileManager defaultManager] removeItemAtPath:outPath error:nil];
                            break;
                        }
                        case AVAssetExportSessionStatusFailed:{
                            NSLog(@"exportSession.status AVAssetExportSessionStatusFailed");
                            break;
                        }
                        case AVAssetExportSessionStatusCancelled:
                            NSLog(@"exportSession.status AVAssetExportSessionStatusCancelled");
                            break;
                        default:
                            break;
                    }
                }];
                
                
            }
        }];
    }];
    

PHVideoRequestOptions 的 version 两个值:
PHVideoRequestOptionsVersionCurrent 当前视屏(包括编辑后)
PHVideoRequestOptionsVersionOriginal 原始视屏

关键参数为 AVAssetExportSession 的 presetName,设置压缩的程度:

AVAssetExportPresetLowQuality 最低压缩,压缩后视屏大小最大,但清晰度最高;
AVAssetExportPresetMediumQuality 中度压缩,压缩后是视屏大小中等,清晰度也是中等;
AVAssetExportPresetHighestQuality 高度压缩,压缩后视屏大小最小,清晰度最差。

outputFileType 参数,压缩完视频格式,列常见的一些:

AVFileTypeQuickTimeMovie .mov 格式;
AVFileTypeMPEG4 mp4格式;
AVFileTypeAppleM4V .m4v格式;
AVFileTypeAppleM4A .m4a格式;
AVFileType3GPP .3gp 格式

本例压缩完视屏后存储到临时路径下,然后获取到 data 数据后,去做其他操作,然后删除临时压缩数据。

上一篇 下一篇

猜你喜欢

热点阅读