纵观移动市场,一款移动app,要想长期在移动市场立足,最起码要包含以下几个要素:实用的功能、极强的用户体验、华丽简洁的外观。华丽外观的背后,少不了美工的辛苦设计,但如果开发人员不懂得怎么合理展示这些设计好的图片,将会糟蹋了这些设计,功亏一篑。

比如下面张图片,本来是设计来做按钮背景的:

  1.   button.png,尺寸为:24x60
  2.   现在我们把它用作为按钮背景,按钮尺寸是150x50:
  3.   1-(void)viewDidLoad
  4.   2{
  5.   3[superviewDidLoad];
  6.   4//得到view的尺寸
  7.   5CGSizeviewSize=self.view.bounds.size;
  8.   6
  9.   7//初始化按钮
  10.   8UIButton*button=[[UIButtonalloc]init];
  11.   9//设置尺寸
  12.   10button.bounds=CGRectMake(0,0,150,50);
  13.   11//设置位置
  14.   12button.center=CGPointMake(viewSize.width*0.5f,viewSize.height*0.5f);
  15.   13
  16.   14//加载图片
  17.   15UIImage*image=[UIImageimageNamed:@"button"];
  18.   16//设置背景图片
  19.   17[buttonsetBackgroundImage:imageforState:UIControlStateNormal];
  20.   18
  21.   19//添加按钮
  22.   20[self.viewaddSubview:button];
  23.   21}

运行效果图:

  可以看到,效果非常地差。原因很简单,因为原图大小为24x60,现在整张图片被全方位拉伸为150x50,比较严重的是图片的4个角。

  有些人可能马上想到一个解决方案,你叫美工把图片做大一点不就好了么,怎么拉伸都没事。没错,这是一种解决方案,不过不建议采取。原因很简单:1.图片大,导致安装包也大,加载到内存中也大;2.有更好的解决方案。

  细看一下图片,其实图片会变得难看,完全是因为4个角被拉伸了,中间的拉伸并没有明显地丑化外观。因此要想小图片被拉伸后不会变得难看,在图片拉伸的时候,我们只需拉伸图片的中间一块矩形区域即可,不要拉伸边缘部分。

  比如只拉伸下图的矩形区域,上下左右的边缘都不拉伸:

  iOS中提供很好用的API帮我们实现上述功能。到iOS6.0为止,iOS提供了3种图片拉伸的解决方案,接下来分别详细介绍这些方案。

  一、iOS5.0之前

  iOS中有个叫端盖(endcap)的概念,用来指定图片中的哪一部分不用拉伸。比如下图中,黑色代表需要被拉伸的矩形区域,上下左右不需要被拉伸的边缘就称为端盖。

>

  使用UIImage的这个方法,可以通过设置端盖宽度返回一个经过拉伸处理的UIImage对象

  1.   1-(UIImage*)stretchableImageWithLeftCapWidth:(NSInteger)leftCapWidthtopCapHeight:(NSInteger)topCapHeight;
  2.   这个方法只有2个参数,leftCapWidth代表左端盖宽度,topCapHeight代表顶端盖高度。系统会自动计算出右端盖宽度(rightCapWidth)和底端盖高度(bottomCapHeight),算法如下:
  3.   1//width为图片宽度
  4.   2rightCapWidth=width-leftCapWidth-1;
  5.   3
  6.   4//height为图片高度
  7.   5bottomCapHeight=height-topCapHeight-1
  8.   经过计算,你会发现中间的可拉伸区域只有1x1
  9.   1//stretchWidth为中间可拉伸区域的宽度
  10.   2stretchWidth=width-leftCapWidth-rightCapWidth=1;
  11.   3
  12.   4//stretchHeight为中间可拉伸区域的高度
  13.   5stretchHeight=height-topCapHeight-bottomCapHeight=1;
  14.   因此,使用这个方法只会拉伸图片中间1x1的区域,并不会影响到边缘和角落。
  15.   下面演示下方法的使用:
  16.   1//左端盖宽度
  17.   2NSIntegerleftCapWidth=image.size.width*0.5f;
  18.   3//顶端盖高度
  19.   4NSIntegertopCapHeight=image.size.height*0.5f;
  20.   5//重新赋值
  21.   6image=[imagestretchableImageWithLeftCapWidth:leftCapWidthtopCapHeight:topCapHeight];

调用这个方法后,原来的image并不会发生改变,会产生一个新的经过拉伸的UIImage,所以第6行中需要将返回值赋值回给image变量

  运行效果:

  可以发现,图片非常美观地显示出来了

  注意:

  1.这个方法在iOS5.0出来后就过期了

  2.这个方法只能拉伸1x1的区域

  二、iOS5.0

  在iOS5.0中,UIImage又有一个新方法可以处理图片的拉伸问题

  1.  -(UIImage*)resizableImageWithCapInsets:(UIEdgeInsets)capInsets

复制代码

这个方法只接收一个UIEdgeInsets类型的参数,可以通过设置UIEdgeInsets的left、right、top、bottom来分别指定左端盖宽度、右端盖宽度、顶端盖高度、底端盖高度

  1.   1CGFloattop=25;//顶端盖高度
  2.   2CGFloatbottom=25;//底端盖高度
  3.   3CGFloatleft=10;//左端盖宽度
  4.   4CGFloatright=10;//右端盖宽度
  5.   5UIEdgeInsetsinsets=UIEdgeInsetsMake(top,left,bottom,right);
  6.   6//伸缩后重新赋值
  7.   7image=[imageresizableImageWithCapInsets:insets];

运行效果:

  三、iOS6.0

  1.   在iOS6.0中,UIImage又提供了一个方法处理图片拉伸
  2.   -(UIImage*)resizableImageWithCapInsets:(UIEdgeInsets)capInsetsresizingMode:(UIImageResizingMode)resizingMode
  3.   对比iOS5.0中的方法,只多了一个UIImageResizingMode参数,用来指定拉伸的模式:
  4.   "UIImageResizingModeStretch:拉伸模式,通过拉伸UIEdgeInsets指定的矩形区域来填充图片
  5.   "UIImageResizingModeTile:平铺模式,通过重复显示UIEdgeInsets指定的矩形区域来填充图片
  6.   1CGFloattop=25;//顶端盖高度
  7.   2CGFloatbottom=25;//底端盖高度
  8.   3CGFloatleft=10;//左端盖宽度
  9.   4CGFloatright=10;//右端盖宽度
  10.   5UIEdgeInsetsinsets=UIEdgeInsetsMake(top,left,bottom,right);
  11.   6//指定为拉伸模式,伸缩后重新赋值
  12.   7image=[imageresizableImageWithCapInsets:insetsresizingMode:UIImageResizingModeStretch];

复制代码

运行效果:

iOS图片拉伸技巧的更多相关文章

  1. (转)iOS图片拉伸技巧

    ( 原文博客地址:  http://blog.csdn.net/q199109106q/article/details/8615661) 纵观移动市场,一款移动app,要想长期在移动市场立足,最起码要 ...

  2. iOS图片拉伸技巧-李明杰分享

    http://bbs.itcast.cn/thread-21436-1-1.html 本文目录 "一.iOS5.0之前------------------------------------ ...

  3. iOS图片拉伸技巧—— resizableImageWithCapInsets

    http://blog.csdn.net/chaoyuan899/article/details/19811889

  4. IOS中图片拉伸技巧与方法总结(转载)

    以下内容转载自:http://my.oschina.net/u/2340880/blog/403996 IOS中图片拉伸技巧与方法总结 一.了解几个图像拉伸的函数和方法 1.直接拉伸法 简单暴力,却是 ...

  5. 李洪强iOS开发之图片拉伸技巧

    纵观移动市场,一款移动app,要想长期在移动市场立足,最起码要包含以下几个要素:实用的功能.极强的用户体验.华丽简洁的外观.华丽外观的背后,少不了美工的辛苦设计,但如果开发人员不懂得怎么合理展示这些设 ...

  6. iOS 图片拉伸的解释

    以前对于ios的图片拉伸参数一直不太理解,终于看到一篇好文章,转载一下,原文地址:http://blog.csdn.net/q199109106q/article/details/8615661 主要 ...

  7. 博主教你制作类似9patch效果的iOS图片拉伸

    下面张图片,本来是设计来做按钮背景的:   button.png,尺寸为:24x60 现在我们把它用作为按钮背景,按钮尺寸是150x50: // 得到view的尺寸 CGSize viewSize = ...

  8. iOS图片拉伸

    常用的图片拉伸场景有:聊天页面的气泡,需要根据内容拉伸,但圆角拉伸后会变形,为避免圆角拉伸,可以指定拉伸区域.UIImage实体调用以下方法即可指定拉伸区域. - (UIImage *)stretch ...

  9. iOS 图片拉伸 resizableImageWithCapInsets

    UIImage *image =  [[UIImage imageNamed:@"test.png"] resizableImageWithCapInsets:UIEdgeInse ...

随机推荐

  1. Notepad++源码编译及其分析

    Notepad++是一个小巧精悍的编辑器,其使用方法我就不多说了,由于notepad++是使用c++封装的windows句柄以及api来实现的,因此对于其源码的研究有助于学习如何封装自己简单的库(当然 ...

  2. Android ActionBar 初探

    1.指南,例子,个人感觉 首先上官网指南链接http://developer.android.com/guide/topics/ui/actionbar.html 参考了官网上的例子http://de ...

  3. HDU4411 最小费用流

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=4411 floyd处理出最短路 每个点拆为i.i+n,i到i+n连一条容量为1,费用为负无穷的边,代表这个城 ...

  4. 关于C#中的 static

    一:感受 做商业项目才能更深刻和彻底的探索到技术的原理与真实面貌.以前在学校里面的时候这些C Sharp的基本语法,数据结构,面向对象背的滚瓜乱熟,那真得是背的!无论是从概念从理论上面来谈还是写一个小 ...

  5. 微信小程序常见问题集合(长期更新)

    最新更新: 新手跳坑系列:推荐阅读:<二十四>request:fail错误(含https解决方案)(真机预览问题 跳坑指南<七十>如何让微信小程序服务类目审核通过 跳坑六十九: ...

  6. PHP语言中使用JSON和将json还原成数组

    从5.2版本开始,PHP原生提供json_encode()和json_decode()函数,前者用于编码,后者用于解码. 一.json_encode() 1 2 3 4 <?php $arr = ...

  7. How do I get the path of the current executed file in Python?

    First, you need to import from inspect and os from inspect import getsourcefile from os.path import ...

  8. docker 目录迁移

    (ubuntu 12.04) 默认路径 /var/lib/docker  --> /data/docker root@node1:~# service docker stop root@node ...

  9. RIDE小技巧——Content Assistance快捷键(CTRL+空格)的修改

    大家在用RIDE Content Assistance功能的快捷键时会与机器中是输入法的切换相冲突,这里提供一下修改的位置,大家可以根据个人的喜好修改. 有三处需要修改: {Python_home}\ ...

  10. js_闭包

    先从闭包特点解释,应该更好理解.闭包的两个特点:1.作为一个函数变量的一个引用 - 当函数返回时,其处于激活状态.2.一个闭包就是当一个函数返回时,一个没有释放资源的栈区.其实上面两点可以合成一点,就 ...