iOS 使用矢量图
更多图片处理方法见图片组件 BBWebImage
iOS 使用矢量图
iOS 图标通常用 PNG 格式的图片。PNG 图片放大到超过自身的大小就会模糊。可以使用 PDF 格式的矢量图,优点是任意改变图片大小并且保持清晰度。
简单使用
与 PNG 格式的图片一样,在 Xcode 中把 PDF 格式的矢量图拖进 *.xcassets (默认是 Assets.xcassets) 文件夹中,然后用不带后缀(.pdf)的文件名生成 UIImage
imageView.image = [UIImage imageNamed:@"Vector"];
注意,如果以上代码用 "Vector.pdf",无法得到 UIImage。
这样做的话,Xcode 会在编译时根据 PDF 图的大小生成 @1x、@2x、@3x 的 PNG 图片,与使用 PNG 图片的显示效果相同。如果把图片放大到超过 PNG 图片的大小,则会显示模糊的图片。没有发挥矢量图可以任意调整大小的优点。
改变矢量图大小
如果需要改变矢量图大小并且保持清晰度,那就要解析 PDF 源文件,把矢量图绘制成所需大小的位图(Bitmap)。YHPDFImageLoader 库就实现了这个功能,并且可以选择拉伸图片时是否保持原图宽高比,还添加了内存和磁盘缓存。解析 PDF 并绘制位图的代码在 YHPDFImageDraw.m 文件的 drawImageWithURL:size:canStretched:page: 方法中。但是那些代码有 bug,在保持原图宽高比的时候,绘制出的位图不居中。这里参照那些代码,写了 UIImage 的 Category,用于解析 PDF 源文件,绘制指定大小的位图;可以选择拉伸图片时是否保持原图宽高比;拉伸时保持图片居中。注意,这里的 PDF 文件放在工程目录中,与 *.m、*.h 文件一样,不能放在 *.xcassets 里。
#import "UIImage+Vector.h"
@implementation UIImage (Vector)
+ (UIImage *)vectorImageWithName:(NSString *)name size:(CGSize)size {
// 默认保持原图宽高比
return [self vectorImageWithName:name size:size stretch:NO];
}
+ (UIImage *)vectorImageWithName:(NSString *)name size:(CGSize)size stretch:(BOOL)stretch {
// PDF 文件路径
NSString *path = [NSBundle.mainBundle pathForResource:name ofType:@"pdf"];
NSAssert(path, @"Vector image file path should NOT be nil");
if (!path) return nil;
return [self vectorImageWithURL:[NSURL fileURLWithPath:path] size:size stretch:stretch page:1];
}
// url: PDF 文件 URL
// size: 所需绘制图片大小;如果需要绘制原图大小,用 CGSizeZero
// stretch: 是否拉伸;YES,拉伸图片,忽略原图宽高比;NO,保持原图宽高比
+ (UIImage *)vectorImageWithURL:(NSURL *)url size:(CGSize)size stretch:(BOOL)stretch page:(NSUInteger)page {
CGFloat screenScale = UIScreen.mainScreen.scale;
// PDF 源文件
CGPDFDocumentRef pdfRef = CGPDFDocumentCreateWithURL((__bridge CFURLRef)url);
// PDF 中的一页
CGPDFPageRef imagePage = CGPDFDocumentGetPage(pdfRef, page);
// PDF 这一页显示出来的 CGRect
CGRect pdfRect = CGPDFPageGetBoxRect(imagePage, kCGPDFCropBox);
// 传入的大小如果为零,使用 PDF 原图大小
CGSize contextSize = (size.width <= 0 || size.height <= 0) ? pdfRect.size : size;
// RGB 颜色空间
CGColorSpaceRef colorSpace = CGColorSpaceCreateDeviceRGB();
// 位图上下文
CGContextRef context = CGBitmapContextCreate(NULL,
contextSize.width * screenScale,
contextSize.height * screenScale,
8,
0,
colorSpace,
kCGBitmapByteOrderDefault | kCGImageAlphaPremultipliedFirst);
// 坐标缩放,增加清晰度
CGContextScaleCTM(context, screenScale, screenScale);
if (size.width > 0 && size.height > 0) {
// 指定图片大小,需要缩放图片
// 计算宽高缩放比
CGFloat widthScale = size.width / pdfRect.size.width;
CGFloat heightScale = size.height / pdfRect.size.height;
if (!stretch) {
// 保持原图宽高比,使用宽高缩放比中的最小值
heightScale = MIN(widthScale, heightScale);
widthScale = heightScale;
// 坐标平移,使图片居中
CGFloat currentRatio = size.width / size.height;
CGFloat realRatio = pdfRect.size.width / pdfRect.size.height;
if (currentRatio < realRatio) {
CGContextTranslateCTM(context, 0, (size.height - size.width / realRatio) / 2);
} else {
CGContextTranslateCTM(context, (size.width - size.height * realRatio) / 2, 0);
}
}
// 用以上宽高缩放比缩放坐标
CGContextScaleCTM(context, widthScale, heightScale);
} else {
// 使用原图大小
// 获取原图坐标转换矩阵,用于位图上下文
CGAffineTransform drawingTransform = CGPDFPageGetDrawingTransform(imagePage, kCGPDFCropBox, pdfRect, 0, true);
CGContextConcatCTM(context, drawingTransform);
}
// 把 PDF 中的一页绘制到位图
CGContextDrawPDFPage(context, imagePage);
CGPDFDocumentRelease(pdfRef);
// 创建 UIImage
CGImageRef image = CGBitmapContextCreateImage(context);
UIImage *pdfImage = [[UIImage alloc] initWithCGImage:image scale:screenScale orientation:UIImageOrientationUp];
// 释放资源
CGImageRelease(image);
CGContextRelease(context);
CGColorSpaceRelease(colorSpace);
return pdfImage;
}
@end
使用方法
// 保持原图宽高比
imageView.image = [UIImage vectorImageWithName:@"Vector" size:CGSizeMake(50, 50)];
// 拉伸图片,忽略原图宽高比
imageView.image = [UIImage vectorImageWithName:@"Vector"
size:CGSizeMake(50, 50)
stretch:YES];
参考
http://lugede.cn/ios-use-vector-pdf-image
https://github.com/jiisd/YHPDFImageLoader
转载请注明出处:http://www.cnblogs.com/silence-cnblogs/p/7307554.html
iOS 使用矢量图的更多相关文章
- iOS 矢量图pdf替换2倍3倍图
一.在开发中矢量图的使用大大提高设计的切图效率! ios 中可以用pdf替换现在的2倍3倍图(1倍图已经忽略) 1.将pdf矢量图拖进工程Assets.xcassets中 2.按照步骤操作 3.矢量图 ...
- iOS - 如何切图适配各种机型
关于iPhone6/6+适配问题一直有争议,今天小编专门为大家整理了相关的有效方案,希望对大伙儿有帮助! 移动app开发中多种设备尺寸适配问题,过去只属于Android阵营的头疼事儿,只是很多设计师选 ...
- 在 Xcode 6 中使用矢量图( iPhone 6 置配 UI)
在 Xcode 6 中使用矢量图( iPhone 6 置配 UI) (本文转载:http://iosdeveloper.diandian.com/post/2014-09-25/40063062789 ...
- iconfont.cn阿里巴巴矢量图下载字体图标实战
1.阿里巴巴矢量图网址:www.iconfont.cn 2.然后用新浪微博账号登录 3.输入要查找的图标相应的关键字,回车 4.滑过要找的图标,点击购物车,让图标存储到暂存架中 5.点击暂存架,存储为 ...
- 在xcode6中使用矢量图(iPhone6置配UI)
转载出处:http://blog.xoneday.com ios应用程序是一个图像主导的产品.在开发一个应用程序时,你需要各种尺寸的图标,你需要为每个图像文件制作一个@1x尺寸和一个@2x尺寸.这样你 ...
- (转)iOS 对矢量图片的支持如何?
简单说,iOS 支持矢量图片,不过支持的一般.在系统层面上,iOS 对矢量绘图支持得很好.iOS 的 Core Graphics 框架带有很多矢量绘图命令,简单一些的直线.矩形.椭圆,复杂一些的贝赛尔 ...
- PaintCode 教程:矢量图轻松转换成CoreGraphics代码
本文译自Ranwenderlich的这篇:http://www.raywenderlich.com/100281/paintcode-for-designers-getting-started Pai ...
- 将阿里矢量图添加到element-ui
在阿里矢量图的操作 选择需要的图标添加至购物车 选择图标 将购物车中的图标, 添加至项目 添加至项目 会自动跳转到我的项目 项目页面 在 更多操作 中选择 编辑项目 更多操作 将 Fo ...
- 矢量图绘制工具Svg-edit调整画布的大小
矢量图绘制工具Svg-edit调整画布的大小 ------------------------------ ------------------------
随机推荐
- 利用reverse索引优化like语句的方法详解
在有一些情况下,开发同学经常使用like去实现一些业务需求,当使用like时,我们都知道使用like 前%(like '%111')这种情况是无法使用索引的,那么如何优化此类的SQL呢,下面是一个案例 ...
- C# 杂活
1 下拉框 List<Model.Sys.AccountModel> AcModel = BLL.Sys.AccountBLL.Instance.GetModelList("Ro ...
- Lucene实现索引和查询
0引言 随着万维网的发展和大数据时代的到来,每天都有大量的数字化信息在生产.存储.传递和转化,如何从大量的信息中以一定的方式找到满足自己需求的信息,使之有序化并加以利用成为一大难题.全文检索技术是现如 ...
- iOS voip电话和sip软电话 --网络电话
一|介绍1.两者区别: SIP软电话与IP电话在技术上属于同一类型,只是SIP软电话是使用电脑软件实现的,而IP电话有一部分是在话机中直接写入了程序,可以通过硬件直接使用.IP(简称VoIP,源自英语 ...
- C++ 知识点总结复习
C++ 1.C++是静态类型语言,使用静态类型的编程语言是在编译时执行类型检查,而不是在运行时执行类型检查. 2.面向对象程序设计 C++ 完全支持面向对象的程序设计,包括面向对象开发的四大特性: 封 ...
- 函数的非固定参数-Day3
一.函数非固定参数 1.默认函数,我们在传参之前,选给参数指定一个默认的值.默认参数特点是非必须传递的. def test(x,y=2): print(x) print(y) print(" ...
- 贪心算法——Fence Repair(POJ 3253)
题目描述 农夫约翰为了修理栅栏,要将一块很长的木板切割成N块.准备切成的木板长度为L1,L2,L3--LN,未切割前木板的长度恰好为切割后木板长度的总和.每次切断木板时,需要的开销为这块木板的长度.请 ...
- CPU31X-2DP通过DP网络连接远程IO站
一.远程IO站介绍 二.该DP网络系统结构 三.组态DP主站 1.组态机架硬件配置 2.设置profibus属性,主站地址为2,如下图 3.完成主站组态 四.组态远程IO从站ET200M 1.接口模块 ...
- Xamarin android SwipeRefreshLayout入门实例
android SwipeRefreshLayout 是实现的效果就是上滑下拉刷新ListView 获取其他控件数据.基本上每个App都有这种效果.Google提供了一个官方的刷新控件SwipeRef ...
- ArcGIS 网络分析[2] 在ArcMap中使用网络数据集进行五大网络分析[最短路径/服务区/最近设施点/OD成本矩阵/车辆分配]
上一章花了大篇幅介绍网络数据集的创建,也简单说了下点线的连通性问题. 那么可以试试刀锋不锋利啦! 网络分析呢,ArcGIS提供了5个基本分析类型: 最短路径求解 服务区(服务覆盖范围) 事故突发地的最 ...