iOS图片拉伸技巧-李明杰分享
http://bbs.itcast.cn/thread-21436-1-1.html
本文目录
"一、iOS5.0之前------------------------------------
"二、iOS5.0-----------------------------------------
"三、iOS6.0-----------------------------------------
纵观移动市场,一款移动app,要想长期在移动市场立足,最起码要包含以下几个要素:实用的功能、极强的用户体验、华丽简洁的外观。华丽外观的背后,少不了美工的辛苦设计,但如果开发人员不懂得怎么合理展示这些设计好的图片,将会糟蹋了这些设计,功亏一篑。
比如下面张图片,本来是设计来做按钮背景的:
- button.png,尺寸为:24x60
- 现在我们把它用作为按钮背景,按钮尺寸是150x50:
- 1-(void)viewDidLoad
- 2{
- 3[superviewDidLoad];
- 4//得到view的尺寸
- 5CGSizeviewSize=self.view.bounds.size;
- 6
- 7//初始化按钮
- 8UIButton*button=[[UIButtonalloc]init];
- 9//设置尺寸
- 10button.bounds=CGRectMake(0,0,150,50);
- 11//设置位置
- 12button.center=CGPointMake(viewSize.width*0.5f,viewSize.height*0.5f);
- 13
- 14//加载图片
- 15UIImage*image=[UIImageimageNamed:@"button"];
- 16//设置背景图片
- 17[buttonsetBackgroundImage:imageforState:UIControlStateNormal];
- 18
- 19//添加按钮
- 20[self.viewaddSubview:button];
- 21}
复制代码
运行效果图:
<ignore_js_op>
可以看到,效果非常地差。原因很简单,因为原图大小为24x60,现在整张图片被全方位拉伸为150x50,比较严重的是图片的4个角。
有些人可能马上想到一个解决方案,你叫美工把图片做大一点不就好了么,怎么拉伸都没事。没错,这是一种解决方案,不过不建议采取。原因很简单:1.图片大,导致安装包也大,加载到内存中也大;2.有更好的解决方案。
细看一下图片,其实图片会变得难看,完全是因为4个角被拉伸了,中间的拉伸并没有明显地丑化外观。因此要想小图片被拉伸后不会变得难看,在图片拉伸的时候,我们只需拉伸图片的中间一块矩形区域即可,不要拉伸边缘部分。
比如只拉伸下图的矩形区域,上下左右的边缘都不拉伸:
iOS中提供很好用的API帮我们实现上述功能。到iOS6.0为止,iOS提供了3种图片拉伸的解决方案,接下来分别详细介绍这些方案。
一、iOS5.0之前
iOS中有个叫端盖(endcap)的概念,用来指定图片中的哪一部分不用拉伸。比如下图中,黑色代表需要被拉伸的矩形区域,上下左右不需要被拉伸的边缘就称为端盖。
使用UIImage的这个方法,可以通过设置端盖宽度返回一个经过拉伸处理的UIImage对象
- 1-(UIImage*)stretchableImageWithLeftCapWidth:(NSInteger)leftCapWidthtopCapHeight:(NSInteger)topCapHeight;
- 这个方法只有2个参数,leftCapWidth代表左端盖宽度,topCapHeight代表顶端盖高度。系统会自动计算出右端盖宽度(rightCapWidth)和底端盖高度(bottomCapHeight),算法如下:
- 1//width为图片宽度
- 2rightCapWidth=width-leftCapWidth-1;
- 3
- 4//height为图片高度
- 5bottomCapHeight=height-topCapHeight-1
- 经过计算,你会发现中间的可拉伸区域只有1x1
- 1//stretchWidth为中间可拉伸区域的宽度
- 2stretchWidth=width-leftCapWidth-rightCapWidth=1;
- 3
- 4//stretchHeight为中间可拉伸区域的高度
- 5stretchHeight=height-topCapHeight-bottomCapHeight=1;
- 因此,使用这个方法只会拉伸图片中间1x1的区域,并不会影响到边缘和角落。
- 下面演示下方法的使用:
- 1//左端盖宽度
- 2NSIntegerleftCapWidth=image.size.width*0.5f;
- 3//顶端盖高度
- 4NSIntegertopCapHeight=image.size.height*0.5f;
- 5//重新赋值
- 6image=[imagestretchableImageWithLeftCapWidth:leftCapWidthtopCapHeight:topCapHeight];
复制代码
调用这个方法后,原来的image并不会发生改变,会产生一个新的经过拉伸的UIImage,所以第6行中需要将返回值赋值回给image变量
运行效果:
<ignore_js_op>
可以发现,图片非常美观地显示出来了
注意:
1.这个方法在iOS5.0出来后就过期了
2.这个方法只能拉伸1x1的区域
二、iOS5.0
在iOS5.0中,UIImage又有一个新方法可以处理图片的拉伸问题
- -(UIImage*)resizableImageWithCapInsets:(UIEdgeInsets)capInsets
复制代码
这个方法只接收一个UIEdgeInsets类型的参数,可以通过设置UIEdgeInsets的left、right、top、bottom来分别指定左端盖宽度、右端盖宽度、顶端盖高度、底端盖高度
- 1CGFloattop=25;//顶端盖高度
- 2CGFloatbottom=25;//底端盖高度
- 3CGFloatleft=10;//左端盖宽度
- 4CGFloatright=10;//右端盖宽度
- 5UIEdgeInsetsinsets=UIEdgeInsetsMake(top,left,bottom,right);
- 6//伸缩后重新赋值
- 7image=[imageresizableImageWithCapInsets:insets];
复制代码
运行效果:
<ignore_js_op>
三、iOS6.0
- 在iOS6.0中,UIImage又提供了一个方法处理图片拉伸
- -(UIImage*)resizableImageWithCapInsets:(UIEdgeInsets)capInsetsresizingMode:(UIImageResizingMode)resizingMode
- 对比iOS5.0中的方法,只多了一个UIImageResizingMode参数,用来指定拉伸的模式:
- "UIImageResizingModeStretch:拉伸模式,通过拉伸UIEdgeInsets指定的矩形区域来填充图片
- "UIImageResizingModeTile:平铺模式,通过重复显示UIEdgeInsets指定的矩形区域来填充图片
- 1CGFloattop=25;//顶端盖高度
- 2CGFloatbottom=25;//底端盖高度
- 3CGFloatleft=10;//左端盖宽度
- 4CGFloatright=10;//右端盖宽度
- 5UIEdgeInsetsinsets=UIEdgeInsetsMake(top,left,bottom,right);
- 6//指定为拉伸模式,伸缩后重新赋值
- 7image=[imageresizableImageWithCapInsets:insetsresizingMode:UIImageResizingModeStretch];
复制代码
运行效果:
<ignore_js_op>
转载于:https://www.cnblogs.com/yangmx/p/3589493.html
iOS图片拉伸技巧-李明杰分享相关推荐
- 【李明杰老师分享】iOS图片拉伸技巧
纵观移动市场,一款移动app,要想长期在移动市场立足,最起码要包含以下几个要素:实用的功能.极强的用户体验.华丽简洁的外观.华丽外观的背后,少不了美工的辛苦设计,但如果开发人员不懂得怎么合理展示这些设 ...
- ios大牛李明杰亲授《从入门到精通Swift编程》限时优惠活动推出!已近600人报名直播课!
课程简介: Swift,是Apple公司于2014年6月发布的全新编程语言,是第一个既满足工业标准又像脚本语言一样充满表现力和趣味的编程语言.从Swift面世那一刻起,就受到了全世界各地开发者的热捧和 ...
- iOS底层原理班(下)/OC对象/关联对象/多线程/内存管理/性能优化-李明杰-专题视频课程...
iOS底层原理班(下)/OC对象/关联对象/多线程/内存管理/性能优化-236人已学习 课程介绍 得遇名师,突飞猛进!iOS培训王者MJ(李明杰)老师精心研发,iOS进阶课程,实用技术 ...
- LLVM框架/LLVM编译流程/Clang前端/LLVM IR/LLVM应用与实践-李明杰-专题视频课程
LLVM框架/LLVM编译流程/Clang前端/LLVM IR/LLVM应用与实践-3人已学习 课程介绍 LLVM并非仅仅是一款编译器这么简单.利用LLVM,我们可以进行各种疯狂的操作 ...
- 专访搜狗输入法 iOS 版开发负责人李腾杰:第三方输入法开发与优化实践
输入法是一种对性能要求极高的产品,不同于普通应用开发,很多在普通应用开发看来不是问题的,在输入法看来却是比较关键.同时,由于 iOS 系统的某些限制,输入法不得不在产品功能和性能方面做出调整,以尽可能 ...
- iOS图片拉伸(resizableImage)
返回一张受保护且被拉伸的图片 应用场景:聊天窗口的气泡 方法一(弃用): iOS 5.0以前使用(弃用)这个方法会自动计算出偏向中间的一个1*1的方格也就是被拉伸的地方(默认使用拉伸),一般传入的值为 ...
- iOS图片拉伸之神属性:resizableImageWithCapInsets
在仿写QQ会话窗口的时候,气泡的背景图片拉伸问题.并不是所有地方都可以拉伸的,所以定义了下面的工具类中的一个方法,专门拉伸图片. UIImageResizingModeStrech:拉伸模式,通过拉伸 ...
- iOS底层原理班实战视频教程 -李明杰-专题视频课程
IOS底层开发班实战视频培训课程:APP逆向实战.加壳脱壳.数据安全.编译原理.iOS底层开发实现.iOS底层开发机制 iOS进阶课程,实用技术不断的更新和升级,更快帮助职场人士在开发领域脱颖而出.远 ...
- 最新李明杰小码哥ios开发视频教程四期
最新文章
- Exists and IN
- Remove Linked List Elements
- WSDM 2022 | 一种用于在线广告自动竞价的协作竞争多智能体框架
- 【OpenPose-Windows】运行OpenposeDemo.exe 如何保存图像运行结果及关节点信息
- python spark dataframe_pyspark dataframe 常用操作
- 查询字符串某个字符的个数
- vue中的uri_浅谈vue-resource和vue-axios的区别
- 手把手教你写平衡二叉树
- 0505.Net基础班第二十天(基础加强总复习)
- EF异常:“System.InvalidOperationException”类型的未经处理的异常在 mscorlib.dll 中发生
- vc浏览器_【36氪基金X一刻】零基础VC/PE行研标准班7月10日线上开课
- 《JavaScript权威指南第7版》第4章 表达式和运算符
- 最全办公室租赁技巧,让你找到心仪的办公室
- 微信调用手机浏览器打开下载链接
- 不定积分问题:1/x^3+1的不定积分求法
- python语音识别库kaldi_Kaldi 使用 DFSMN 训练语音模型
- 技嘉B460M小雕板win2012 R2安装网卡驱动
- html背景图片自适应窗口大小
- python 单词纠错_用 Python 实现英文单词纠错功能
- Unity3D Animator人物模型下沉的一种原因
热门文章
- 那些战火纷飞和兄弟们肝胆心照的生活,不由的脸上浮起了笑容
- C语言操作MYSQL简易教程
- Xshell 7 功能强大,免费享用,再也不用找破解版了
- 行业价格战疑云未消,安能物流为何急于争夺“港股快运第一股”?
- 浙江工商大学python题库_浙江工商大学
- 自动驾驶轨迹预测论文阅读(三)Social GAN: Socially Acceptable Trajectories with Generative Adversarial Networks
- Hibernate升级到5.4.18.final的过程踩过的坑
- 别拦我,我要撞豆腐 ----- for循环中进行异常抛出,for循环还能继续循环吗?
- 蓝牙调速小车测试程序(只放程序)
- 史上最高春晚红包活动来电,百度十个亿的项目参与下?