#####简述:本文介绍的是一个用于在iOS项目中高效加载PDF矢量图标(尺寸能够无限放大)的工具。html
咱们知道在 Xcode 6 及以上版本能够在 Asset Catalog 中使用 PDF 格式的矢量图资源。ios
【引用】 大体上,PDF是矢量元素的事实标准。矢量文件包含一个元素的不少元数据,用来告诉系统如何渲染这些内容,而这些和屏幕分辨率无关。举个通俗易懂例子,一个圆形的矢量PDF图,当它渲染成5像素宽和渲染成5000000像素宽时是同样清晰的。 在iOS平台,Xcode是在编译时,根据你的矢量PDF图的大小,生成1x、2x和3x图。若是你的PDF图是45*45px,那么Xcode会在编译时生成下面3个PNG: 45*45px :1x设备用的(iPhone 3G and 3GS) 90*90px :2x或Retina显示设备用的(iPhone 4, 4S, 5, 5S, and 6) 135*135px :3x设备用的(iPhone 6 Plus 及以上) 这也意味着当有更高的屏幕分辨率时,Xcode能够根据已有的矢量PDF放大图片,这样自动就支持之后的设备了。还有,若是你是OS X开发者,那么矢量PDF就更好用了,OS X app彻底支持矢量PDF,你能够用代码缩放图片而不会失真。
想了解上述所有内容请猛戳传送门:4个你须要知道的Asset Catalog的秘密git
咱们对比一下最近设计部门的朋友刚导出的某个图标的一套常规的 PNG 图片和 PDF 类型的图片的大小:程序员
PDF 文件大小为 7KBgithub
PNG 三个文件合计大小为 85KB缓存
对比结果: PDF 类型的文件大概占空间为传统 PNG 类型的 8%(以当前资源为依据,不一样资源对比结果可能会有部分出入)。app
首先就是设计部门出图就会比以前方便不少,直接导出矢量文件便可,而且若是后期再须要 4X、5X... 规格的图,不须要对以前的图标再返工处理。工具
再者做为开发者在管理图片相关的添加、替换、移除等重复性的操做维护压力能够下降。设计
因为 PDF 图标文件为矢量图,不一样于以前的传统的位图,在放大以后能够依然保持清晰而非模糊毛边有像素颗粒感。code
例如,后期需求调整要求某一个按钮交互热区变大,相应图标也要放大。若是使用以前 PNG 类型的资源,须要设计从新再出一套图(做为一个严谨的程序员,固然不可以容忍模糊图标的存在🙃),但无形中这些都是开发过程当中的时间成本。
想一想若是使用 PDF 类型的资源直接改变一下图标大小不就能够了吗?那就直接行动,可是最后发如今 Asset Catalog 就算使用了 PDF 类型的图放大后仍是模糊了。为何呢?原来 Xcode 在编译的时候只是依据目前设备所须要的资源只自动生成1X、2X和3X规格的位图类型的图片,那么在后期经过只改变控件的大小来但愿图片精度也动态的调整天然是行不通了。
由此就产生了 YHPDFImageLoader 这个工具,它旨在解决上述后期动态调整放大图片发虚的问题,与系统调用加载图片兼容,并具备三级加载两级缓存功能,以减小重复性质的运算并提升加载效率
,下面是一张加载效果对比图:
固然,使用 YHPDFImageLoader 依然可使用 .bundle 资源文件包或者文件夹的形式管理 PDF 素材资源(虽然苹果声称使用 Asset Catalog 后 APP 的相关资源能够有效的防盗,可是目前仍可垂手可得的提取出里面的内容)。
另外,YHPDFImageLoader 一样支持使用 CocoaPods 集成:
pod 'YHPDFImageLoader'
使用方式:
#import "UIImage+YHPDFIcon.h"
UIImage *image = [UIImage yh_imageNamed:@"pdfName"];
效果展现(源文件图片分辨率为 30x46 ,大小为 7KB)
####更多使用方法请参照项目中 Demo 。
###还在等什么,赶忙 点击下载 集成进你的项目中和你的设计小伙伴们更愉快的玩耍吧。