Photos的使用

Photos对应的基本概念

PHFetchResult -> PHCollectionList ->PHCollection -> PHAssetCollection -> PHAsset -> PHImageManager

  1. PHAsset表示相册里的一个资源,如一张图片或者一个视频。

  2. PHAssetCollection表示一个相册或者时刻,可以是系统相册或者用户自定义的相册,PHCollection是它的父类。

  3. PHCollectionList表示多个相册PHCollection的集合。

  4. PHFetchResult是调用了PhotoKit提供的资源请求接口如fetchAssetCollectionsWithType函数,返回的请求结果,PHFetchResult是一个数组,里面的元素可以是PHAsset,也可以是PHCollection,在请求的使用可以用PHFetchOptions定义请求参数,比如只请求视频类型或者图片类型,请求结果的排序方式等。

  5. PHImageManager是对一个PHAsset进行请求以获取资源数据的接口,PHAsset里面只是资源的元数据,如图片信息,图片大小和创建日期等,当你要把图片load出来的时候就要用到PHImageManager的requestImageForAsset来进行加载,可以通过参数来设置加载图片的大小尺寸等,另外使用PHCachingImageManager还可以进行缓存加载。

获取所有相册

1,获取系统相册
获取到系统所有的相册
PHFetchResult *smartAlbums = [PHAssetCollection fetchAssetCollectionsWithType:PHAssetCollectionTypeSmartAlbum subtype:PHAssetCollectionSubtypeAny options:nil];


typedef NS_ENUM(NSInteger, PHAssetCollectionType) {
    PHAssetCollectionTypeAlbum      = 1, //从 iTunes 同步来的相册,以及用户在Photos中自己创建的相册
    PHAssetCollectionTypeSmartAlbum = 2, //经由相机得来的相册
    PHAssetCollectionTypeMoment     = 3, //Photos 为我们自动生成的时间分组的相册
} PHOTOS_ENUM_AVAILABLE_IOS_TVOS(8_0, 10_0);

typedef NS_ENUM(NSInteger, PHAssetCollectionSubtype) {
    
    // PHAssetCollectionTypeAlbum regular subtypes
    PHAssetCollectionSubtypeAlbumRegular         = 2, //用户在 Photos 中创建的相册
    PHAssetCollectionSubtypeAlbumSyncedEvent     = 3, /使用 iTunes 从 Photos 照片库或者 iPhoto 照片库同步过来的事件。
    PHAssetCollectionSubtypeAlbumSyncedFaces     = 4, //使用 iTunes 从 Photos 照片库或者 iPhoto 照片库同步的人物相册。
    PHAssetCollectionSubtypeAlbumSyncedAlbum     = 5, //做了 AlbumSyncedEvent 应该做的事
    PHAssetCollectionSubtypeAlbumImported        = 6, //从相机或是外部存储导入的相册
    
    // PHAssetCollectionTypeAlbum shared subtypes
    PHAssetCollectionSubtypeAlbumMyPhotoStream   = 100, //用户的 iCloud 照片流
    PHAssetCollectionSubtypeAlbumCloudShared     = 101, //用户使用 iCloud 共享的相册
    
    // PHAssetCollectionTypeSmartAlbum subtypes
    PHAssetCollectionSubtypeSmartAlbumGeneric    = 200, //文档解释为非特殊类型的相册,主要包括从 iPhoto 同步过来的相册
    PHAssetCollectionSubtypeSmartAlbumPanoramas  = 201, //相机拍摄的全景照片
    PHAssetCollectionSubtypeSmartAlbumVideos     = 202, //相机拍摄的视频
    PHAssetCollectionSubtypeSmartAlbumFavorites  = 203, //收藏文件夹
    PHAssetCollectionSubtypeSmartAlbumTimelapses = 204, //延时视频文件夹,同时也会出现在视频文件夹中
    PHAssetCollectionSubtypeSmartAlbumAllHidden  = 205, //包含隐藏照片或视频的文件夹
    PHAssetCollectionSubtypeSmartAlbumRecentlyAdded = 206, //相机近期拍摄的照片或视频
    PHAssetCollectionSubtypeSmartAlbumBursts     = 207, //连拍模式拍摄的照片
    PHAssetCollectionSubtypeSmartAlbumSlomoVideos = 208, //Slomo 是 slow motion 的缩写,高速摄影慢动作解析,在该模式下,iOS 设备以120帧拍摄。
    PHAssetCollectionSubtypeSmartAlbumUserLibrary = 209, //这个命名最神奇了,就是相机相册,所有相机拍摄的照片或视频都会出现在该相册中,而且使用其他应用保存的照片也会出现在这里。
    PHAssetCollectionSubtypeSmartAlbumSelfPortraits PHOTOS_AVAILABLE_IOS_TVOS(9_0, 10_0) = 210, //这个相册包含了用户使用前置摄像头拍摄的照片和视频
    PHAssetCollectionSubtypeSmartAlbumScreenshots PHOTOS_AVAILABLE_IOS_TVOS(9_0, 10_0) = 211, //使用设备的截屏功能生成的照片
    PHAssetCollectionSubtypeSmartAlbumDepthEffect PHOTOS_AVAILABLE_IOS_TVOS(10_2, 10_1) = 212, //在可兼容的设备上使用景深摄像模式拍的照片
    PHAssetCollectionSubtypeSmartAlbumLivePhotos PHOTOS_AVAILABLE_IOS_TVOS(10_3, 10_2) = 213, //包含所有的Live Photo资源
    PHAssetCollectionSubtypeSmartAlbumAnimated PHOTOS_AVAILABLE_IOS_TVOS(11_0, 11_0) = 214, //动图
    PHAssetCollectionSubtypeSmartAlbumLongExposures PHOTOS_AVAILABLE_IOS_TVOS(11_0, 11_0) = 215, //长曝光
    // Used for fetching, if you don't care about the exact subtype
    PHAssetCollectionSubtypeAny = NSIntegerMax ////包含所有类型
} PHOTOS_ENUM_AVAILABLE_IOS_TVOS(8_0, 10_0);

注意,获取指定类型的相册时,主类型和子类型要匹配,不要串台。如果不匹配,系统会按照 Any 子类型来处理。对于 Moment 类型,子类型使用 Any。


拿到系统相册信息
[smartAlbums enumerateObjectsUsingBlock:^(id _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
PHAssetCollection *colletion = obj;
[smartArray addObject:colletion];
}]

2,获取用户自定义的相册
获取自定义相册
PHFetchResult *userAlbums = [PHAssetCollection fetchAssetCollectionsWithType:PHAssetCollectionTypeAlbum subtype:PHAssetCollectionSubtypeAny options:nil];

获取自定义相册信息:
[userAlbums enumerateObjectsUsingBlock:^(id _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
PHAssetCollection *colletion = obj;
[smartArray addObject:colletion];
}];

获取具体的视频或者图片信息

先获取具体的一个相册
PHAssetCollection *collection = [smartArray objectAtIndex:i];
PHFetchResult *result = [PHAsset fetchAssetsInAssetCollection:collection options:nil];

获取具体相册里面的信息
PHAsset *asset = result[I];

信息展示

我们要通过PHCachingImageManager去获取缩略图
[self.imageManager requestImageForAsset: PHAsset targetSize:CELLSIZE contentMode:PHImageContentModeAspectFit options:nil resultHandler:^(UIImage * _Nullable result, NSDictionary * _Nullable info) {

}]
获取地址信息

__block NSString videoUrl = @"";
dispatch_semaphore_t semaphore = dispatch_semaphore_create(0);
[[PHImageManager defaultManager] requestAVAssetForVideo:asset
options:[PHVideoRequestOptions new] resultHandler:^(AVAsset * avAsset, AVAudioMix * audioMix, NSDictionary * info) {
videoUrl = ((AVURLAsset
)avAsset).URL.absoluteString;
dispatch_semaphore_signal(semaphore);
}];
dispatch_semaphore_wait(semaphore, DISPATCH_TIME_FOREVER);
return videoUrl;

你可能感兴趣的:(Photos的使用)