Photos.framework -- PHCachingImageManager

PHCachingImageManager 提供获取缩略图和原图像或视频等方法,优化了预加载大量资源的功能。

说到底,PHCachingImageManager 就是提供一种预加载的方式,来提高照片展示的体验。具体的使用方法直接看官方的文档,还是文档上写得详细:

Photos.framework -- PHCachingImageManager_第1张图片
3E8892AA-4C88-4F69-B33D-5798AEC41F28.png

这里需要注意的有两点,在上图都标红了:

  • 第一个就是 Create a PHCachingImageManager instance ,这是需要创建一个单例,其实就是保证工作范围内容只创建一个 PHCachingImageManager 实例就可以了。

这里我就被自己坑到了,在做一个获取相册的页面,每次都加载相册的第一张照片时,就会先创建一个 PHCachingImageManager 实例,然后再通过这个实例去加载图片展示在 CollerctionView 上~~~ 然后就坑了,总会有一到两张图片是加载不出来的,一直找不到原因,后来再读了下官方的文档,改为只创建一个 PHCachingImageManager 实例,这个问题就解决了。

  • 第二个就是如果通过
 requestImageForAsset:targetSize:contentMode:options:resultHandler: 

方法来加载图片时,如果图片没有被缓存过,就会缓存起来。

所以像获取系统相册这种功能,因展示的照片量很少,可以不需要预加载图片的功能。

PHCachingImageManager 提供的属性和方法
  • allowsCachingHighQualityImages

    一个布尔值,设置是否允许加载高质量的图片

  • 缓存一些电子版:

- (void)startCachingImagesForAssets:(NSArray *)assets targetSize:(CGSize)targetSize contentMode:(PHImageContentMode)contentMode options:(PHImageRequestOptions *)options;

  • 停止缓存一些照片:
-- (void)stopCachingImagesForAssets:(NSArray *)assets targetSize:(CGSize)targetSize contentMode:(PHImageContentMode)contentMode options:(PHImageRequestOptions *)options;

参数说明:

Photos.framework -- PHCachingImageManager_第2张图片
E51F13EA-9042-45E4-91B2-CADA3E62BAB2.png
  • 停止缓存所有照片:
-- (void)stopCachingImagesForAllAssets;

你可能感兴趣的:(Photos.framework -- PHCachingImageManager)