iOS设置图片拉伸不变形区域
2017-06-29 21:36
316 查看
引
在开发中,我们可能会遇到这种情况:设计做了一张图,比如是按钮或文本条的背景,但由于文字长度不一,因此按钮或者文本条大小也会变化,如果直接设为背景,那么势必导致图片被拉伸,如果是整体图片还没什么,但如果是一些特殊的图片,比如这种:由于右下角有一个箭头,正常来说不管按钮怎么变化大小,右下角的区域都应该是固定大小的,这就要求限制该区域不论图片怎么拉伸都不拉伸这个区域。
实现方法
iOS提供了简单的方法来设置不被拉伸的区域,是以图片原本大小上对应区域来设置的,方法为:- (UIImage *)resizableImageWithCapInsets:(UIEdgeInsets)capInsets resizingMode:(UIImageResizingMode)resizingMode
这个方法第一个参数接受一个UIEdgeInsets对象,用来说明你要限制不被拉伸的区域,其包含四个参数,分别为图片中距离上、左、下、右边界的不拉伸部分的范围宽度:
UIEdgeInsets insets = UIEdgeInsetsMake(top, left, bottom, right);
也就是说,在我们引言的例子中,我们就需要设置距离右边界和下边界一定距离,确保包含打钩部分,使其不被拉伸。
如果还有其他角落有范围不想被拉伸,name灵活设置四个参数对应的距离就好了。
上面的方法中第二个参数表示拉伸的模式:
UIImageResizingModeStretch:拉伸模式,通过拉伸UIEdgeInsets指定的矩形区域来填充图片
UIImageResizingModeTile:平铺模式,通过重复显示UIEdgeInsets指定的矩形区域来填充图片
我们通过设置后,可以得到确保右下角不被拉伸的效果:
图中上面的是没做设置的,下面是做了设置的,可以看出效果很明显。
代码如下:
// 不处理的图片 UIImageView *unHandleImg = [[UIImageView alloc] initWithFrame:CGRectMake((SCREENWIDTH-200)/2, 100, 200, 30)]; unHandleImg.image = [UIImage imageNamed:@"theImage"]; [self.view addSubview:unHandleImg]; // 处理区域拉伸的图片 UIImageView *handleImg = [[UIImageView alloc] initWithFrame:CGRectMake((SCREENWIDTH-200)/2, 200, 200, 30)]; UIImage *img = [UIImage imageNamed:@"theImage"]; // 四个数值对应图片中距离上、左、下、右边界的不拉伸部分的范围宽度 img = [img resizableImageWithCapInsets:UIEdgeInsetsMake(35, 35, 35, 35) resizingMode:UIImageResizingModeStretch]; handleImg.image = img; [self.view addSubview:handleImg];
需要注意的是,需要把图片添加到Assets中,创建对应的图片集合才能够生效,否则效果是不尽如人意的。
结
这算是一个比较常用到的小技巧了,记录下来,也希望能够帮助还不知道的人。示例工程:https://github.com/Cloudox/ImageAreaStretchDemo
版权所有:http://blog.csdn.net/cloudox_
相关文章推荐
- IOS中设置图片拉伸区域
- ios-拉伸图片变形解决办法:选取某一区域
- ios-拉伸图片变形解决办法:选取某一区域
- iOS 解决button设置背景图片的时候拉伸变形的问题
- ios设置图片的拉伸区域
- 在IOS中设置原始图片拉伸
- IOS-53-图片、button等空间是否可拉伸设置;以及UITabelView的headerView设置
- iOS图片实现可拉伸不变形的处理操作
- IOS 创建一个可以随意拉伸不变形的图片
- iOS中实现返回可拉伸不变形的图片
- IOS resizableImageWithCapInsets 拉伸图片时出现变形不成功
- ios UIImageView 设置图片 不变形
- iOS 返回一张可以随意拉伸不变形的图片
- iOS开发 ImageView网络请求得到的图片设置UIImageView不变形处理
- iOS - 设置图片为背景色,且拉伸到指定大小
- ios 图片拉伸不变形的方法
- iOS 图片不变形拉伸
- iOS图片实现可拉伸不变形的处理操作
- iOS 返回一张可以随意拉伸不变形的图片 方法
- IOS开发-09.图片拉伸不变形