PHCachingImageManager 提供获取缩略图和原图像或视频等方法,优化了预加载大量资源的功能。
说到底,PHCachingImageManager 就是提供一种预加载的方式,来提高照片展示的体验。具体的使用方法直接看官方的文档,还是文档上写得详细:
3E8892AA-4C88-4F69-B33D-5798AEC41F28.png这里需要注意的有两点,在上图都标红了:
- 第一个就是 Create a PHCachingImageManager instance ,这是需要创建一个单例,其实就是保证工作范围内容只创建一个 PHCachingImageManager 实例就可以了。
这里我就被自己坑到了,在做一个获取相册的页面,每次都加载相册的第一张照片时,就会先创建一个 PHCachingImageManager 实例,然后再通过这个实例去加载图片展示在 CollerctionView 上~~~ 然后就坑了,总会有一到两张图片是加载不出来的,一直找不到原因,后来再读了下官方的文档,改为只创建一个 PHCachingImageManager 实例,这个问题就解决了。
- 第二个就是如果通过
requestImageForAsset:targetSize:contentMode:options:resultHandler:
方法来加载图片时,如果图片没有被缓存过,就会缓存起来。
所以像获取系统相册这种功能,因展示的照片量很少,可以不需要预加载图片的功能。
PHCachingImageManager 提供的属性和方法
-
allowsCachingHighQualityImages
一个布尔值,设置是否允许加载高质量的图片
-
缓存一些电子版:
- (void)startCachingImagesForAssets:(NSArray<PHAsset *> *)assets targetSize:(CGSize)targetSize contentMode:(PHImageContentMode)contentMode options:(PHImageRequestOptions *)options;
- 停止缓存一些照片:
-- (void)stopCachingImagesForAssets:(NSArray<PHAsset *> *)assets targetSize:(CGSize)targetSize contentMode:(PHImageContentMode)contentMode options:(PHImageRequestOptions *)options;
参数说明:
E51F13EA-9042-45E4-91B2-CADA3E62BAB2.png- 停止缓存所有照片:
-- (void)stopCachingImagesForAllAssets;
网友评论